0
0
mirror of https://github.com/phpv8/v8js.git synced 2025-01-20 17:31:51 +00:00

Merge pull request #163 from stesie/cache-array-tmpl

Cache pseudo-Array FunctionTemplate as well
This commit is contained in:
Stefan Siegl 2015-09-01 16:14:48 +02:00
commit fa352e216f
3 changed files with 20 additions and 6 deletions

View File

@ -108,6 +108,8 @@ static void v8js_free_storage(void *object TSRMLS_DC) /* {{{ */
c->object_name.~Persistent(); c->object_name.~Persistent();
c->global_template.Reset(); c->global_template.Reset();
c->global_template.~Persistent(); c->global_template.~Persistent();
c->array_tmpl.Reset();
c->array_tmpl.~Persistent();
/* Clear persistent call_impl & method_tmpls templates */ /* Clear persistent call_impl & method_tmpls templates */
for (std::map<v8js_tmpl_t *, v8js_tmpl_t>::iterator it = c->call_impls.begin(); for (std::map<v8js_tmpl_t *, v8js_tmpl_t>::iterator it = c->call_impls.begin();
@ -221,6 +223,7 @@ static zend_object_value v8js_new(zend_class_entry *ce TSRMLS_DC) /* {{{ */
new(&c->object_name) v8::Persistent<v8::String>(); new(&c->object_name) v8::Persistent<v8::String>();
new(&c->context) v8::Persistent<v8::Context>(); new(&c->context) v8::Persistent<v8::Context>();
new(&c->global_template) v8::Persistent<v8::FunctionTemplate>(); new(&c->global_template) v8::Persistent<v8::FunctionTemplate>();
new(&c->array_tmpl) v8::Persistent<v8::FunctionTemplate>();
new(&c->modules_stack) std::vector<char*>(); new(&c->modules_stack) std::vector<char*>();
new(&c->modules_base) std::vector<char*>(); new(&c->modules_base) std::vector<char*>();

View File

@ -45,7 +45,8 @@ struct v8js_ctx {
long memory_limit; long memory_limit;
bool memory_limit_hit; bool memory_limit_hit;
v8::Persistent<v8::FunctionTemplate> global_template; v8js_tmpl_t global_template;
v8js_tmpl_t array_tmpl;
zval *module_loader; zval *module_loader;
std::vector<char *> modules_stack; std::vector<char *> modules_stack;

View File

@ -901,13 +901,23 @@ static v8::Handle<v8::Object> v8js_wrap_array_to_object(v8::Isolate *isolate, zv
uint key_len; uint key_len;
ulong index; ulong index;
// @todo re-use template likewise v8js_ctx *ctx = (v8js_ctx *) isolate->GetData(0);
v8::Local<v8::FunctionTemplate> new_tpl = v8::FunctionTemplate::New(isolate, 0); v8::Local<v8::FunctionTemplate> new_tpl;
if(ctx->array_tmpl.IsEmpty()) {
new_tpl = v8::FunctionTemplate::New(isolate, 0);
/* Call it Array, but it is not a native array, especially it doesn't have /* Call it Array, but it is not a native array, especially it doesn't have
* have the typical Array.prototype functions. */ * have the typical Array.prototype functions. */
new_tpl->SetClassName(V8JS_SYM("Array")); new_tpl->SetClassName(V8JS_SYM("Array"));
/* Store for later re-use */
ctx->array_tmpl.Reset(isolate, new_tpl);
}
else {
new_tpl = v8::Local<v8::FunctionTemplate>::New(isolate, ctx->array_tmpl);
}
v8::Handle<v8::Object> newobj = new_tpl->InstanceTemplate()->NewInstance(); v8::Handle<v8::Object> newobj = new_tpl->InstanceTemplate()->NewInstance();
HashTable *myht = HASH_OF(value); HashTable *myht = HASH_OF(value);