mirror of
https://github.com/phpv8/v8js.git
synced 2025-01-08 22:11:52 +00:00
Fix memory leak in zend_read_property; also pass correct scope object.
This commit is contained in:
parent
1c3a919ae8
commit
879d1d54a2
@ -515,8 +515,7 @@ static inline v8::Local<v8::Value> php_v8js_named_property_callback(v8::Local<v8
|
|||||||
v8::Local<v8::Function> cb;
|
v8::Local<v8::Function> cb;
|
||||||
|
|
||||||
V8JS_TSRMLS_FETCH();
|
V8JS_TSRMLS_FETCH();
|
||||||
zend_class_entry *scope = NULL; /* XXX? */
|
zend_class_entry *scope, *ce;
|
||||||
zend_class_entry *ce;
|
|
||||||
zend_function *method_ptr = NULL;
|
zend_function *method_ptr = NULL;
|
||||||
zval *php_value;
|
zval *php_value;
|
||||||
|
|
||||||
@ -524,7 +523,7 @@ static inline v8::Local<v8::Value> php_v8js_named_property_callback(v8::Local<v8
|
|||||||
v8::Local<v8::FunctionTemplate> tmpl =
|
v8::Local<v8::FunctionTemplate> tmpl =
|
||||||
v8::Local<v8::FunctionTemplate>::New
|
v8::Local<v8::FunctionTemplate>::New
|
||||||
(isolate, *reinterpret_cast<v8js_tmpl_t *>(self->GetAlignedPointerFromInternalField(0)));
|
(isolate, *reinterpret_cast<v8js_tmpl_t *>(self->GetAlignedPointerFromInternalField(0)));
|
||||||
ce = Z_OBJCE_P(object);
|
ce = scope = Z_OBJCE_P(object);
|
||||||
|
|
||||||
/* First, check the (case-insensitive) method table */
|
/* First, check the (case-insensitive) method table */
|
||||||
php_strtolower(lower, name_len);
|
php_strtolower(lower, name_len);
|
||||||
@ -599,8 +598,15 @@ static inline v8::Local<v8::Value> php_v8js_named_property_callback(v8::Local<v8
|
|||||||
// wrap it
|
// wrap it
|
||||||
ret_value = zval_to_v8js(php_value, isolate TSRMLS_CC);
|
ret_value = zval_to_v8js(php_value, isolate TSRMLS_CC);
|
||||||
}
|
}
|
||||||
/* php_value is the value in the property table; we don't own a
|
/* php_value is the value in the property table; *usually* we
|
||||||
* reference to it (and so don't have to deref) */
|
* don't own a reference to it (and so don't have to deref).
|
||||||
|
* But sometimes the value is the result of a __get() call and
|
||||||
|
* the refcnt of the returned value is 0. In that case, free
|
||||||
|
* it. */
|
||||||
|
if (php_value != EG(uninitialized_zval_ptr)) {
|
||||||
|
zval_add_ref(&php_value);
|
||||||
|
zval_ptr_dtor(&php_value);
|
||||||
|
}
|
||||||
} else if (callback_type == V8JS_PROP_SETTER) {
|
} else if (callback_type == V8JS_PROP_SETTER) {
|
||||||
MAKE_STD_ZVAL(php_value);
|
MAKE_STD_ZVAL(php_value);
|
||||||
if (v8js_to_zval(set_value, php_value, 0, isolate TSRMLS_CC) == SUCCESS) {
|
if (v8js_to_zval(set_value, php_value, 0, isolate TSRMLS_CC) == SUCCESS) {
|
||||||
|
Loading…
Reference in New Issue
Block a user