ID: 49694 Updated by: j...@php.net Reported By: compconsultant at yahoo dot com -Status: Open +Status: Feedback Bug Type: Streams related Operating System: Centos 5.3 PHP Version: 5.2.11 New Comment:
Isn't it tail that "hangs" since you use -F instead of -f ? Previous Comments: ------------------------------------------------------------------------ [2009-10-05 14:54:17] compconsultant at yahoo dot com Same result, no difference, no "ok" displayed ------------------------------------------------------------------------ [2009-09-27 22:57:05] compconsultant at yahoo dot com Description: ------------ Using proc_open to open a pipe to a command, and, putting stream_select into a function, hangs upon return from that function. Reproduce code: --------------- <?php function SelectStream($StreamsArray) { $Null = array(); $timeout = NULL; stream_select($StreamsArray, $Null, $Null, $timeout); echo "After select\n"; return FALSE; } $ProcDescriptor = array(1 => array("pipe", "w")); $Resource = proc_open("tail -F /var/log/mail.log", $ProcDescriptor, $Pipes, NULL, NULL, array("binary_pipes" => TRUE)); if ($Resource === FALSE) die("proc_open failed\n"); $ProgResource = $Pipes[1]; /* $ProgResource = popen("tail -F /var/log/mail.log", "r"); if ($ProgResource === FALSE) die("Could not open the PIPE\n"); */ $Streams[] = $ProgResource; $Resource = SelectStream($Streams); echo "ok\n"; ?> Expected result: ---------------- I expect ok to be displayed. If you replace proc_open with popen (uncomment the lines), the same function returns fine (ok displayed). If you remove the stream_select, it also returns fine. Actual result: -------------- The string ok is not displayed, the statement is never reached. After select is displayed. So, it is hanging on the return statement. ------------------------------------------------------------------------ -- Edit this bug report at http://bugs.php.net/?id=49694&edit=1