ID:               45928
 Comment by:       cschneid at cschneid dot com
 Reported By:      [EMAIL PROTECTED]
 Status:           Critical
 Bug Type:         CGI related
 Operating System: Mac OS X 10.5
 PHP Version:      5.3CVS-2008-08-26 (CVS)
 New Comment:

I had a quick look at this bug and found the problem to be in
Zend/zend_stream.c function zend_stream_fsize(): It uses fstat() to
determine the filesize which on MacOS X for pipes returns either 0 (my
interpretation: no data from the pipe ready yet) or a number up to 16384
(my interpretation: data from the pipe ready but the maximum buffer size
is 16k).

I see several solutions but I'm not sure which is the desired one:
- return 0 (size unknown) if the file is a pipe (or socket, ...)
- return 0 if the file is not a regular file (or symlink, dir?)
- look into a way of determining EOF reached

As a quick test I changed
        return buf.st_size;
in function zend_stream_fsize() to
        return 0;
and cat 30k.php | php worked after that.

I posted this to [EMAIL PROTECTED] but did not get any reply so I'm not
sure how to proceed.


Previous Comments:
------------------------------------------------------------------------

[2008-08-26 18:24:52] [EMAIL PROTECTED]

Description:
------------
any php-file which is larger that 16Kb will result in parse error on
Mac OS X, if run as following:
cat largefile.php|php -l

while the following options will work:
php -l largefile.php
php -l < largefile.php

"-l" flag is optional. it can be reproduced without it too

I discussed this with Rasmus (he was able to reproduce this problem
too), and he mentioned, that this bug is most likely re2c-related

Expected result:
----------------
No syntax errors detected in -

Actual result:
--------------
PHP Parse error:  syntax error, unexpected $end in …


------------------------------------------------------------------------


-- 
Edit this bug report at http://bugs.php.net/?id=45928&edit=1

Reply via email to