diff options
| author | Dmitry Stogov <dmitry@php.net> | 2007-10-17 12:09:14 +0000 |
|---|---|---|
| committer | Dmitry Stogov <dmitry@php.net> | 2007-10-17 12:09:14 +0000 |
| commit | a098b7ead428e8b7af19b43d2025c5a169d03e2e (patch) | |
| tree | 5155c926aff73cf7e0fd63414893e5ba88f6bb67 | |
| parent | e61f2d2ad32e01522aae6b3da77dacbcdf6a205b (diff) | |
| download | php-git-a098b7ead428e8b7af19b43d2025c5a169d03e2e.tar.gz | |
Fixed possible crash because of uninitialized value (Zdash Urf)
| -rw-r--r-- | ext/soap/php_encoding.c | 2 | ||||
| -rwxr-xr-x | ext/soap/tests/classmap004.phpt | 66 |
2 files changed, 68 insertions, 0 deletions
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-- +<?php require_once('skipif.inc'); ?> +--FILE-- +<?php +ini_set("soap.wsdl_cache_enabled",0); + +class A { + public $a; + function __construct($a){ + $this->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 + ) + +) |
