From fcb056b5a51cbdbfe82885773f7ba5e580944122 Mon Sep 17 00:00:00 2001 From: Stefan Siegl Date: Mon, 28 Sep 2015 22:57:00 +0200 Subject: [PATCH] Handle access of undeclared properties --- v8js_object_export.cc | 18 +++++++++--------- 1 file changed, 9 insertions(+), 9 deletions(-) diff --git a/v8js_object_export.cc b/v8js_object_export.cc index a9c65a5..f3eb27a 100644 --- a/v8js_object_export.cc +++ b/v8js_object_export.cc @@ -594,9 +594,9 @@ inline v8::Local v8js_named_property_callback(v8::Local p /* Nope, not a method -- must be a (case-sensitive) property */ zend_property_info *property_info = zend_get_property_info(ce, Z_STR(zname), 1 TSRMLS_CC); - if(property_info && - property_info != ZEND_WRONG_PROPERTY_INFO && - property_info->flags & ZEND_ACC_PUBLIC) { + if(!property_info || + (property_info != ZEND_WRONG_PROPERTY_INFO && + property_info->flags & ZEND_ACC_PUBLIC)) { zval *property_val = zend_read_property(NULL, &zobject, V8JS_CONST name, name_len, true, &php_value TSRMLS_CC); // special case uninitialized_zval_ptr and return an empty value // (indicating that we don't intercept this property) if the @@ -631,9 +631,9 @@ inline v8::Local v8js_named_property_callback(v8::Local p else { zend_property_info *property_info = zend_get_property_info(ce, Z_STR(zname), 1 TSRMLS_CC); - if(property_info && - property_info != ZEND_WRONG_PROPERTY_INFO && - property_info->flags & ZEND_ACC_PUBLIC) { + if(!property_info || + (property_info != ZEND_WRONG_PROPERTY_INFO && + property_info->flags & ZEND_ACC_PUBLIC)) { zend_update_property(scope, &zobject, V8JS_CONST name, name_len, &php_value TSRMLS_CC); ret_value = set_value; } @@ -664,9 +664,9 @@ inline v8::Local v8js_named_property_callback(v8::Local p } else { zend_property_info *property_info = zend_get_property_info(ce, Z_STR(zname), 1 TSRMLS_CC); - if(property_info && - property_info != ZEND_WRONG_PROPERTY_INFO && - property_info->flags & ZEND_ACC_PUBLIC) { + if(!property_info || + (property_info != ZEND_WRONG_PROPERTY_INFO && + property_info->flags & ZEND_ACC_PUBLIC)) { h->unset_property(&zobject, &zname, NULL TSRMLS_CC); ret_value = V8JS_TRUE(); }