mirror of
https://github.com/servo/servo.git
synced 2025-07-23 15:23:42 +01:00
Extract generated finalizers into generic helper functions. (#31569)
This commit is contained in:
parent
0327d4638b
commit
19f1f2a8f4
3 changed files with 60 additions and 31 deletions
|
@ -6101,38 +6101,12 @@ let this = native_from_object_static::<%s>(obj).unwrap();
|
||||||
|
|
||||||
|
|
||||||
def finalizeHook(descriptor, hookName, context):
|
def finalizeHook(descriptor, hookName, context):
|
||||||
release = ""
|
|
||||||
if descriptor.isGlobal():
|
if descriptor.isGlobal():
|
||||||
release += """\
|
release = "finalize_global(obj, this);"
|
||||||
finalize_global(obj);
|
|
||||||
"""
|
|
||||||
elif descriptor.weakReferenceable:
|
elif descriptor.weakReferenceable:
|
||||||
release += """\
|
release = "finalize_weak_referenceable(obj, this);"
|
||||||
let mut slot = UndefinedValue();
|
else:
|
||||||
JS_GetReservedSlot(obj, DOM_WEAK_SLOT, &mut slot);
|
release = "finalize_common(this);"
|
||||||
let weak_box_ptr = slot.to_private() as *mut WeakBox<%s>;
|
|
||||||
if !weak_box_ptr.is_null() {
|
|
||||||
let count = {
|
|
||||||
let weak_box = &*weak_box_ptr;
|
|
||||||
assert!(weak_box.value.get().is_some());
|
|
||||||
assert!(weak_box.count.get() > 0);
|
|
||||||
weak_box.value.set(None);
|
|
||||||
let count = weak_box.count.get() - 1;
|
|
||||||
weak_box.count.set(count);
|
|
||||||
count
|
|
||||||
};
|
|
||||||
if count == 0 {
|
|
||||||
mem::drop(Box::from_raw(weak_box_ptr));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
""" % descriptor.concreteType
|
|
||||||
release += """\
|
|
||||||
if !this.is_null() {
|
|
||||||
// The pointer can be null if the object is the unforgeable holder of that interface.
|
|
||||||
let _ = Box::from_raw(this as *mut %s);
|
|
||||||
}
|
|
||||||
debug!("%s finalize: {:p}", this);\
|
|
||||||
""" % (descriptor.concreteType, descriptor.concreteType)
|
|
||||||
return release
|
return release
|
||||||
|
|
||||||
|
|
||||||
|
@ -6569,7 +6543,9 @@ def generate_imports(config, cgthings, descriptors, callbacks=None, dictionaries
|
||||||
'crate::dom::bindings::utils::ProtoOrIfaceArray',
|
'crate::dom::bindings::utils::ProtoOrIfaceArray',
|
||||||
'crate::dom::bindings::utils::callargs_is_constructing',
|
'crate::dom::bindings::utils::callargs_is_constructing',
|
||||||
'crate::dom::bindings::utils::enumerate_global',
|
'crate::dom::bindings::utils::enumerate_global',
|
||||||
'crate::dom::bindings::utils::finalize_global',
|
'crate::dom::bindings::finalize::finalize_common',
|
||||||
|
'crate::dom::bindings::finalize::finalize_global',
|
||||||
|
'crate::dom::bindings::finalize::finalize_weak_referenceable',
|
||||||
'crate::dom::bindings::utils::generic_getter',
|
'crate::dom::bindings::utils::generic_getter',
|
||||||
'crate::dom::bindings::utils::generic_lenient_getter',
|
'crate::dom::bindings::utils::generic_lenient_getter',
|
||||||
'crate::dom::bindings::utils::generic_lenient_setter',
|
'crate::dom::bindings::utils::generic_lenient_setter',
|
||||||
|
|
52
components/script/dom/bindings/finalize.rs
Normal file
52
components/script/dom/bindings/finalize.rs
Normal file
|
@ -0,0 +1,52 @@
|
||||||
|
/* This Source Code Form is subject to the terms of the Mozilla Public
|
||||||
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
||||||
|
* file, You can obtain one at https://mozilla.org/MPL/2.0/. */
|
||||||
|
|
||||||
|
use std::any::type_name;
|
||||||
|
use std::mem;
|
||||||
|
|
||||||
|
use js::glue::JS_GetReservedSlot;
|
||||||
|
use js::jsapi::JSObject;
|
||||||
|
use js::jsval::UndefinedValue;
|
||||||
|
|
||||||
|
use crate::dom::bindings::utils::finalize_global as do_finalize_global;
|
||||||
|
use crate::dom::bindings::weakref::{WeakBox, WeakReferenceable, DOM_WEAK_SLOT};
|
||||||
|
|
||||||
|
/// Generic finalizer implementations for DOM binding implementations.
|
||||||
|
|
||||||
|
pub unsafe fn finalize_common<T>(this: *const T) {
|
||||||
|
if !this.is_null() {
|
||||||
|
// The pointer can be null if the object is the unforgeable holder of that interface.
|
||||||
|
let _ = Box::from_raw(this as *mut T);
|
||||||
|
}
|
||||||
|
debug!("{} finalize: {:p}", type_name::<T>(), this);
|
||||||
|
}
|
||||||
|
|
||||||
|
pub unsafe fn finalize_global<T>(obj: *mut JSObject, this: *const T) {
|
||||||
|
do_finalize_global(obj);
|
||||||
|
finalize_common::<T>(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
pub unsafe fn finalize_weak_referenceable<T: WeakReferenceable>(
|
||||||
|
obj: *mut JSObject,
|
||||||
|
this: *const T,
|
||||||
|
) {
|
||||||
|
let mut slot = UndefinedValue();
|
||||||
|
JS_GetReservedSlot(obj, DOM_WEAK_SLOT, &mut slot);
|
||||||
|
let weak_box_ptr = slot.to_private() as *mut WeakBox<T>;
|
||||||
|
if !weak_box_ptr.is_null() {
|
||||||
|
let count = {
|
||||||
|
let weak_box = &*weak_box_ptr;
|
||||||
|
assert!(weak_box.value.get().is_some());
|
||||||
|
assert!(weak_box.count.get() > 0);
|
||||||
|
weak_box.value.set(None);
|
||||||
|
let count = weak_box.count.get() - 1;
|
||||||
|
weak_box.count.set(count);
|
||||||
|
count
|
||||||
|
};
|
||||||
|
if count == 0 {
|
||||||
|
mem::drop(Box::from_raw(weak_box_ptr));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
finalize_common::<T>(this);
|
||||||
|
}
|
|
@ -140,6 +140,7 @@ pub mod cell;
|
||||||
pub mod constant;
|
pub mod constant;
|
||||||
pub mod conversions;
|
pub mod conversions;
|
||||||
pub mod error;
|
pub mod error;
|
||||||
|
pub mod finalize;
|
||||||
pub mod guard;
|
pub mod guard;
|
||||||
pub mod htmlconstructor;
|
pub mod htmlconstructor;
|
||||||
pub mod inheritance;
|
pub mod inheritance;
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue