|
@@ -30,14 +30,14 @@ static void v8js_fetch_php_variable(v8::Local<v8::String> name, const v8::Proper
|
|
v8::Handle<v8::External> data = v8::Handle<v8::External>::Cast(info.Data());
|
|
v8::Handle<v8::External> data = v8::Handle<v8::External>::Cast(info.Data());
|
|
v8js_accessor_ctx *ctx = static_cast<v8js_accessor_ctx *>(data->Value());
|
|
v8js_accessor_ctx *ctx = static_cast<v8js_accessor_ctx *>(data->Value());
|
|
v8::Isolate *isolate = ctx->isolate;
|
|
v8::Isolate *isolate = ctx->isolate;
|
|
- zval **variable;
|
|
|
|
|
|
+ zval *variable;
|
|
|
|
|
|
V8JS_TSRMLS_FETCH();
|
|
V8JS_TSRMLS_FETCH();
|
|
|
|
|
|
- zend_is_auto_global(ctx->variable_name_string, ctx->variable_name_string_len TSRMLS_CC);
|
|
|
|
|
|
+ zend_is_auto_global(ctx->variable_name TSRMLS_CC);
|
|
|
|
|
|
- if (zend_hash_find(&EG(symbol_table), ctx->variable_name_string, ctx->variable_name_string_len + 1, (void **) &variable) == SUCCESS) {
|
|
|
|
- info.GetReturnValue().Set(zval_to_v8js(*variable, isolate TSRMLS_CC));
|
|
|
|
|
|
+ if ((variable = zend_hash_find(&EG(symbol_table), ctx->variable_name))) {
|
|
|
|
+ info.GetReturnValue().Set(zval_to_v8js(variable, isolate TSRMLS_CC));
|
|
return;
|
|
return;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
@@ -45,24 +45,19 @@ static void v8js_fetch_php_variable(v8::Local<v8::String> name, const v8::Proper
|
|
|
|
|
|
void v8js_accessor_ctx_dtor(v8js_accessor_ctx *ctx TSRMLS_DC) /* {{{ */
|
|
void v8js_accessor_ctx_dtor(v8js_accessor_ctx *ctx TSRMLS_DC) /* {{{ */
|
|
{
|
|
{
|
|
- efree(ctx->variable_name_string);
|
|
|
|
|
|
+ zend_string_release(ctx->variable_name);
|
|
efree(ctx);
|
|
efree(ctx);
|
|
}
|
|
}
|
|
/* }}} */
|
|
/* }}} */
|
|
|
|
|
|
void v8js_register_accessors(std::vector<v8js_accessor_ctx*> *accessor_list, v8::Local<v8::FunctionTemplate> php_obj_t, zval *array, v8::Isolate *isolate TSRMLS_DC) /* {{{ */
|
|
void v8js_register_accessors(std::vector<v8js_accessor_ctx*> *accessor_list, v8::Local<v8::FunctionTemplate> php_obj_t, zval *array, v8::Isolate *isolate TSRMLS_DC) /* {{{ */
|
|
{
|
|
{
|
|
- char *property_name;
|
|
|
|
- uint property_name_len;
|
|
|
|
- ulong index;
|
|
|
|
- zval **item;
|
|
|
|
|
|
+ zend_string *property_name;
|
|
|
|
+ zval *item;
|
|
v8::Local<v8::ObjectTemplate> php_obj = php_obj_t->InstanceTemplate();
|
|
v8::Local<v8::ObjectTemplate> php_obj = php_obj_t->InstanceTemplate();
|
|
|
|
|
|
- for (zend_hash_internal_pointer_reset(Z_ARRVAL_P(array));
|
|
|
|
- zend_hash_get_current_data(Z_ARRVAL_P(array), (void **) &item) != FAILURE;
|
|
|
|
- zend_hash_move_forward(Z_ARRVAL_P(array))
|
|
|
|
- ) {
|
|
|
|
- switch (Z_TYPE_PP(item))
|
|
|
|
|
|
+ ZEND_HASH_FOREACH_STR_KEY_VAL(Z_ARRVAL_P(array), property_name, item) {
|
|
|
|
+ switch (Z_TYPE_P(item))
|
|
{
|
|
{
|
|
/*
|
|
/*
|
|
case IS_OBJECT:
|
|
case IS_OBJECT:
|
|
@@ -75,22 +70,17 @@ void v8js_register_accessors(std::vector<v8js_accessor_ctx*> *accessor_list, v8:
|
|
continue; /* Ignore invalid values */
|
|
continue; /* Ignore invalid values */
|
|
}
|
|
}
|
|
|
|
|
|
- if (zend_hash_get_current_key_ex(Z_ARRVAL_P(array), &property_name, &property_name_len, &index, 0, NULL) != HASH_KEY_IS_STRING) {
|
|
|
|
- continue; /* Ignore invalid property names */
|
|
|
|
- }
|
|
|
|
-
|
|
|
|
// Create context to store accessor data
|
|
// Create context to store accessor data
|
|
v8js_accessor_ctx *ctx = (v8js_accessor_ctx *)emalloc(sizeof(v8js_accessor_ctx));
|
|
v8js_accessor_ctx *ctx = (v8js_accessor_ctx *)emalloc(sizeof(v8js_accessor_ctx));
|
|
- ctx->variable_name_string = estrdup(Z_STRVAL_PP(item));
|
|
|
|
- ctx->variable_name_string_len = Z_STRLEN_PP(item);
|
|
|
|
|
|
+ ctx->variable_name = zend_string_copy(Z_STR_P(item));
|
|
ctx->isolate = isolate;
|
|
ctx->isolate = isolate;
|
|
|
|
|
|
/* Set the variable fetch callback for given symbol on named property */
|
|
/* Set the variable fetch callback for given symbol on named property */
|
|
- php_obj->SetAccessor(V8JS_STRL(property_name, property_name_len - 1), v8js_fetch_php_variable, NULL, v8::External::New(isolate, ctx), v8::PROHIBITS_OVERWRITING, v8::ReadOnly, v8::AccessorSignature::New(isolate, php_obj_t));
|
|
|
|
|
|
+ php_obj->SetAccessor(V8JS_ZSTR(property_name), v8js_fetch_php_variable, NULL, v8::External::New(isolate, ctx), v8::PROHIBITS_OVERWRITING, v8::ReadOnly, v8::AccessorSignature::New(isolate, php_obj_t));
|
|
|
|
|
|
/* record the context so we can free it later */
|
|
/* record the context so we can free it later */
|
|
accessor_list->push_back(ctx);
|
|
accessor_list->push_back(ctx);
|
|
- }
|
|
|
|
|
|
+ } ZEND_HASH_FOREACH_END();
|
|
}
|
|
}
|
|
/* }}} */
|
|
/* }}} */
|
|
|
|
|