From: Dmitry Stogov Date: Wed, 17 Oct 2007 12:09:14 +0000 (+0000) Subject: Fixed possible crash because of uninitialized value (Zdash Urf) X-Git-Tag: RELEASE_2_0_0a1~1578 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=a098b7ead428e8b7af19b43d2025c5a169d03e2e;p=php Fixed possible crash because of uninitialized value (Zdash Urf) --- diff --git a/ext/soap/php_encoding.c b/ext/soap/php_encoding.c index 532aa9c665..7a5b16adac 100644 --- a/ext/soap/php_encoding.c +++ b/ext/soap/php_encoding.c @@ -1135,6 +1135,7 @@ static zval* get_zval_property(zval* object, char* name TSRMLS_DC) zval *data; zend_class_entry *old_scope; + INIT_PZVAL(&member); ZVAL_STRING(&member, name, 0); old_scope = EG(scope); EG(scope) = Z_OBJCE_P(object); @@ -1169,6 +1170,7 @@ static void unset_zval_property(zval* object, char* name TSRMLS_DC) zval member; zend_class_entry *old_scope; + INIT_PZVAL(&member); ZVAL_STRING(&member, name, 0); old_scope = EG(scope); EG(scope) = Z_OBJCE_P(object); diff --git a/ext/soap/tests/classmap004.phpt b/ext/soap/tests/classmap004.phpt new file mode 100755 index 0000000000..3b9d678e6a --- /dev/null +++ b/ext/soap/tests/classmap004.phpt @@ -0,0 +1,66 @@ +--TEST-- +SOAP Classmap 4: encoding of objects with __get() +--SKIPIF-- + +--FILE-- +x = $a; + } + function __get($name) { + return @$this->a[$name]; + } + function __set($name, $val) { + $this->a[$name] = $val; + } + function __unset($name) { + unset($this->a[$name]); + } +} + +class B extends A { + function __construct($a){ + parent::__construct($a); + $this->y = $a + 1; + } +} + +function f(){ + return new B(5); +} + +class LocalSoapClient extends SoapClient { + + function __construct($wsdl, $options) { + parent::__construct($wsdl, $options); + $this->server = new SoapServer($wsdl, $options); + $this->server->addFunction("f"); + } + + function __doRequest($request, $location, $action, $version) { + ob_start(); + $this->server->handle($request); + $response = ob_get_contents(); + ob_end_clean(); + return $response; + } +} + +$client = new LocalSoapClient(dirname(__FILE__)."/classmap003.wsdl", + array('classmap'=>array('A'=>'A','B'=>'B'))); +print_r($client->f()); +?> +--EXPECT-- +B Object +( + [a] => Array + ( + [x] => 5 + [y] => 6 + ) + +)