From 7fdcd7a8ae414aa5f93489ce050eb5ddb9083b27 Mon Sep 17 00:00:00 2001 From: gaoquanzero Date: Mon, 10 Apr 2023 18:47:34 +0800 Subject: [PATCH] chore(napi): add noop feature in napi crate (#1546) --- crates/napi/Cargo.toml | 1 + .../src/bindgen_runtime/module_register.rs | 18 ++++++++++-------- 2 files changed, 11 insertions(+), 8 deletions(-) diff --git a/crates/napi/Cargo.toml b/crates/napi/Cargo.toml index 9635d641..75ad5844 100644 --- a/crates/napi/Cargo.toml +++ b/crates/napi/Cargo.toml @@ -20,6 +20,7 @@ all-features = true independent = true [features] +noop = [] async = ["tokio_rt"] compat-mode = [] default = ["napi3", "compat-mode"] # for most Node.js users diff --git a/crates/napi/src/bindgen_runtime/module_register.rs b/crates/napi/src/bindgen_runtime/module_register.rs index 56f1fbcd..2813c2af 100644 --- a/crates/napi/src/bindgen_runtime/module_register.rs +++ b/crates/napi/src/bindgen_runtime/module_register.rs @@ -200,7 +200,7 @@ pub fn get_class_constructor(js_name: &'static str) -> Option { } #[doc(hidden)] -#[cfg(feature = "compat-mode")] +#[cfg(all(feature = "compat-mode", not(feature = "noop")))] // compatibility for #[module_exports] pub fn register_module_exports(callback: ModuleExportsCallback) { MODULE_EXPORTS.push(callback); @@ -326,7 +326,7 @@ pub fn get_c_callback(raw_fn: ExportRegisterCallback) -> Result }) } -#[cfg(windows)] +#[cfg(all(windows, not(feature = "noop")))] #[ctor::ctor] fn load_host() { unsafe { @@ -334,7 +334,7 @@ fn load_host() { } } -#[cfg(target_arch = "wasm32")] +#[cfg(all(target_arch = "wasm32", not(feature = "noop")))] #[no_mangle] unsafe extern "C" fn napi_register_wasm_v1( env: sys::napi_env, @@ -343,6 +343,7 @@ unsafe extern "C" fn napi_register_wasm_v1( unsafe { napi_register_module_v1(env, exports) } } +#[cfg(not(feature = "noop"))] #[no_mangle] unsafe extern "C" fn napi_register_module_v1( env: sys::napi_env, @@ -555,6 +556,7 @@ unsafe extern "C" fn napi_register_module_v1( exports } +#[cfg(not(feature = "noop"))] pub(crate) unsafe extern "C" fn noop( env: sys::napi_env, _info: sys::napi_callback_info, @@ -572,7 +574,7 @@ pub(crate) unsafe extern "C" fn noop( ptr::null_mut() } -#[cfg(all(feature = "napi4", not(target_arch = "wasm32")))] +#[cfg(all(feature = "napi4", not(target_arch = "wasm32"), not(feature = "noop")))] fn create_custom_gc(env: sys::napi_env) { use std::os::raw::c_char; @@ -646,7 +648,7 @@ fn create_custom_gc(env: sys::napi_env) { ); } -#[cfg(all(feature = "napi4", not(target_arch = "wasm32")))] +#[cfg(all(feature = "napi4", not(target_arch = "wasm32"), not(feature = "noop")))] unsafe extern "C" fn remove_thread_id(id: *mut std::ffi::c_void) { let thread_id = unsafe { Box::from_raw(id.cast::()) }; THREADS_CAN_ACCESS_ENV @@ -654,13 +656,13 @@ unsafe extern "C" fn remove_thread_id(id: *mut std::ffi::c_void) { .remove(&*thread_id); } -#[cfg(all(feature = "napi4", not(target_arch = "wasm32")))] +#[cfg(all(feature = "napi4", not(target_arch = "wasm32"), not(feature = "noop")))] #[allow(unused)] unsafe extern "C" fn empty(env: sys::napi_env, info: sys::napi_callback_info) -> sys::napi_value { ptr::null_mut() } -#[cfg(all(feature = "napi4", not(target_arch = "wasm32")))] +#[cfg(all(feature = "napi4", not(target_arch = "wasm32"), not(feature = "noop")))] #[allow(unused)] unsafe extern "C" fn custom_gc_finalize( env: sys::napi_env, @@ -672,7 +674,7 @@ unsafe extern "C" fn custom_gc_finalize( }); } -#[cfg(all(feature = "napi4", not(target_arch = "wasm32")))] +#[cfg(all(feature = "napi4", not(target_arch = "wasm32"), not(feature = "noop")))] // recycle the ArrayBuffer/Buffer Reference if the ArrayBuffer/Buffer is not dropped on the main thread extern "C" fn custom_gc( env: sys::napi_env,