tony2001 Thu Aug 24 08:42:16 2006 UTC Added files: (Branch: PHP_4_4) /php-src/ext/standard/tests/file bug38450.phpt
Modified files: /php-src NEWS /php-src/main user_streams.c Log: fix #38450 (constructor is not called for classes used in userspace stream wrappers) http://cvs.php.net/viewvc.cgi/php-src/NEWS?r1=1.1247.2.920.2.158&r2=1.1247.2.920.2.159&diff_format=u Index: php-src/NEWS diff -u php-src/NEWS:1.1247.2.920.2.158 php-src/NEWS:1.1247.2.920.2.159 --- php-src/NEWS:1.1247.2.920.2.158 Thu Aug 24 08:30:28 2006 +++ php-src/NEWS Thu Aug 24 08:42:16 2006 @@ -1,6 +1,8 @@ PHP 4 NEWS ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||| ?? ??? 2006, Version 4.4.5 +- Fixed bug #38450 (constructor is not called for classes used in userspace + stream wrappers). (Tony) - Fixed bug #38378 (wddx_serialize_value() generates no wellformed xml). (sj at sjaensch dot org, grzegorz dot nosek at netart dot pl, Tony). http://cvs.php.net/viewvc.cgi/php-src/main/user_streams.c?r1=1.29.2.4.2.2&r2=1.29.2.4.2.3&diff_format=u Index: php-src/main/user_streams.c diff -u php-src/main/user_streams.c:1.29.2.4.2.2 php-src/main/user_streams.c:1.29.2.4.2.3 --- php-src/main/user_streams.c:1.29.2.4.2.2 Sun Jan 1 13:47:00 2006 +++ php-src/main/user_streams.c Thu Aug 24 08:42:16 2006 @@ -17,7 +17,7 @@ +----------------------------------------------------------------------+ */ -/* $Id: user_streams.c,v 1.29.2.4.2.2 2006/01/01 13:47:00 sniper Exp $ */ +/* $Id: user_streams.c,v 1.29.2.4.2.3 2006/08/24 08:42:16 tony2001 Exp $ */ #include "php.h" #include "php_globals.h" @@ -193,7 +193,33 @@ object_init_ex(us->object, uwrap->ce); ZVAL_REFCOUNT(us->object) = 1; PZVAL_IS_REF(us->object) = 1; - + + if (zend_hash_exists(&uwrap->ce->function_table, uwrap->ce->name, uwrap->ce->name_length+1)) { + zval *retval_ptr; + zval *function_name; + + MAKE_STD_ZVAL(function_name); + ZVAL_STRINGL(function_name, uwrap->ce->name, uwrap->ce->name_length, 1); + + if (call_user_function_ex(EG(function_table), &us->object, function_name, &retval_ptr, 0, 0, 1, NULL TSRMLS_CC) == FAILURE) { + php_error_docref(NULL TSRMLS_CC, E_WARNING, "Could not execute %s::%s()", uwrap->ce->name, uwrap->ce->name); + zval_dtor(function_name); + FREE_ZVAL(function_name); + zval_dtor(us->object); + FREE_ZVAL(us->object); + efree(us); + FG(user_stream_current_filename) = NULL; + return NULL; + } else { + if (retval_ptr) { + zval_ptr_dtor(&retval_ptr); + } + } + zval_dtor(function_name); + FREE_ZVAL(function_name); + } + + /* call it's stream_open method - set up params first */ MAKE_STD_ZVAL(zfilename); ZVAL_STRING(zfilename, filename, 1); http://cvs.php.net/viewvc.cgi/php-src/ext/standard/tests/file/bug38450.phpt?view=markup&rev=1.1 Index: php-src/ext/standard/tests/file/bug38450.phpt +++ php-src/ext/standard/tests/file/bug38450.phpt --TEST-- Bug #38450 (constructor is not called for classes used in userspace stream wrappers) --FILE-- <?php class VariableStream { var $position; var $varname; function VariableStream($var) { var_dump("constructor!"); } function stream_open($path, $mode, $options, &$opened_path) { $url = parse_url($path); $this->varname = $url["host"]; $this->position = 0; return true; } function stream_read($count) { $ret = substr($GLOBALS[$this->varname], $this->position, $count); $this->position += strlen($ret); return $ret; } function stream_write($data) { $left = substr($GLOBALS[$this->varname], 0, $this->position); $right = substr($GLOBALS[$this->varname], $this->position + strlen($data)); $GLOBALS[$this->varname] = $left . $data . $right; $this->position += strlen($data); return strlen($data); } function stream_tell() { return $this->position; } function stream_eof() { return $this->position >= strlen($GLOBALS[$this->varname]); } function stream_seek($offset, $whence) { switch ($whence) { case SEEK_SET: if ($offset < strlen($GLOBALS[$this->varname]) && $offset >= 0) { $this->position = $offset; return true; } else { return false; } break; case SEEK_CUR: if ($offset >= 0) { $this->position += $offset; return true; } else { return false; } break; case SEEK_END: if (strlen($GLOBALS[$this->varname]) + $offset >= 0) { $this->position = strlen($GLOBALS[$this->varname]) + $offset; return true; } else { return false; } break; default: return false; } } } stream_wrapper_register("var", "VariableStream") or die("Failed to register protocol"); $myvar = ""; $fp = fopen("var://myvar", "r+"); fwrite($fp, "line1\n"); fwrite($fp, "line2\n"); fwrite($fp, "line3\n"); rewind($fp); while (!feof($fp)) { echo fgets($fp); } fclose($fp); var_dump($myvar); echo "Done\n"; ?> --EXPECTF-- Warning: Missing argument 1 for VariableStream::VariableStream() in %s on line %d string(12) "constructor!" line1 line2 line3 string(18) "line1 line2 line3 " Done --UEXPECTF-- Warning: Missing argument 1 for VariableStream::VariableStream() in %s on line %d unicode(12) "constructor!" line1 line2 line3 string(18) "line1 line2 line3 " Done -- PHP CVS Mailing List (http://www.php.net/) To unsubscribe, visit: http://www.php.net/unsub.php