diff options
Diffstat (limited to 'components/script/dom')
-rw-r--r-- | components/script/dom/bindings/conversions.rs | 9 | ||||
-rw-r--r-- | components/script/dom/bindings/root.rs | 17 |
2 files changed, 14 insertions, 12 deletions
diff --git a/components/script/dom/bindings/conversions.rs b/components/script/dom/bindings/conversions.rs index 531ff6ea885..da4334207bf 100644 --- a/components/script/dom/bindings/conversions.rs +++ b/components/script/dom/bindings/conversions.rs @@ -452,13 +452,10 @@ where /// Returns Err(()) if `obj` is a wrapper or if the object is not an object /// for a DOM object of the given type (as defined by the proto_id and proto_depth). #[inline] -pub unsafe fn private_from_proto_check_static<F>( +unsafe fn private_from_proto_check_static( obj: *mut JSObject, - proto_check: F, -) -> Result<*const libc::c_void, ()> -where - F: Fn(&'static DOMClass) -> bool, -{ + proto_check: fn(&'static DOMClass) -> bool, +) -> Result<*const libc::c_void, ()> { let dom_class = get_dom_class(obj).map_err(|_| ())?; if proto_check(dom_class) { trace!("good prototype"); diff --git a/components/script/dom/bindings/root.rs b/components/script/dom/bindings/root.rs index 59f9b964564..36bc2296ee5 100644 --- a/components/script/dom/bindings/root.rs +++ b/components/script/dom/bindings/root.rs @@ -63,12 +63,17 @@ where /// out references which cannot outlive this new `Root`. #[allow(unrooted_must_root)] pub unsafe fn new(value: T) -> Self { - debug_assert!(thread_state::get().is_script()); - STACK_ROOTS.with(|ref root_list| { - let root_list = &*root_list.get().unwrap(); - root_list.root(value.stable_trace_object()); - Root { value, root_list } - }) + unsafe fn add_to_root_list(object: *const dyn JSTraceable) -> *const RootCollection { + debug_assert!(thread_state::get().is_script()); + STACK_ROOTS.with(|ref root_list| { + let root_list = &*root_list.get().unwrap(); + root_list.root(object); + root_list + }) + } + + let root_list = add_to_root_list(value.stable_trace_object()); + Root { value, root_list } } } |