mirror of
https://github.com/phpv8/v8js.git
synced 2025-01-18 13:51:52 +00:00
Merge pull request #57 from stesie/call-object_properties_init
More fixes on handling of derived V8Js objects and property export
This commit is contained in:
commit
f31c44e524
23
tests/derived_class_properties.phpt
Normal file
23
tests/derived_class_properties.phpt
Normal file
@ -0,0 +1,23 @@
|
|||||||
|
--TEST--
|
||||||
|
Test V8::executeString() : Properties on derived class
|
||||||
|
--SKIPIF--
|
||||||
|
<?php require_once(dirname(__FILE__) . '/skipif.inc'); ?>
|
||||||
|
--FILE--
|
||||||
|
<?php
|
||||||
|
|
||||||
|
class V8Wrapper extends V8Js {
|
||||||
|
public $testing;
|
||||||
|
|
||||||
|
public function __construct() {
|
||||||
|
parent::__construct();
|
||||||
|
$this->testing = 23;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$v8 = new V8Wrapper();
|
||||||
|
$v8->executeString('print("foo\n");');
|
||||||
|
?>
|
||||||
|
===EOF===
|
||||||
|
--EXPECT--
|
||||||
|
foo
|
||||||
|
===EOF===
|
26
tests/derived_class_properties_extra.phpt
Normal file
26
tests/derived_class_properties_extra.phpt
Normal file
@ -0,0 +1,26 @@
|
|||||||
|
--TEST--
|
||||||
|
Test V8::executeString() : Extra properties on derived class
|
||||||
|
--SKIPIF--
|
||||||
|
<?php require_once(dirname(__FILE__) . '/skipif.inc'); ?>
|
||||||
|
--FILE--
|
||||||
|
<?php
|
||||||
|
|
||||||
|
class V8Wrapper extends V8Js {
|
||||||
|
protected $testing;
|
||||||
|
|
||||||
|
public function __construct() {
|
||||||
|
parent::__construct();
|
||||||
|
$this->testing = 23;
|
||||||
|
$this->extraTesting = 42;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$v8 = new V8Wrapper();
|
||||||
|
$v8->executeString('print(PHP.testing + "\n");');
|
||||||
|
$v8->executeString('print(PHP.extraTesting + "\n");');
|
||||||
|
?>
|
||||||
|
===EOF===
|
||||||
|
--EXPECT--
|
||||||
|
undefined
|
||||||
|
42
|
||||||
|
===EOF===
|
26
tests/derived_class_properties_init.phpt
Normal file
26
tests/derived_class_properties_init.phpt
Normal file
@ -0,0 +1,26 @@
|
|||||||
|
--TEST--
|
||||||
|
Test V8::executeString() : Initialized properties on derived class
|
||||||
|
--SKIPIF--
|
||||||
|
<?php require_once(dirname(__FILE__) . '/skipif.inc'); ?>
|
||||||
|
--FILE--
|
||||||
|
<?php
|
||||||
|
|
||||||
|
class V8Wrapper extends V8Js {
|
||||||
|
public $testing = 23;
|
||||||
|
protected $protectedVar = 42;
|
||||||
|
private $privateVar = 42;
|
||||||
|
}
|
||||||
|
|
||||||
|
$v8 = new V8Wrapper();
|
||||||
|
echo($v8->testing."\n");
|
||||||
|
$v8->executeString('print(PHP.testing + "\n");');
|
||||||
|
$v8->executeString('print(PHP.protectedVar + "\n");');
|
||||||
|
$v8->executeString('print(PHP.privateVar + "\n");');
|
||||||
|
?>
|
||||||
|
===EOF===
|
||||||
|
--EXPECT--
|
||||||
|
23
|
||||||
|
23
|
||||||
|
undefined
|
||||||
|
undefined
|
||||||
|
===EOF===
|
27
tests/derived_class_properties_protected.phpt
Normal file
27
tests/derived_class_properties_protected.phpt
Normal file
@ -0,0 +1,27 @@
|
|||||||
|
--TEST--
|
||||||
|
Test V8::executeString() : Protected and private properties on derived class
|
||||||
|
--SKIPIF--
|
||||||
|
<?php require_once(dirname(__FILE__) . '/skipif.inc'); ?>
|
||||||
|
--FILE--
|
||||||
|
<?php
|
||||||
|
|
||||||
|
class V8Wrapper extends V8Js {
|
||||||
|
protected $testing;
|
||||||
|
private $privTesting;
|
||||||
|
|
||||||
|
public function __construct() {
|
||||||
|
parent::__construct();
|
||||||
|
$this->testing = 23;
|
||||||
|
$this->privTesting = 42;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$v8 = new V8Wrapper();
|
||||||
|
$v8->executeString('print(PHP.testing + "\n");');
|
||||||
|
$v8->executeString('print(PHP.privTesting + "\n");');
|
||||||
|
?>
|
||||||
|
===EOF===
|
||||||
|
--EXPECT--
|
||||||
|
undefined
|
||||||
|
undefined
|
||||||
|
===EOF===
|
48
v8js.cc
48
v8js.cc
@ -536,6 +536,10 @@ static zend_object_value php_v8js_new(zend_class_entry *ce TSRMLS_DC) /* {{{ */
|
|||||||
zend_object_std_init(&c->std, ce TSRMLS_CC);
|
zend_object_std_init(&c->std, ce TSRMLS_CC);
|
||||||
#if PHP_VERSION_ID >= 50400
|
#if PHP_VERSION_ID >= 50400
|
||||||
object_properties_init(&c->std, ce);
|
object_properties_init(&c->std, ce);
|
||||||
|
#else
|
||||||
|
zval *tmp;
|
||||||
|
zend_hash_copy(c->std.properties, &ce->default_properties,
|
||||||
|
(copy_ctor_func_t) zval_add_ref, (void *) &tmp, sizeof(zval *));
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
retval.handle = zend_objects_store_put(c, NULL, (zend_objects_free_object_storage_t) php_v8js_free_storage, NULL TSRMLS_CC);
|
retval.handle = zend_objects_store_put(c, NULL, (zend_objects_free_object_storage_t) php_v8js_free_storage, NULL TSRMLS_CC);
|
||||||
@ -762,7 +766,35 @@ static PHP_METHOD(V8Js, __construct)
|
|||||||
c->object_name.Reset(c->isolate, object_name_js);
|
c->object_name.Reset(c->isolate, object_name_js);
|
||||||
|
|
||||||
/* Add the PHP object into global object */
|
/* Add the PHP object into global object */
|
||||||
V8JS_GLOBAL->Set(object_name_js, php_obj_t->InstanceTemplate()->NewInstance(), v8::ReadOnly);
|
v8::Local<v8::Object> php_obj = php_obj_t->InstanceTemplate()->NewInstance();
|
||||||
|
V8JS_GLOBAL->Set(object_name_js, php_obj, v8::ReadOnly);
|
||||||
|
|
||||||
|
/* Export public property values */
|
||||||
|
HashTable *properties = zend_std_get_properties(getThis());
|
||||||
|
HashPosition pos;
|
||||||
|
zval **value;
|
||||||
|
ulong index;
|
||||||
|
char *member;
|
||||||
|
uint member_len;
|
||||||
|
|
||||||
|
for(zend_hash_internal_pointer_reset_ex(properties, &pos);
|
||||||
|
zend_hash_get_current_data_ex(properties, (void **) &value, &pos) == SUCCESS;
|
||||||
|
zend_hash_move_forward_ex(properties, &pos)) {
|
||||||
|
if(zend_hash_get_current_key_ex(properties, &member, &member_len, &index, 0, &pos) != HASH_KEY_IS_STRING) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
zval zmember;
|
||||||
|
ZVAL_STRING(&zmember, member, 0);
|
||||||
|
|
||||||
|
zend_property_info *property_info = zend_get_property_info(c->std.ce, &zmember, 1 TSRMLS_CC);
|
||||||
|
if(property_info && property_info->flags & ZEND_ACC_PUBLIC) {
|
||||||
|
/* Write value to PHP JS object */
|
||||||
|
php_obj->ForceSet(V8JS_SYML(member, member_len - 1), zval_to_v8js(*value, c->isolate TSRMLS_CC), v8::ReadOnly);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
/* }}} */
|
/* }}} */
|
||||||
|
|
||||||
@ -1296,12 +1328,16 @@ static void php_v8js_write_property(zval *object, zval *member, zval *value ZEND
|
|||||||
{
|
{
|
||||||
V8JS_BEGIN_CTX(c, object)
|
V8JS_BEGIN_CTX(c, object)
|
||||||
|
|
||||||
/* Global PHP JS object */
|
/* Check whether member is public, if so, export to V8. */
|
||||||
v8::Local<v8::String> object_name_js = v8::Local<v8::String>::New(c->isolate, c->object_name);
|
zend_property_info *property_info = zend_get_property_info(c->std.ce, member, 1 TSRMLS_CC);
|
||||||
v8::Local<v8::Object> jsobj = V8JS_GLOBAL->Get(object_name_js)->ToObject();
|
if(property_info->flags & ZEND_ACC_PUBLIC) {
|
||||||
|
/* Global PHP JS object */
|
||||||
|
v8::Local<v8::String> object_name_js = v8::Local<v8::String>::New(c->isolate, c->object_name);
|
||||||
|
v8::Local<v8::Object> jsobj = V8JS_GLOBAL->Get(object_name_js)->ToObject();
|
||||||
|
|
||||||
/* Write value to PHP JS object */
|
/* Write value to PHP JS object */
|
||||||
jsobj->ForceSet(V8JS_SYML(Z_STRVAL_P(member), Z_STRLEN_P(member)), zval_to_v8js(value, c->isolate TSRMLS_CC), v8::ReadOnly);
|
jsobj->ForceSet(V8JS_SYML(Z_STRVAL_P(member), Z_STRLEN_P(member)), zval_to_v8js(value, c->isolate TSRMLS_CC), v8::ReadOnly);
|
||||||
|
}
|
||||||
|
|
||||||
/* Write value to PHP object */
|
/* Write value to PHP object */
|
||||||
std_object_handlers.write_property(object, member, value ZEND_HASH_KEY_CC TSRMLS_CC);
|
std_object_handlers.write_property(object, member, value ZEND_HASH_KEY_CC TSRMLS_CC);
|
||||||
|
Loading…
Reference in New Issue
Block a user