ID: 42585 Comment by: atomiku at gmail dot com Reported By: csaba at alum dot mit dot edu Status: Assigned Bug Type: COM related Operating System: Win XP Pro PHP Version: 5.2.4 Assigned To: wharmby New Comment:
I seem to be experiencing this too, this is in my opinion CRITICAL. In the class, it's supposed to die... picture something like this: $someClass->someFunc(); //someFunc is supposed to die. while (true) { echo "Test"; sleep(5); die(); } It actually makes it to the while loop, doesn't print "test" though, it just stops for 5 seconds. If I change to sleep(10), it stops for 10 seconds. No idea what is going on here. Previous Comments: ------------------------------------------------------------------------ [2007-09-07 11:04:43] [EMAIL PROTECTED] Assigned to the COM maintainer. ------------------------------------------------------------------------ [2007-09-07 09:49:16] csaba at alum dot mit dot edu Description: ------------ If I have a COM object call into PHP (via com_event_sink or IE's window.setTimeout) with a die() within the called code, then PHP hangs. In the example below, IE comes up and waits around for 4 seconds, after which an $ie->quit() is issued. In the event handler (function OnQuit()) a die() is issued. While IE does shut down, PHP does not return me the command prompt. This is from PHP CLI, of course. Csaba Gabor from Vienna Reproduce code: --------------- <?php class IESink { public $terminated = false; public function TitleChange($text) { echo("title has changed: $text \n"); } public function OnQuit() { print "Quitting\n"; die(); print "Died\n"; $this->terminated = true; } } $ie = new COM("InternetExplorer.Application"); $ie->Visible = true; $sink = new IESink; com_event_sink($ie, $sink, "DWebBrowserEvents2"); $ie->Navigate("http://www.php.net/"); $start = time(); $quitted = false; while (!$sink->terminated) { com_message_pump(200); if (time()-$start>4 && !$quitted) { $quitted=true; $ie->quit(); } } print "Finished!\n"; ?> Expected result: ---------------- I expect to be shown the following three lines, ie to go away, AND for PHP to terminate: title has changed: PHP: Hypertext Preprocessor title has changed: PHP: Hypertext Preprocessor Quitting Actual result: -------------- The above 3 lines are shown, IE goes away, BUT php does not terminate. Also, note that if I manually shut IE down, instead of waiting the 4 seconds, then I get the following additional line (and PHP still hangs the cmd prompt): Fatal error: Call to undefined method com::quit() in Unknown on line 0 It seems to me that the while loop stays active, since that's the only place that $ie->quit() is issued. ------------------------------------------------------------------------ -- Edit this bug report at http://bugs.php.net/?id=42585&edit=1