chore(napi-derive): make_ref tweaks (#1371)
This commit is contained in:
parent
618d0f8046
commit
573f67b90f
7 changed files with 8 additions and 34 deletions
|
@ -61,13 +61,12 @@ impl TryToTokens for NapiFn {
|
|||
unsafe impl Sync for NapiRefContainer {}
|
||||
let _make_ref = |a: ::std::ptr::NonNull<napi::bindgen_prelude::sys::napi_value__>| {
|
||||
let mut node_ref = ::std::mem::MaybeUninit::uninit();
|
||||
assert_eq!(unsafe {
|
||||
napi::bindgen_prelude::sys::napi_create_reference(env, a.as_ptr(), 1, node_ref.as_mut_ptr())
|
||||
napi::bindgen_prelude::check_status!(unsafe {
|
||||
napi::bindgen_prelude::sys::napi_create_reference(env, a.as_ptr(), 0, node_ref.as_mut_ptr())
|
||||
},
|
||||
napi::bindgen_prelude::sys::Status::napi_ok,
|
||||
"failed to create napi ref"
|
||||
);
|
||||
unsafe { node_ref.assume_init() }
|
||||
)?;
|
||||
Ok::<napi::sys::napi_ref, napi::Error>(unsafe { node_ref.assume_init() })
|
||||
};
|
||||
let mut _args_array = [::std::ptr::null_mut::<napi::bindgen_prelude::sys::napi_ref__>(); #arg_ref_count];
|
||||
let mut _arg_write_index = 0;
|
||||
|
@ -184,7 +183,10 @@ impl NapiFn {
|
|||
let mut mut_ref_spans = vec![];
|
||||
let make_ref = |input| {
|
||||
quote! {
|
||||
_args_array[_arg_write_index] = _make_ref(::std::ptr::NonNull::new(#input).expect("ref ptr was null"));
|
||||
_args_array[_arg_write_index] = _make_ref(
|
||||
::std::ptr::NonNull::new(#input)
|
||||
.ok_or_else(|| napi::Error::new(napi::Status::InvalidArg, "referenced ptr is null".to_owned()))?
|
||||
)?;
|
||||
_arg_write_index += 1;
|
||||
}
|
||||
};
|
||||
|
|
|
@ -195,7 +195,6 @@ Generated by [AVA](https://avajs.dev).
|
|||
export function threadsafeFunctionFatalMode(cb: (...args: any[]) => any): void␊
|
||||
export function threadsafeFunctionFatalModeError(cb: (...args: any[]) => any): void␊
|
||||
export function threadsafeFunctionClosureCapture(func: (...args: any[]) => any): void␊
|
||||
export function useTokioWithoutAsync(): void␊
|
||||
export function getBuffer(): Buffer␊
|
||||
export function appendBuffer(buf: Buffer): Buffer␊
|
||||
export function getEmptyBuffer(): Buffer␊
|
||||
|
|
Binary file not shown.
|
@ -106,7 +106,6 @@ import {
|
|||
receiveObjectWithClassField,
|
||||
AnotherClassForEither,
|
||||
receiveDifferentClass,
|
||||
useTokioWithoutAsync,
|
||||
getNumArr,
|
||||
getNestedNumArr,
|
||||
CustomFinalize,
|
||||
|
@ -754,12 +753,6 @@ Napi4Test('await Promise in rust', async (t) => {
|
|||
t.is(result, fx + 100)
|
||||
})
|
||||
|
||||
Napi4Test('Run function which uses tokio internally but is not async', (t) => {
|
||||
useTokioWithoutAsync()
|
||||
// The prior didn't throw an exception, so it worked.
|
||||
t.assert(true)
|
||||
})
|
||||
|
||||
Napi4Test('Promise should reject raw error in rust', async (t) => {
|
||||
const fxError = new Error('What is Happy Planet')
|
||||
const err = await t.throwsAsync(() => asyncPlus100(Promise.reject(fxError)))
|
||||
|
|
1
examples/napi/index.d.ts
vendored
1
examples/napi/index.d.ts
vendored
|
@ -185,7 +185,6 @@ export function threadsafeFunctionThrowError(cb: (...args: any[]) => any): void
|
|||
export function threadsafeFunctionFatalMode(cb: (...args: any[]) => any): void
|
||||
export function threadsafeFunctionFatalModeError(cb: (...args: any[]) => any): void
|
||||
export function threadsafeFunctionClosureCapture(func: (...args: any[]) => any): void
|
||||
export function useTokioWithoutAsync(): void
|
||||
export function getBuffer(): Buffer
|
||||
export function appendBuffer(buf: Buffer): Buffer
|
||||
export function getEmptyBuffer(): Buffer
|
||||
|
|
|
@ -40,5 +40,4 @@ mod string;
|
|||
mod symbol;
|
||||
mod task;
|
||||
mod threadsafe_function;
|
||||
mod tokio_outside_async;
|
||||
mod typed_array;
|
||||
|
|
|
@ -1,18 +0,0 @@
|
|||
use std::time::Duration;
|
||||
use tokio::{sync::oneshot, time::Instant};
|
||||
|
||||
#[napi]
|
||||
pub fn use_tokio_without_async() {
|
||||
let (sender, receiver) = oneshot::channel();
|
||||
let handle = tokio::task::spawn(async {
|
||||
// If this panics, the test failed.
|
||||
sender.send(true).unwrap();
|
||||
});
|
||||
let start = Instant::now();
|
||||
while !handle.is_finished() {
|
||||
if start.elapsed() > Duration::from_secs(5) {
|
||||
panic!("The future never resolved.");
|
||||
}
|
||||
}
|
||||
assert_eq!(receiver.blocking_recv(), Ok(true));
|
||||
}
|
Loading…
Add table
Reference in a new issue