script/dom/bindings/
function.rs1#[macro_export]
11macro_rules! native_fn {
12 ($cx:expr, $call:expr, $name:expr, $nargs:expr, $flags:expr) => {{
13 let fun_obj = $crate::native_raw_obj_fn!($cx, $call, $name, $nargs, $flags);
14 let cx = $cx.into();
15 #[expect(unsafe_code)]
16 unsafe {
17 Function::new(cx, fun_obj)
18 }
19 }};
20}
21
22#[macro_export]
28macro_rules! native_raw_obj_fn {
29 ($cx:expr, $call:expr, $name:expr, $nargs:expr, $flags:expr) => {{
30 #[expect(unsafe_code)]
31 #[allow(clippy::macro_metavars_in_unsafe)]
32 unsafe extern "C" fn wrapper(cx: *mut JSContext, argc: u32, vp: *mut JSVal) -> bool {
33 let mut cx = unsafe {
34 js::context::JSContext::from_ptr(
36 std::ptr::NonNull::new(cx).expect("JSContext is not null in SM hook"),
37 )
38 };
39 let call_args = unsafe { CallArgs::from_vp(vp, argc) };
40 $call(&mut cx, call_args)
41 }
42 #[expect(unsafe_code)]
43 #[allow(clippy::macro_metavars_in_unsafe)]
44 unsafe {
45 let name: &std::ffi::CStr = $name;
46 let raw_fun = js::jsapi::JS_NewFunction(
47 $cx.raw_cx(),
48 Some(wrapper),
49 $nargs,
50 $flags,
51 name.as_ptr() as *const std::ffi::c_char,
52 );
53 assert!(!raw_fun.is_null());
54 js::jsapi::JS_GetFunctionObject(raw_fun)
55 }
56 }};
57}