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