ID: 39196
Updated by: [EMAIL PROTECTED]
Reported By: [EMAIL PROTECTED]
-Status: Open
+Status: Bogus
Bug Type: Scripting Engine problem
Operating System: Linux 2.6.18-gentoo
PHP Version: 5.2.0RC5
New Comment:
Not PHP problem.
Code like this is supposed to result in endless loop
(ming-0.3.0/src/blocks/jpeg.c:142):
for ( ;; )
{
if ( SWFInput_getChar(input) != JPEG_MARKER )
SWF_error("Jpeg marker not found where expected!");
<skip>
}
Previous Comments:
------------------------------------------------------------------------
[2006-10-19 11:55:37] [EMAIL PROTECTED]
Description:
------------
When the error thrown by SWFMovie::save is catched by the error handler
and "converted" to an exceptions this results in an endless loop.
Tested with 5.2-RC5 and 5.2-RC6-dev.
I tested this with another E_RECOVERABLE_ERROR thrown by a wrong return
value of __toString, which does not cause the endless loop, so that it
is perhaps ming related.
Reproduce code:
---------------
<?php
function errorHandler($errno, $errstr, $errfile, $errline)
{
throw new Exception( 'An error occured.' );
}
set_error_handler( 'errorHandler' );
$movie = new SWFMovie();
$image = new SWFBitmap( file_get_contents(
'http://kore.phpugdo.de/jpg.jpeg' ) );
$object = $movie->add( $image );
$movie->save( 'test.swf' );
Expected result:
----------------
PHP Fatal error: Uncaught exception 'Exception' with message 'An error
occured.' in /path/file.php
Actual result:
--------------
Endless loop
Shortened backtrace after a SIGINT, which made me assume, that is a
problem in the scripting engine:
#0 0x083ea725 in _zend_mm_alloc_int (heap=0x871b3f8, size=16,
__zend_filename=0x86b89e4
"/home/kore/bin/php/php-5.2-cvs/php-src/Zend/zend.c",
__zend_lineno=962,
__zend_orig_filename=0x0, __zend_orig_lineno=0) at
/home/kore/bin/php/php-5.2-cvs/php-src/Zend/zend_alloc.c:1080
#1 0x083eb91a in _emalloc (size=16, __zend_filename=0x86b89e4
"/home/kore/bin/php/php-5.2-cvs/php-src/Zend/zend.c",
__zend_lineno=962, __zend_orig_filename=0x0,
__zend_orig_lineno=0) at
/home/kore/bin/php/php-5.2-cvs/php-src/Zend/zend_alloc.c:1640
#2 0x08406d45 in zend_error (type=4096, format=0x869d417 "%s") at
/home/kore/bin/php/php-5.2-cvs/php-src/Zend/zend.c:962
#3 0x083b6a1c in php_verror (docref=0x88478b4 'Z' <repeats 79 times>,
"\204�\217*Zu", params=0x869cee5 "", type=4096, format=0x86639f9
"%s",
args=0xbf87997c "4q\204\bp�\207\bXZ") at
/home/kore/bin/php/php-5.2-cvs/php-src/main/main.c:584
#4 0x083b6a81 in php_error_docref0 (docref=0x0, type=4096,
format=0x86639f9 "%s") at
/home/kore/bin/php/php-5.2-cvs/php-src/main/main.c:596
#5 0x081d7433 in php_ming_error (msg=0xb7d7ffa0 "Unexpected end of
Jpeg file (EOF found)!") at
/home/kore/bin/php/php-5.2-cvs/php-src/ext/ming/ming.c:4027
#6 0xb7d64403 in methodWriteJpegFile () from /usr/lib/libming.so.0
------------------------------------------------------------------------
--
Edit this bug report at http://bugs.php.net/?id=39196&edit=1