use napi::{CallContext, Error, JsBoolean, JsString, JsUnknown, Module, Result, Status}; #[js_function] fn test_throw(_ctx: CallContext) -> Result { Err(Error::from_status(Status::GenericFailure)) } #[js_function(1)] fn test_throw_with_reason(ctx: CallContext) -> Result { let reason = ctx.get::(0)?; Err(Error::new( Status::GenericFailure, reason.as_str()?.to_owned(), )) } #[js_function] pub fn test_throw_with_panic(_ctx: CallContext) -> Result { panic!("don't panic."); } #[js_function(1)] pub fn is_error(ctx: CallContext) -> Result { let js_value = ctx.get::(0)?; ctx.env.get_boolean(js_value.is_error()?) } pub fn register_js(module: &mut Module) -> Result<()> { module.create_named_method("testThrow", test_throw)?; module.create_named_method("testThrowWithReason", test_throw_with_reason)?; module.create_named_method("isError", is_error)?; Ok(()) }