mirror of
https://github.com/phpv8/v8js.git
synced 2025-01-03 16:51:52 +00:00
Re-use v8js_ctx context for V8Function calls, closes #158
This commit is contained in:
parent
e6d2de2c4f
commit
ae33f6a9ab
@ -50,10 +50,10 @@ void v8js_terminate_execution(v8js_ctx *c TSRMLS_DC);
|
|||||||
/* Fetch V8 object properties */
|
/* Fetch V8 object properties */
|
||||||
int v8js_get_properties_hash(v8::Handle<v8::Value> jsValue, HashTable *retval, int flags, v8::Isolate *isolate TSRMLS_DC);
|
int v8js_get_properties_hash(v8::Handle<v8::Value> jsValue, HashTable *retval, int flags, v8::Isolate *isolate TSRMLS_DC);
|
||||||
|
|
||||||
#define V8JS_CTX_PROLOGUE(ctx) \
|
#define V8JS_CTX_PROLOGUE_EX(ctx, ret) \
|
||||||
if (!V8JSG(v8_initialized)) { \
|
if (!V8JSG(v8_initialized)) { \
|
||||||
zend_error(E_ERROR, "V8 not initialized"); \
|
zend_error(E_ERROR, "V8 not initialized"); \
|
||||||
return; \
|
return ret; \
|
||||||
} \
|
} \
|
||||||
\
|
\
|
||||||
v8::Isolate *isolate = (ctx)->isolate; \
|
v8::Isolate *isolate = (ctx)->isolate; \
|
||||||
@ -63,6 +63,9 @@ int v8js_get_properties_hash(v8::Handle<v8::Value> jsValue, HashTable *retval, i
|
|||||||
v8::Local<v8::Context> v8_context = v8::Local<v8::Context>::New(isolate, (ctx)->context); \
|
v8::Local<v8::Context> v8_context = v8::Local<v8::Context>::New(isolate, (ctx)->context); \
|
||||||
v8::Context::Scope context_scope(v8_context);
|
v8::Context::Scope context_scope(v8_context);
|
||||||
|
|
||||||
|
#define V8JS_CTX_PROLOGUE(ctx) \
|
||||||
|
V8JS_CTX_PROLOGUE_EX(ctx,)
|
||||||
|
|
||||||
#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) = (v8js_ctx *) zend_object_store_get_object(object TSRMLS_CC); \
|
||||||
|
@ -60,13 +60,7 @@ static int v8js_v8object_has_property(zval *object, zval *member, int has_set_ex
|
|||||||
return retval;
|
return retval;
|
||||||
}
|
}
|
||||||
|
|
||||||
v8::Isolate *isolate = obj->ctx->isolate;
|
V8JS_CTX_PROLOGUE_EX(obj->ctx, retval);
|
||||||
v8::Locker locker(isolate);
|
|
||||||
v8::Isolate::Scope isolate_scope(isolate);
|
|
||||||
v8::HandleScope local_scope(isolate);
|
|
||||||
v8::Local<v8::Context> temp_context = v8::Context::New(isolate);
|
|
||||||
v8::Context::Scope temp_scope(temp_context);
|
|
||||||
|
|
||||||
v8::Local<v8::Value> v8obj = v8::Local<v8::Value>::New(isolate, obj->v8obj);
|
v8::Local<v8::Value> v8obj = v8::Local<v8::Value>::New(isolate, obj->v8obj);
|
||||||
|
|
||||||
if (Z_TYPE_P(member) == IS_STRING && v8obj->IsObject() && !v8obj->IsFunction())
|
if (Z_TYPE_P(member) == IS_STRING && v8obj->IsObject() && !v8obj->IsFunction())
|
||||||
@ -126,13 +120,7 @@ static zval *v8js_v8object_read_property(zval *object, zval *member, int type ZE
|
|||||||
return retval;
|
return retval;
|
||||||
}
|
}
|
||||||
|
|
||||||
v8::Isolate *isolate = obj->ctx->isolate;
|
V8JS_CTX_PROLOGUE_EX(obj->ctx, retval);
|
||||||
v8::Locker locker(isolate);
|
|
||||||
v8::Isolate::Scope isolate_scope(isolate);
|
|
||||||
v8::HandleScope local_scope(isolate);
|
|
||||||
v8::Local<v8::Context> temp_context = v8::Context::New(isolate);
|
|
||||||
v8::Context::Scope temp_scope(temp_context);
|
|
||||||
|
|
||||||
v8::Local<v8::Value> v8obj = v8::Local<v8::Value>::New(isolate, obj->v8obj);
|
v8::Local<v8::Value> v8obj = v8::Local<v8::Value>::New(isolate, obj->v8obj);
|
||||||
|
|
||||||
if (Z_TYPE_P(member) == IS_STRING && v8obj->IsObject() && !v8obj->IsFunction())
|
if (Z_TYPE_P(member) == IS_STRING && v8obj->IsObject() && !v8obj->IsFunction())
|
||||||
@ -175,13 +163,7 @@ static void v8js_v8object_write_property(zval *object, zval *member, zval *value
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
v8::Isolate *isolate = obj->ctx->isolate;
|
V8JS_CTX_PROLOGUE(obj->ctx);
|
||||||
v8::Locker locker(isolate);
|
|
||||||
v8::Isolate::Scope isolate_scope(isolate);
|
|
||||||
v8::HandleScope local_scope(isolate);
|
|
||||||
v8::Local<v8::Context> temp_context = v8::Context::New(isolate);
|
|
||||||
v8::Context::Scope temp_scope(temp_context);
|
|
||||||
|
|
||||||
v8::Local<v8::Value> v8obj = v8::Local<v8::Value>::New(isolate, obj->v8obj);
|
v8::Local<v8::Value> v8obj = v8::Local<v8::Value>::New(isolate, obj->v8obj);
|
||||||
|
|
||||||
if (v8obj->IsObject() && !v8obj->IsFunction()) {
|
if (v8obj->IsObject() && !v8obj->IsFunction()) {
|
||||||
@ -200,13 +182,7 @@ static void v8js_v8object_unset_property(zval *object, zval *member ZEND_HASH_KE
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
v8::Isolate *isolate = obj->ctx->isolate;
|
V8JS_CTX_PROLOGUE(obj->ctx);
|
||||||
v8::Locker locker(isolate);
|
|
||||||
v8::Isolate::Scope isolate_scope(isolate);
|
|
||||||
v8::HandleScope local_scope(isolate);
|
|
||||||
v8::Local<v8::Context> temp_context = v8::Context::New(isolate);
|
|
||||||
v8::Context::Scope temp_scope(temp_context);
|
|
||||||
|
|
||||||
v8::Local<v8::Value> v8obj = v8::Local<v8::Value>::New(isolate, obj->v8obj);
|
v8::Local<v8::Value> v8obj = v8::Local<v8::Value>::New(isolate, obj->v8obj);
|
||||||
|
|
||||||
if (v8obj->IsObject() && !v8obj->IsFunction()) {
|
if (v8obj->IsObject() && !v8obj->IsFunction()) {
|
||||||
@ -245,12 +221,7 @@ static HashTable *v8js_v8object_get_properties(zval *object TSRMLS_DC) /* {{{ */
|
|||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
v8::Isolate *isolate = obj->ctx->isolate;
|
V8JS_CTX_PROLOGUE_EX(obj->ctx, NULL);
|
||||||
v8::Locker locker(isolate);
|
|
||||||
v8::Isolate::Scope isolate_scope(isolate);
|
|
||||||
v8::HandleScope local_scope(isolate);
|
|
||||||
v8::Local<v8::Context> temp_context = v8::Context::New(isolate);
|
|
||||||
v8::Context::Scope temp_scope(temp_context);
|
|
||||||
v8::Local<v8::Value> v8obj = v8::Local<v8::Value>::New(isolate, obj->v8obj);
|
v8::Local<v8::Value> v8obj = v8::Local<v8::Value>::New(isolate, obj->v8obj);
|
||||||
|
|
||||||
if (v8js_get_properties_hash(v8obj, obj->properties, obj->flags, isolate TSRMLS_CC) == SUCCESS) {
|
if (v8js_get_properties_hash(v8obj, obj->properties, obj->flags, isolate TSRMLS_CC) == SUCCESS) {
|
||||||
@ -279,12 +250,7 @@ static zend_function *v8js_v8object_get_method(zval **object_ptr, char *method,
|
|||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
v8::Isolate *isolate = obj->ctx->isolate;
|
V8JS_CTX_PROLOGUE_EX(obj->ctx, NULL);
|
||||||
v8::Locker locker(isolate);
|
|
||||||
v8::Isolate::Scope isolate_scope(isolate);
|
|
||||||
v8::HandleScope local_scope(isolate);
|
|
||||||
v8::Local<v8::Context> temp_context = v8::Context::New(isolate);
|
|
||||||
v8::Context::Scope temp_scope(temp_context);
|
|
||||||
v8::Local<v8::String> jsKey = V8JS_STRL(method, method_len);
|
v8::Local<v8::String> jsKey = V8JS_STRL(method, method_len);
|
||||||
v8::Local<v8::Value> v8obj = v8::Local<v8::Value>::New(isolate, obj->v8obj);
|
v8::Local<v8::Value> v8obj = v8::Local<v8::Value>::New(isolate, obj->v8obj);
|
||||||
|
|
||||||
@ -378,12 +344,7 @@ static int v8js_v8object_get_closure(zval *object, zend_class_entry **ce_ptr, ze
|
|||||||
return FAILURE;
|
return FAILURE;
|
||||||
}
|
}
|
||||||
|
|
||||||
v8::Isolate *isolate = obj->ctx->isolate;
|
V8JS_CTX_PROLOGUE_EX(obj->ctx, FAILURE);
|
||||||
v8::Locker locker(isolate);
|
|
||||||
v8::Isolate::Scope isolate_scope(isolate);
|
|
||||||
v8::HandleScope local_scope(isolate);
|
|
||||||
v8::Local<v8::Context> temp_context = v8::Context::New(isolate);
|
|
||||||
v8::Context::Scope temp_scope(temp_context);
|
|
||||||
v8::Local<v8::Value> v8obj = v8::Local<v8::Value>::New(isolate, obj->v8obj);
|
v8::Local<v8::Value> v8obj = v8::Local<v8::Value>::New(isolate, obj->v8obj);
|
||||||
|
|
||||||
if (!v8obj->IsFunction()) {
|
if (!v8obj->IsFunction()) {
|
||||||
|
Loading…
Reference in New Issue
Block a user