use proc_macro2::{Ident, Literal, TokenStream}; use quote::ToTokens; use crate::{ codegen::{get_register_ident, js_mod_to_token_stream}, BindgenResult, NapiConst, TryToTokens, }; impl TryToTokens for NapiConst { fn try_to_tokens(&self, tokens: &mut TokenStream) -> BindgenResult<()> { let register = self.gen_module_register(); (quote! { #register }) .to_tokens(tokens); Ok(()) } } impl NapiConst { fn gen_module_register(&self) -> TokenStream { let name_str = self.name.to_string(); let name_ident = self.name.clone(); let js_name_lit = Literal::string(&format!("{}\0", self.name)); let register_name = get_register_ident(&name_str); let type_name = &self.type_name; let cb_name = Ident::new( &format!("__register__const__{}_callback__", register_name), self.name.span(), ); let js_mod_ident = js_mod_to_token_stream(self.js_mod.as_ref()); quote! { #[allow(non_snake_case)] #[allow(clippy::all)] unsafe fn #cb_name(env: napi::sys::napi_env) -> napi::Result { <#type_name as napi::bindgen_prelude::ToNapiValue>::to_napi_value(env, #name_ident) } #[allow(non_snake_case)] #[allow(clippy::all)] #[cfg(not(test))] #[napi::bindgen_prelude::ctor] fn #register_name() { napi::bindgen_prelude::register_module_export(#js_mod_ident, #js_name_lit, #cb_name); } } } }