]> granicus.if.org Git - php/commitdiff
Fixed bug #64770 stream_select() fails with pipes
authorAnatol Belski <ab@php.net>
Fri, 3 May 2013 15:01:33 +0000 (17:01 +0200)
committerAnatol Belski <ab@php.net>
Fri, 3 May 2013 15:01:33 +0000 (17:01 +0200)
returned by proc_open() on Windows x64

NEWS
ext/standard/streamsfuncs.c
ext/standard/tests/streams/bug64770.phpt [new file with mode: 0644]

diff --git a/NEWS b/NEWS
index cd865d2c8a9e13b9a8ecf283cb3d263393f51159..2d831aeab23fe6c04f465e2e9ae28a23fbeffb57 100644 (file)
--- a/NEWS
+++ b/NEWS
@@ -11,6 +11,10 @@ PHP                                                                        NEWS
   . Fixed bug #64726 (Segfault when calling fetch_object on a use_result and DB
     pointer has closed). (Laruence)
 
+- Streams:
+  . Fixed bug #64770 (stream_select() fails with pipes returned by proc_open()
+    on Windows x64). (Anatol)
+
 ?? ??? 2013, PHP 5.3.25
 
 ### ADD ENTRIES ABOVE FOR 5.3.26. 5.3.25 NEWS WILL BE UPDATED BY RM ON MERGE ###
index 27042f6e5ddf0190153193f45891a3735b8bea07..465d72d37808fb3ddf1c88f442d710e766930360 100644 (file)
@@ -611,7 +611,7 @@ static int stream_array_to_fd_set(zval *stream_array, fd_set *fds, php_socket_t
 {
        zval **elem;
        php_stream *stream;
-       php_socket_t this_fd;
+       php_socket_t this_fd = 0;
        int cnt = 0;
 
        if (Z_TYPE_P(stream_array) != IS_ARRAY) {
@@ -648,7 +648,7 @@ static int stream_array_from_fd_set(zval *stream_array, fd_set *fds TSRMLS_DC)
        zval **elem, **dest_elem;
        php_stream *stream;
        HashTable *new_hash;
-       php_socket_t this_fd;
+       php_socket_t this_fd = 0;
        int ret = 0;
 
        if (Z_TYPE_P(stream_array) != IS_ARRAY) {
diff --git a/ext/standard/tests/streams/bug64770.phpt b/ext/standard/tests/streams/bug64770.phpt
new file mode 100644 (file)
index 0000000..ae738d8
--- /dev/null
@@ -0,0 +1,51 @@
+--TEST--
+Bug #64770 stream_select() fails with pipes from proc_open() 
+--FILE--
+<?php
+
+$descs = array(
+       0 => array('pipe', 'r'), // stdin
+       1 => array('pipe', 'w'), // stdout
+       2 => array('pipe', 'w'), // strerr
+);
+
+$other_opts = array('suppress_errors' => false, 'binary_pipes' => true);
+
+$p = proc_open('dir', $descs, $pipes, '.', NULL, $other_opts);
+
+if (is_resource($p)) {
+       $data = '';
+
+       while (1) {     
+               $w = $e = NULL;
+               $n = stream_select($pipes, $w, $e, 300);
+
+               if ($n === false) {
+                       echo "no streams \n";
+                       break;
+               } else if ($n === 0) {
+                       echo "process timed out\n";
+                       proc_terminate($p, 9);
+                       break;
+               } else if ($n > 0) {
+                       $line = fread($pipes[1], 8192);
+                       if (strlen($line) == 0) {
+                               /* EOF */
+                               break;
+                       }
+                       $data .= $line;
+               }
+       }
+       var_dump(strlen($data));
+
+       $ret = proc_close($p);
+       var_dump($ret);
+} else {
+       echo "no process\n";
+}
+?>
+==DONE==
+--EXPECTF--
+int(%d)
+int(0)
+==DONE==