diff --git a/napi/src/async_work.rs b/napi/src/async_work.rs index 0ec502f0..390e3065 100644 --- a/napi/src/async_work.rs +++ b/napi/src/async_work.rs @@ -13,21 +13,21 @@ pub struct AsyncWork { } impl AsyncWork { + #[inline] pub fn run(env: sys::napi_env, task: T, deferred: sys::napi_deferred) -> Result<()> { let mut raw_resource = ptr::null_mut(); let status = unsafe { sys::napi_create_object(env, &mut raw_resource) }; check_status(status)?; let mut raw_name = ptr::null_mut(); let s = "napi_rs_async"; - let status = unsafe { + check_status(unsafe { sys::napi_create_string_utf8( env, s.as_ptr() as *const c_char, s.len() as u64, &mut raw_name, ) - }; - check_status(status)?; + })?; let result = AsyncWork { inner_task: task, deferred, diff --git a/napi/src/env.rs b/napi/src/env.rs index 00b47968..ba2a2270 100644 --- a/napi/src/env.rs +++ b/napi/src/env.rs @@ -66,35 +66,34 @@ impl Env { #[inline] pub fn create_int32(&self, int: i32) -> Result { let mut raw_value = ptr::null_mut(); - let status = - unsafe { sys::napi_create_int32(self.0, int, (&mut raw_value) as *mut sys::napi_value) }; - check_status(status)?; + check_status(unsafe { + sys::napi_create_int32(self.0, int, (&mut raw_value) as *mut sys::napi_value) + })?; Ok(JsNumber::from_raw_unchecked(self.0, raw_value)) } #[inline] pub fn create_int64(&self, int: i64) -> Result { let mut raw_value = ptr::null_mut(); - let status = - unsafe { sys::napi_create_int64(self.0, int, (&mut raw_value) as *mut sys::napi_value) }; - check_status(status)?; + check_status(unsafe { + sys::napi_create_int64(self.0, int, (&mut raw_value) as *mut sys::napi_value) + })?; Ok(JsNumber::from_raw_unchecked(self.0, raw_value)) } #[inline] pub fn create_uint32(&self, number: u32) -> Result { let mut raw_value = ptr::null_mut(); - let status = unsafe { sys::napi_create_uint32(self.0, number, &mut raw_value) }; - check_status(status)?; + check_status(unsafe { sys::napi_create_uint32(self.0, number, &mut raw_value) })?; Ok(JsNumber::from_raw_unchecked(self.0, raw_value)) } #[inline] pub fn create_double(&self, double: f64) -> Result { let mut raw_value = ptr::null_mut(); - let status = - unsafe { sys::napi_create_double(self.0, double, (&mut raw_value) as *mut sys::napi_value) }; - check_status(status)?; + check_status(unsafe { + sys::napi_create_double(self.0, double, (&mut raw_value) as *mut sys::napi_value) + })?; Ok(JsNumber::from_raw_unchecked(self.0, raw_value)) } @@ -116,6 +115,29 @@ impl Env { Ok(JsBigint::from_raw_unchecked(self.0, raw_value, 1)) } + #[cfg(napi6)] + #[inline] + /// https://nodejs.org/api/n-api.html#n_api_napi_create_bigint_words + pub fn create_bigint_from_i128(&self, value: i128) -> Result { + let mut raw_value = ptr::null_mut(); + let sign_bit = if value > 0 { 0 } else { 1 }; + let words = &value as *const i128 as *const u64; + check_status(unsafe { + sys::napi_create_bigint_words(self.0, sign_bit, 2, words, &mut raw_value) + })?; + Ok(JsBigint::from_raw_unchecked(self.0, raw_value, 1)) + } + + #[cfg(napi6)] + #[inline] + /// https://nodejs.org/api/n-api.html#n_api_napi_create_bigint_words + pub fn create_bigint_from_u128(&self, value: u128) -> Result { + let mut raw_value = ptr::null_mut(); + let words = &value as *const u128 as *const u64; + check_status(unsafe { sys::napi_create_bigint_words(self.0, 0, 2, words, &mut raw_value) })?; + Ok(JsBigint::from_raw_unchecked(self.0, raw_value, 1)) + } + #[cfg(napi6)] #[inline] /// https://nodejs.org/api/n-api.html#n_api_napi_create_bigint_words @@ -161,18 +183,16 @@ impl Env { #[inline] fn create_string_from_chars(&self, data_ptr: *const c_char, len: u64) -> Result { let mut raw_value = ptr::null_mut(); - let status = unsafe { sys::napi_create_string_utf8(self.0, data_ptr, len, &mut raw_value) }; - check_status(status)?; + check_status(unsafe { sys::napi_create_string_utf8(self.0, data_ptr, len, &mut raw_value) })?; Ok(JsString::from_raw_unchecked(self.0, raw_value)) } #[inline] pub fn create_string_utf16(&self, chars: &[u16]) -> Result { let mut raw_value = ptr::null_mut(); - let status = unsafe { + check_status(unsafe { sys::napi_create_string_utf16(self.0, chars.as_ptr(), chars.len() as u64, &mut raw_value) - }; - check_status(status)?; + })?; Ok(JsString::from_raw_unchecked(self.0, raw_value)) } @@ -202,17 +222,16 @@ impl Env { #[inline] pub fn create_object(&self) -> Result { let mut raw_value = ptr::null_mut(); - let status = unsafe { sys::napi_create_object(self.0, &mut raw_value) }; - check_status(status)?; + check_status(unsafe { sys::napi_create_object(self.0, &mut raw_value) })?; Ok(JsObject::from_raw_unchecked(self.0, raw_value)) } #[inline] pub fn create_array_with_length(&self, length: usize) -> Result { let mut raw_value = ptr::null_mut(); - let status = - unsafe { sys::napi_create_array_with_length(self.0, length as u64, &mut raw_value) }; - check_status(status)?; + check_status(unsafe { + sys::napi_create_array_with_length(self.0, length as u64, &mut raw_value) + })?; Ok(JsObject::from_raw_unchecked(self.0, raw_value)) } @@ -221,8 +240,9 @@ impl Env { let mut raw_value = ptr::null_mut(); let mut data = Vec::with_capacity(length as usize); let mut data_ptr = data.as_mut_ptr(); - let status = unsafe { sys::napi_create_buffer(self.0, length, &mut data_ptr, &mut raw_value) }; - check_status(status)?; + check_status(unsafe { + sys::napi_create_buffer(self.0, length, &mut data_ptr, &mut raw_value) + })?; mem::forget(data); Ok(JsBuffer::from_raw_unchecked( @@ -238,7 +258,7 @@ impl Env { let length = data.len() as u64; let mut raw_value = ptr::null_mut(); let data_ptr = data.as_mut_ptr(); - let status = unsafe { + check_status(unsafe { sys::napi_create_external_buffer( self.0, length, @@ -247,12 +267,9 @@ impl Env { Box::leak(Box::new(length)) as *mut u64 as *mut _, &mut raw_value, ) - }; - check_status(status)?; + })?; let mut changed = 0; - let adjust_external_memory_status = - unsafe { sys::napi_adjust_external_memory(self.0, length as i64, &mut changed) }; - check_status(adjust_external_memory_status)?; + check_status(unsafe { sys::napi_adjust_external_memory(self.0, length as i64, &mut changed) })?; mem::forget(data); Ok(JsBuffer::from_raw_unchecked( self.0, @@ -267,9 +284,9 @@ impl Env { let mut raw_value = ptr::null_mut(); let mut data = Vec::with_capacity(length as usize); let mut data_ptr = data.as_mut_ptr(); - let status = - unsafe { sys::napi_create_arraybuffer(self.0, length, &mut data_ptr, &mut raw_value) }; - check_status(status)?; + check_status(unsafe { + sys::napi_create_arraybuffer(self.0, length, &mut data_ptr, &mut raw_value) + })?; mem::forget(data); let mut array_buffer = JsArrayBuffer::from_raw_unchecked(self.0, raw_value); array_buffer.data = data_ptr as *const u8; @@ -282,7 +299,7 @@ impl Env { let length = data.len() as u64; let mut raw_value = ptr::null_mut(); let data_ptr = data.as_ptr(); - let status = unsafe { + check_status(unsafe { sys::napi_create_external_arraybuffer( self.0, data_ptr as *mut c_void, @@ -291,12 +308,9 @@ impl Env { &length as *const _ as *mut c_void, &mut raw_value, ) - }; - check_status(status)?; + })?; let mut changed = 0; - let adjust_external_memory_status = - unsafe { sys::napi_adjust_external_memory(self.0, length as i64, &mut changed) }; - check_status(adjust_external_memory_status)?; + check_status(unsafe { sys::napi_adjust_external_memory(self.0, length as i64, &mut changed) })?; mem::forget(data); let mut array_buffer = JsArrayBuffer::from_raw_unchecked(self.0, raw_value); array_buffer.data = data_ptr as *const u8; @@ -307,7 +321,7 @@ impl Env { #[inline] pub fn create_function(&self, name: &str, callback: Callback) -> Result { let mut raw_result = ptr::null_mut(); - let status = unsafe { + check_status(unsafe { sys::napi_create_function( self.0, name.as_ptr() as *const c_char, @@ -316,9 +330,7 @@ impl Env { callback as *mut c_void, &mut raw_result, ) - }; - - check_status(status)?; + })?; Ok(JsFunction::from_raw_unchecked(self.0, raw_result)) } @@ -345,11 +357,9 @@ impl Env { pub fn create_reference(&self, value: T) -> Result> { let mut raw_ref = ptr::null_mut(); let initial_ref_count = 1; - unsafe { - let status = - sys::napi_create_reference(self.0, value.raw_value(), initial_ref_count, &mut raw_ref); - check_status(status)?; - }; + check_status(unsafe { + sys::napi_create_reference(self.0, value.raw_value(), initial_ref_count, &mut raw_ref) + })?; Ok(Ref::new(self.0, raw_ref)) } @@ -357,10 +367,9 @@ impl Env { #[inline] pub fn get_reference_value(&self, reference: &Ref) -> Result { let mut raw_value = ptr::null_mut(); - unsafe { - let status = sys::napi_get_reference_value(self.0, reference.ref_value, &mut raw_value); - check_status(status)?; - }; + check_status(unsafe { + sys::napi_get_reference_value(self.0, reference.ref_value, &mut raw_value) + })?; T::from_raw(self.0, raw_value) } @@ -378,7 +387,7 @@ impl Env { .map(|prop| prop.into_raw(self)) .collect::>>()?; - let status = unsafe { + check_status(unsafe { sys::napi_define_class( self.0, name.as_ptr() as *const c_char, @@ -389,16 +398,14 @@ impl Env { raw_properties.as_ptr(), &mut raw_result, ) - }; - - check_status(status)?; + })?; Ok(JsFunction::from_raw_unchecked(self.0, raw_result)) } #[inline] pub fn wrap(&self, js_object: &mut JsObject, native_object: T) -> Result<()> { - let status = unsafe { + check_status(unsafe { sys::napi_wrap( self.0, js_object.0.value, @@ -407,17 +414,18 @@ impl Env { ptr::null_mut(), ptr::null_mut(), ) - }; - - check_status(status).or(Ok(())) + }) } #[inline] pub fn unwrap(&self, js_object: &JsObject) -> Result<&mut T> { unsafe { let mut unknown_tagged_object: *mut c_void = ptr::null_mut(); - let status = sys::napi_unwrap(self.0, js_object.0.value, &mut unknown_tagged_object); - check_status(status)?; + check_status(sys::napi_unwrap( + self.0, + js_object.0.value, + &mut unknown_tagged_object, + ))?; let type_id: *const TypeId = mem::transmute(unknown_tagged_object); if *type_id == TypeId::of::() { @@ -439,8 +447,11 @@ impl Env { pub fn drop_wrapped(&self, js_object: JsObject) -> Result<()> { unsafe { let mut unknown_tagged_object: *mut c_void = ptr::null_mut(); - let status = sys::napi_unwrap(self.0, js_object.0.value, &mut unknown_tagged_object); - check_status(status)?; + check_status(sys::napi_unwrap( + self.0, + js_object.0.value, + &mut unknown_tagged_object, + ))?; let type_id: *const TypeId = mem::transmute(unknown_tagged_object); if *type_id == TypeId::of::() { @@ -460,7 +471,7 @@ impl Env { #[inline] pub fn create_external(&self, native_object: T) -> Result { let mut object_value = ptr::null_mut(); - let status = unsafe { + check_status(unsafe { sys::napi_create_external( self.0, Box::into_raw(Box::new(TaggedObject::new(native_object))) as *mut c_void, @@ -468,9 +479,7 @@ impl Env { ptr::null_mut(), &mut object_value, ) - }; - - check_status(status)?; + })?; Ok(JsExternal::from_raw_unchecked(self.0, object_value)) } @@ -478,9 +487,11 @@ impl Env { pub fn get_value_external(&self, js_external: &JsExternal) -> Result<&mut T> { unsafe { let mut unknown_tagged_object = ptr::null_mut(); - let status = - sys::napi_get_value_external(self.0, js_external.0.value, &mut unknown_tagged_object); - check_status(status)?; + check_status(sys::napi_get_value_external( + self.0, + js_external.0.value, + &mut unknown_tagged_object, + ))?; let type_id: *const TypeId = mem::transmute(unknown_tagged_object); if *type_id == TypeId::of::() { @@ -504,10 +515,9 @@ impl Env { let reason = e.reason; let reason_string = self.create_string(reason.as_str())?; let mut result = ptr::null_mut(); - let status = unsafe { + check_status(unsafe { sys::napi_create_error(self.0, ptr::null_mut(), reason_string.0.value, &mut result) - }; - check_status(status)?; + })?; Ok(JsObject::from_raw_unchecked(self.0, result)) } @@ -544,11 +554,8 @@ impl Env { #[inline] pub fn get_uv_event_loop(&self) -> Result<*mut sys::uv_loop_s> { let mut uv_loop: *mut sys::uv_loop_s = ptr::null_mut(); - Ok(unsafe { - let status = sys::napi_get_uv_event_loop(self.0, &mut uv_loop); - check_status(status)?; - uv_loop - }) + check_status(unsafe { sys::napi_get_uv_event_loop(self.0, &mut uv_loop) })?; + Ok(uv_loop) } #[cfg(all(feature = "libuv", napi4))] @@ -566,10 +573,7 @@ impl Env { let mut raw_promise = ptr::null_mut(); let mut raw_deferred = ptr::null_mut(); - unsafe { - let status = sys::napi_create_promise(self.0, &mut raw_deferred, &mut raw_promise); - check_status(status)?; - } + check_status(unsafe { sys::napi_create_promise(self.0, &mut raw_deferred, &mut raw_promise) })?; let event_loop = self.get_uv_event_loop()?; let future_promise = promise::FuturePromise::create(self.0, raw_deferred, Box::from(resolver))?; diff --git a/napi/src/promise.rs b/napi/src/promise.rs index e222d477..4aeec4a8 100644 --- a/napi/src/promise.rs +++ b/napi/src/promise.rs @@ -16,6 +16,7 @@ pub struct FuturePromise { unsafe impl Send for FuturePromise {} impl FuturePromise { + #[inline] pub fn create( env: sys::napi_env, raw_deferred: sys::napi_deferred, @@ -41,6 +42,7 @@ impl FuturePromise { }) } + #[inline] pub(crate) fn start(self) -> Result { let mut tsfn_value = ptr::null_mut(); let async_resource_name = self.async_resource_name; diff --git a/test_module/__test__/napi6/bigint.spec.ts b/test_module/__test__/napi6/bigint.spec.ts index 6d88ae32..65afd586 100644 --- a/test_module/__test__/napi6/bigint.spec.ts +++ b/test_module/__test__/napi6/bigint.spec.ts @@ -8,6 +8,14 @@ test('should create bigints', (t) => { if (napiVersion >= 6) { t.is(bindings.testCreateBigintFromI64(), BigInt('9223372036854775807')) t.is(bindings.testCreateBigintFromU64(), BigInt('18446744073709551615')) + t.is( + bindings.testCreateBigintFromI128(), + BigInt('170141183460469231731687303715884105727'), + ) + t.is( + bindings.testCreateBigintFromU128(), + BigInt('340282366920938463463374607431768211455'), + ) t.is( bindings.testCreateBigintFromWords(), BigInt('-340282366920938463463374607431768211455'), diff --git a/test_module/src/lib.rs b/test_module/src/lib.rs index 4102fc80..e8ff8315 100644 --- a/test_module/src/lib.rs +++ b/test_module/src/lib.rs @@ -41,8 +41,9 @@ use napi4::{test_threadsafe_function, test_tokio_readfile, test_tsfn_error}; use napi5::is_date::test_object_is_date; #[cfg(napi6)] use napi6::bigint::{ - test_create_bigint_from_i64, test_create_bigint_from_u64, test_create_bigint_from_words, - test_get_bigint_i64, test_get_bigint_u64, test_get_bigint_words, + test_create_bigint_from_i128, test_create_bigint_from_i64, test_create_bigint_from_u128, + test_create_bigint_from_u64, test_create_bigint_from_words, test_get_bigint_i64, + test_get_bigint_u64, test_get_bigint_words, }; use napi_version::get_napi_version; use symbol::{create_named_symbol, create_symbol_from_js_string, create_unnamed_symbol}; @@ -95,6 +96,10 @@ fn init(module: &mut Module) -> Result<()> { #[cfg(napi6)] module.create_named_method("testCreateBigintFromU64", test_create_bigint_from_u64)?; #[cfg(napi6)] + module.create_named_method("testCreateBigintFromI128", test_create_bigint_from_i128)?; + #[cfg(napi6)] + module.create_named_method("testCreateBigintFromU128", test_create_bigint_from_u128)?; + #[cfg(napi6)] module.create_named_method("testCreateBigintFromWords", test_create_bigint_from_words)?; #[cfg(napi6)] module.create_named_method("testGetBigintI64", test_get_bigint_i64)?; diff --git a/test_module/src/napi6/bigint.rs b/test_module/src/napi6/bigint.rs index faac2761..c5340227 100644 --- a/test_module/src/napi6/bigint.rs +++ b/test_module/src/napi6/bigint.rs @@ -1,17 +1,27 @@ use napi::{CallContext, JsBigint, JsNumber, JsObject, Result}; use std::convert::TryFrom; -#[js_function(0)] +#[js_function] pub fn test_create_bigint_from_i64(ctx: CallContext) -> Result { ctx.env.create_bigint_from_i64(i64::max_value()) } -#[js_function(0)] +#[js_function] pub fn test_create_bigint_from_u64(ctx: CallContext) -> Result { ctx.env.create_bigint_from_u64(u64::max_value()) } -#[js_function(0)] +#[js_function] +pub fn test_create_bigint_from_i128(ctx: CallContext) -> Result { + ctx.env.create_bigint_from_i128(i128::max_value()) +} + +#[js_function] +pub fn test_create_bigint_from_u128(ctx: CallContext) -> Result { + ctx.env.create_bigint_from_u128(u128::max_value()) +} + +#[js_function] pub fn test_create_bigint_from_words(ctx: CallContext) -> Result { ctx .env