aboutsummaryrefslogtreecommitdiffstats
path: root/components/script/dom
diff options
context:
space:
mode:
authorbors-servo <lbergstrom+bors@mozilla.com>2015-12-08 12:11:53 +0530
committerbors-servo <lbergstrom+bors@mozilla.com>2015-12-08 12:11:53 +0530
commit59029325c04d94af636e0b48478b00404afc4f7c (patch)
treee738bb19a565ffe84955cd824ffe496bbaa7e2a0 /components/script/dom
parentcad77d5f1c8458e3b21f3546e8306ab7d5163726 (diff)
parent30d1ff6abccdebd14dff778f6ba6b2f2ec2aa663 (diff)
downloadservo-59029325c04d94af636e0b48478b00404afc4f7c.tar.gz
servo-59029325c04d94af636e0b48478b00404afc4f7c.zip
Auto merge of #8827 - jdm:debugmozjscrash, r=Ms2ger
Avoid a null-dereference using debug mozjs builds. This matches the e… …quivalent code upstream in Gecko. <!-- Reviewable:start --> [<img src="https://reviewable.io/review_button.png" height=40 alt="Review on Reviewable"/>](https://reviewable.io/reviews/servo/servo/8827) <!-- Reviewable:end -->
Diffstat (limited to 'components/script/dom')
-rw-r--r--components/script/dom/bindings/codegen/CodegenRust.py31
1 files changed, 9 insertions, 22 deletions
diff --git a/components/script/dom/bindings/codegen/CodegenRust.py b/components/script/dom/bindings/codegen/CodegenRust.py
index d88e6d9fa32..c714bddb983 100644
--- a/components/script/dom/bindings/codegen/CodegenRust.py
+++ b/components/script/dom/bindings/codegen/CodegenRust.py
@@ -2164,13 +2164,10 @@ def CreateBindingJSObject(descriptor, parent=None):
create += """
let handler = RegisterBindings::proxy_handlers[PrototypeList::Proxies::%s as usize];
let private = RootedValue::new(cx, PrivateValue(raw as *const libc::c_void));
-let obj = {
- let _ac = JSAutoCompartment::new(cx, proto.ptr);
- NewProxyObject(cx, handler,
- private.handle(),
- proto.ptr, %s.get(),
- ptr::null_mut(), ptr::null_mut())
-};
+let obj = NewProxyObject(cx, handler,
+ private.handle(),
+ proto.ptr, %s.get(),
+ ptr::null_mut(), ptr::null_mut());
assert!(!obj.is_null());
let obj = RootedObject::new(cx, obj);\
""" % (descriptor.name, parent)
@@ -2185,12 +2182,8 @@ let obj = RootedObject::new(cx, obj);\
");\n"
"assert!(!obj.ptr.is_null());" % 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 += ("let obj = RootedObject::new(cx, JS_NewObjectWithGivenProto(\n"
+ " cx, &Class.base as *const js::jsapi::Class as *const JSClass, proto.handle()));\n"
"assert!(!obj.ptr.is_null());\n"
"\n"
"JS_SetReservedSlot(obj.ptr, DOM_OBJECT_SLOT,\n"
@@ -2236,11 +2229,7 @@ def CopyUnforgeablePropertiesToInstance(descriptor):
# reflector, so we can make sure we don't get confused by named getters.
if descriptor.proxy:
copyCode += """\
-let mut expando = RootedObject::new(cx, ptr::null_mut());
-{
- let _ac = JSAutoCompartment::new(cx, scope.get());
- expando.handle_mut().set(ensure_expando_object(cx, obj.handle()));
-}
+let expando = RootedObject::new(cx, ensure_expando_object(cx, obj.handle()));
"""
obj = "expando"
else:
@@ -2291,10 +2280,8 @@ assert!(!scope.get().is_null());
assert!(((*JS_GetClass(scope.get())).flags & JSCLASS_IS_GLOBAL) != 0);
let mut proto = RootedObject::new(cx, ptr::null_mut());
-{
- let _ac = JSAutoCompartment::new(cx, scope.get());
- GetProtoObject(cx, scope, scope, proto.handle_mut())
-}
+let _ac = JSAutoCompartment::new(cx, scope.get());
+GetProtoObject(cx, scope, scope, proto.handle_mut());
assert!(!proto.ptr.is_null());
%(createObject)s