mirror of
https://github.com/servo/servo.git
synced 2025-07-22 23:03:42 +01:00
Auto merge of #8226 - froydnj:gc-zeal, r=Ms2ger
unblock using JS_GC_ZEAL I think these patches move the `JS_SetReservedSlot` call to the right place for #6057. I'm not sure that the interface to `create_dom_global` is the best; passing a `JSVal` or a `*libc::c_void` seemed about equal, so I'd welcome feedback there. <!-- Reviewable:start --> [<img src="https://reviewable.io/review_button.png" height=40 alt="Review on Reviewable"/>](https://reviewable.io/reviews/servo/servo/8226) <!-- Reviewable:end -->
This commit is contained in:
commit
3efa749976
2 changed files with 23 additions and 21 deletions
|
@ -2161,27 +2161,27 @@ let obj = {
|
|||
assert!(!obj.is_null());
|
||||
let obj = RootedObject::new(cx, obj);\
|
||||
""" % (descriptor.name, parent)
|
||||
elif descriptor.isGlobal():
|
||||
create += ("let obj = RootedObject::new(\n"
|
||||
" cx,\n"
|
||||
" create_dom_global(\n"
|
||||
" cx,\n"
|
||||
" &Class.base as *const js::jsapi::Class as *const JSClass,\n"
|
||||
" raw as *const libc::c_void,\n"
|
||||
" Some(%s))\n"
|
||||
");\n"
|
||||
"assert!(!obj.ptr.is_null());" % TRACE_HOOK_NAME)
|
||||
else:
|
||||
if descriptor.isGlobal():
|
||||
create += ("let obj = RootedObject::new(\n"
|
||||
" cx,\n"
|
||||
" create_dom_global(\n"
|
||||
" cx,\n"
|
||||
" &Class.base as *const js::jsapi::Class as *const JSClass,\n"
|
||||
" Some(%s))\n"
|
||||
");\n" % TRACE_HOOK_NAME)
|
||||
else:
|
||||
create += ("let obj = {\n"
|
||||
" let _ac = JSAutoCompartment::new(cx, proto.ptr);\n"
|
||||
" JS_NewObjectWithGivenProto(\n"
|
||||
" cx, &Class.base as *const js::jsapi::Class as *const JSClass, proto.handle())\n"
|
||||
"};\n"
|
||||
"let obj = RootedObject::new(cx, obj);\n")
|
||||
create += """\
|
||||
assert!(!obj.ptr.is_null());
|
||||
|
||||
JS_SetReservedSlot(obj.ptr, DOM_OBJECT_SLOT,
|
||||
PrivateValue(raw as *const libc::c_void));"""
|
||||
create += ("let obj = {\n"
|
||||
" let _ac = JSAutoCompartment::new(cx, proto.ptr);\n"
|
||||
" JS_NewObjectWithGivenProto(\n"
|
||||
" cx, &Class.base as *const js::jsapi::Class as *const JSClass, proto.handle())\n"
|
||||
"};\n"
|
||||
"let obj = RootedObject::new(cx, obj);\n"
|
||||
"assert!(!obj.ptr.is_null());\n"
|
||||
"\n"
|
||||
"JS_SetReservedSlot(obj.ptr, DOM_OBJECT_SLOT,\n"
|
||||
" PrivateValue(raw as *const libc::c_void));")
|
||||
return create
|
||||
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue