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