use std::{mem::MaybeUninit, ptr::null_mut};
use smallvec::SmallVec;
use super::{
bindings as napi,
raw::{Env, FunctionCallbackInfo, Local},
};
const ARGV_SIZE: usize = 4;
#[repr(transparent)]
pub struct Arguments(SmallVec<[Local; ARGV_SIZE]>);
impl Arguments {
#[inline]
pub fn get(&self, i: usize) -> Option<Local> {
self.0.get(i).cloned()
}
}
pub unsafe fn is_construct(env: Env, info: FunctionCallbackInfo) -> bool {
let mut target: MaybeUninit<Local> = MaybeUninit::zeroed();
napi::get_new_target(env, info, target.as_mut_ptr()).unwrap();
let target: Local = target.assume_init();
!target.is_null()
}
pub unsafe fn this(env: Env, info: FunctionCallbackInfo, out: &mut Local) {
napi::get_cb_info(env, info, null_mut(), null_mut(), out as *mut _, null_mut()).unwrap();
}
pub unsafe fn len(env: Env, info: FunctionCallbackInfo) -> usize {
let mut argc = 0usize;
napi::get_cb_info(
env,
info,
&mut argc as *mut _,
null_mut(),
null_mut(),
null_mut(),
)
.unwrap();
argc
}
pub unsafe fn argv(env: Env, info: FunctionCallbackInfo) -> Arguments {
let mut argv = MaybeUninit::<[Local; ARGV_SIZE]>::uninit();
let mut argc = ARGV_SIZE;
napi::get_cb_info(
env,
info,
&mut argc as *mut _,
argv.as_mut_ptr().cast(),
null_mut(),
null_mut(),
)
.unwrap();
let argv = if argc > ARGV_SIZE {
let mut argv = Vec::with_capacity(argc);
napi::get_cb_info(
env,
info,
&mut argc as *mut _,
argv.as_mut_ptr(),
null_mut(),
null_mut(),
)
.unwrap();
argv.set_len(argc);
SmallVec::from_vec(argv)
} else {
SmallVec::from_buf_and_len(argv.assume_init(), argc)
};
Arguments(argv)
}