From: Michael Wallner Date: Wed, 21 Jan 2015 16:10:29 +0000 (+0100) Subject: fix read_property handler (return_value lives on stack of zend_read_property) X-Git-Tag: RELEASE_3_0_0_RC1~79 X-Git-Url: https://git.m6w6.name/?p=m6w6%2Fext-http;a=commitdiff_plain;h=1f934bf6f8bf9343eac1fdc7fdba5959b8d062a1 fix read_property handler (return_value lives on stack of zend_read_property) --- diff --git a/php_http_message.c b/php_http_message.c index bf8eb50..f391d5f 100644 --- a/php_http_message.c +++ b/php_http_message.c @@ -859,15 +859,18 @@ static zval *php_http_message_object_read_prop(zval *object, zval *member, int t PHP_HTTP_MESSAGE_OBJECT_INIT(obj); + /* supplied retun_value lives on the stack of zend_read_property! */ + return_value = zend_get_std_object_handlers()->read_property(object, member, type, cache_slot, return_value); + if ((handler = php_http_message_object_get_prophandler(member_name))) { + zval_dtor(return_value); + if (type == BP_VAR_R) { handler->read(obj, return_value); } else { php_property_proxy_t *proxy = php_property_proxy_init(object, member_name); RETVAL_OBJ(&php_property_proxy_object_new_ex(php_property_proxy_get_class_entry(), proxy)->zo); } - } else { - zend_get_std_object_handlers()->read_property(object, member, type, cache_slot, return_value); } zend_string_release(member_name);