0
0
mirror of https://github.com/phpv8/v8js.git synced 2025-01-05 12:51:53 +00:00

v8js_class.cc pt.2 for PHP7, zend_object_store_get_object stuff & script resource

This commit is contained in:
Stefan Siegl 2015-08-25 00:24:04 +02:00
parent a10e601af3
commit 3fa38e7b87
3 changed files with 38 additions and 38 deletions

View File

@ -79,13 +79,10 @@ public:
}; };
#endif #endif
static inline struct v8js_ctx *v8js_fetch_object(zend_object *obj) {
return (struct v8js_ctx *)((char *)obj - XtOffsetOf(struct v8js_ctx, std));
}
static void v8js_free_storage(zend_object *object TSRMLS_DC) /* {{{ */ static void v8js_free_storage(zend_object *object TSRMLS_DC) /* {{{ */
{ {
v8js_ctx *c = v8js_fetch_object(object); v8js_ctx *c = v8js_ctx_fetch_object(object);
zend_object_std_dtor(&c->std TSRMLS_CC); zend_object_std_dtor(&c->std TSRMLS_CC);
zval_dtor(&c->pending_exception); zval_dtor(&c->pending_exception);
@ -254,14 +251,14 @@ static int v8js_create_ext_strarr(const char ***retval, int count, HashTable *ht
{ {
const char **exts = NULL; const char **exts = NULL;
HashPosition pos; HashPosition pos;
zval **tmp; zval *tmp;
int i = 0; int i = 0;
exts = (const char **) calloc(1, count * sizeof(char *)); exts = (const char **) calloc(1, count * sizeof(char *));
zend_hash_internal_pointer_reset_ex(ht, &pos); zend_hash_internal_pointer_reset_ex(ht, &pos);
while (zend_hash_get_current_data_ex(ht, (void **) &tmp, &pos) == SUCCESS) { while ((tmp = zend_hash_get_current_data_ex(ht, &pos))) {
if (Z_TYPE_PP(tmp) == IS_STRING) { if (Z_TYPE_P(tmp) == IS_STRING) {
exts[i++] = zend_strndup(Z_STRVAL_PP(tmp), Z_STRLEN_PP(tmp)); exts[i++] = zend_strndup(Z_STRVAL_P(tmp), Z_STRLEN_P(tmp));
} else { } else {
v8js_free_ext_strarr(exts, i); v8js_free_ext_strarr(exts, i);
return FAILURE; return FAILURE;
@ -294,13 +291,13 @@ static PHP_METHOD(V8Js, __construct)
{ {
char *object_name = NULL, *class_name = NULL; char *object_name = NULL, *class_name = NULL;
int object_name_len = 0, free = 0; int object_name_len = 0, free = 0;
zend_uint class_name_len = 0; unsigned int class_name_len = 0;
zend_bool report_uncaught = 1; zend_bool report_uncaught = 1;
zval *vars_arr = NULL, *exts_arr = NULL; zval *vars_arr = NULL, *exts_arr = NULL;
const char **exts = NULL; const char **exts = NULL;
int exts_count = 0; int exts_count = 0;
v8js_ctx *c = (v8js_ctx *) zend_object_store_get_object(getThis() TSRMLS_CC); v8js_ctx *c = Z_V8JS_CTX_OBJ_P(getThis())
if (!c->context.IsEmpty()) { if (!c->context.IsEmpty()) {
/* called __construct() twice, bail out */ /* called __construct() twice, bail out */
@ -398,8 +395,8 @@ static PHP_METHOD(V8Js, __construct)
v8::Local<v8::FunctionTemplate> php_obj_t = v8::FunctionTemplate::New(isolate, 0); v8::Local<v8::FunctionTemplate> php_obj_t = v8::FunctionTemplate::New(isolate, 0);
/* Set class name for PHP object */ /* Set class name for PHP object */
free = !zend_get_object_classname(getThis(), const_cast<const char**>(&class_name), &class_name_len TSRMLS_CC); zend_class_entry *ce = Z_OBJCE_P(getThis());
php_obj_t->SetClassName(V8JS_SYML(class_name, class_name_len)); php_obj_t->SetClassName(V8JS_SYML(ZSTR_VAL(ce->name), ZSTR_LEN(ce->name)));
if (free) { if (free) {
efree(class_name); efree(class_name);
@ -421,25 +418,22 @@ static PHP_METHOD(V8Js, __construct)
/* Export public property values */ /* Export public property values */
HashTable *properties = zend_std_get_properties(getThis() TSRMLS_CC); HashTable *properties = zend_std_get_properties(getThis() TSRMLS_CC);
HashPosition pos; HashPosition pos;
zval **value; zval *value;
ulong index; ulong index;
char *member; zend_string *member;
uint member_len; uint member_len;
for(zend_hash_internal_pointer_reset_ex(properties, &pos); for(zend_hash_internal_pointer_reset_ex(properties, &pos);
zend_hash_get_current_data_ex(properties, (void **) &value, &pos) == SUCCESS; value = zend_hash_get_current_data_ex(properties, &pos);
zend_hash_move_forward_ex(properties, &pos)) { 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) { if(zend_hash_get_current_key_ex(properties, &member, &index, &pos) != HASH_KEY_IS_STRING) {
continue; continue;
} }
zval zmember; zend_property_info *property_info = zend_get_property_info(c->std.ce, member, 1 TSRMLS_CC);
ZVAL_STRING(&zmember, member);
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) { if(property_info && property_info->flags & ZEND_ACC_PUBLIC) {
/* Write value to PHP JS object */ /* Write value to PHP JS object */
php_obj->ForceSet(V8JS_SYML(member, member_len - 1), zval_to_v8js(*value, isolate TSRMLS_CC), v8::ReadOnly); php_obj->ForceSet(V8JS_SYML(ZSTR_VAL(member), ZSTR_LEN(member) - 1), zval_to_v8js(*value, isolate TSRMLS_CC), v8::ReadOnly);
} }
} }
@ -500,7 +494,7 @@ static void v8js_compile_script(zval *this_ptr, const char *str, int str_len, co
static void v8js_execute_script(zval *this_ptr, v8js_script *res, long flags, long time_limit, long memory_limit, zval **return_value TSRMLS_DC) static void v8js_execute_script(zval *this_ptr, v8js_script *res, long flags, long time_limit, long memory_limit, zval **return_value TSRMLS_DC)
{ {
v8js_ctx *c = (v8js_ctx *) zend_object_store_get_object(getThis() TSRMLS_CC); v8js_ctx *c = Z_V8JS_CTX_OBJ_P(this_ptr);
if (res->ctx != c) { if (res->ctx != c) {
zend_error(E_WARNING, "Script resource from wrong V8Js object passed"); zend_error(E_WARNING, "Script resource from wrong V8Js object passed");
@ -562,10 +556,10 @@ static PHP_METHOD(V8Js, compileString)
v8js_compile_script(getThis(), str, str_len, identifier, identifier_len, &res TSRMLS_CC); v8js_compile_script(getThis(), str, str_len, identifier, identifier_len, &res TSRMLS_CC);
if (res) { if (res) {
ZEND_REGISTER_RESOURCE(return_value, res, le_v8js_script); RETURN_RES(zend_register_resource(res, le_v8js_script));
v8js_ctx *ctx; v8js_ctx *ctx;
ctx = (v8js_ctx *) zend_object_store_get_object(this_ptr TSRMLS_CC); ctx = Z_V8JS_CTX_OBJ_P(getThis());
ctx->script_objects.push_back(res); ctx->script_objects.push_back(res);
} }
return; return;
@ -585,8 +579,9 @@ static PHP_METHOD(V8Js, executeScript)
return; return;
} }
ZEND_FETCH_RESOURCE(res, v8js_script*, &zscript, -1, PHP_V8JS_SCRIPT_RES_NAME, le_v8js_script); if((res = (v8js_script *)zend_fetch_resource(Z_RES_P(zscript), PHP_V8JS_SCRIPT_RES_NAME, le_v8js_script)) == NULL) {
ZEND_VERIFY_RESOURCE(res); RETURN_FALSE;
}
v8js_execute_script(getThis(), res, flags, time_limit, memory_limit, &return_value TSRMLS_CC); v8js_execute_script(getThis(), res, flags, time_limit, memory_limit, &return_value TSRMLS_CC);
} }
@ -628,10 +623,10 @@ static PHP_METHOD(V8Js, getPendingException)
return; return;
} }
c = (v8js_ctx *) zend_object_store_get_object(getThis() TSRMLS_CC); c = Z_V8JS_CTX_OBJ_P(getThis());
if (c->pending_exception) { if (Z_TYPE(c->pending_exception) == IS_OBJECT) {
RETURN_ZVAL(c->pending_exception, 1, 0); RETURN_ZVAL(&c->pending_exception, 1, 0);
} }
} }
/* }}} */ /* }}} */
@ -646,11 +641,11 @@ static PHP_METHOD(V8Js, clearPendingException)
return; return;
} }
c = (v8js_ctx *) zend_object_store_get_object(getThis() TSRMLS_CC); c = Z_V8JS_CTX_OBJ_P(getThis());
if (c->pending_exception) { if (Z_TYPE(c->pending_exception) == IS_OBJECT) {
zval_ptr_dtor(&c->pending_exception); zval_dtor(&c->pending_exception);
c->pending_exception = NULL; ZVAL_NULL(&c->pending_exception);
} }
} }
/* }}} */ /* }}} */
@ -666,8 +661,7 @@ static PHP_METHOD(V8Js, setModuleLoader)
return; return;
} }
c = (v8js_ctx *) zend_object_store_get_object(getThis() TSRMLS_CC); c = Z_V8JS_CTX_OBJ_P(getThis());
ZVAL_COPY(&c->module_loader, &callable); ZVAL_COPY(&c->module_loader, &callable);
} }
/* }}} */ /* }}} */
@ -683,7 +677,7 @@ static PHP_METHOD(V8Js, setTimeLimit)
return; return;
} }
c = (v8js_ctx *) zend_object_store_get_object(getThis() TSRMLS_CC); c = Z_V8JS_CTX_OBJ_P(getThis());
c->time_limit = time_limit; c->time_limit = time_limit;
V8JSG(timer_mutex).lock(); V8JSG(timer_mutex).lock();
@ -719,7 +713,7 @@ static PHP_METHOD(V8Js, setMemoryLimit)
return; return;
} }
c = (v8js_ctx *) zend_object_store_get_object(getThis() TSRMLS_CC); c = Z_V8JS_CTX_OBJ_P(getThis());
c->memory_limit = memory_limit; c->memory_limit = memory_limit;
V8JSG(timer_mutex).lock(); V8JSG(timer_mutex).lock();

View File

@ -74,6 +74,12 @@ struct v8js_ctx {
# define V8JS_TSRMLS_FETCH() # define V8JS_TSRMLS_FETCH()
#endif #endif
static inline struct v8js_ctx *v8js_ctx_fetch_object(zend_object *obj) {
return (struct v8js_ctx *)((char *)obj - XtOffsetOf(struct v8js_ctx, std));
}
#define Z_V8JS_CTX_OBJ_P(zv) v8js_ctx_fetch_object(Z_OBJ_P(zv));
PHP_MINIT_FUNCTION(v8js_class); PHP_MINIT_FUNCTION(v8js_class);

View File

@ -65,7 +65,7 @@ int v8js_get_properties_hash(v8::Handle<v8::Value> jsValue, HashTable *retval, i
#define V8JS_BEGIN_CTX(ctx, object) \ #define V8JS_BEGIN_CTX(ctx, object) \
v8js_ctx *(ctx); \ v8js_ctx *(ctx); \
(ctx) = (v8js_ctx *) zend_object_store_get_object(object TSRMLS_CC); \ (ctx) = Z_V8JS_CTX_OBJ_P(object); \
V8JS_CTX_PROLOGUE(ctx); V8JS_CTX_PROLOGUE(ctx);