我正在尝试为NAPI
编写以下函数。
int addon::fakeAdd(int a, int b)
{
return a + b;
}
Napi::Number addon::addWrapped(const Napi::CallbackInfo &info)
{
Napi::Env env = info.Env();
if (info.Length() < 2 || !info[0].IsNumber() || !info[1].IsNumber())
{
auto x = Napi::TypeError::New(env, "You did not provide 2 numbers");
x.ThrowAsJavaScriptException();
}
Napi::Number num1 = info[0].As<Napi::Number>();
Napi::Number num2 = info[1].As<Napi::Number>();
int returnValue = addon::fakeAdd(num1.Int32Value(), num2.Int32Value());
return Number::New(env, returnValue);
}
我正在将此函数导出为add
。当我从javascript使用to参数来调用它时(例如addon.add(1,2)
),所有内容都像魅力一样工作,并且我得到了正确的结果,即3.现在,我想处理用户未向函数提供任何参数或(一个或两个)参数不是数字。在这种情况下,我想抛出一个自定义消息(“您没有提供2个数字”)。但是,当我尝试从JavaScript调用没有任何参数的方法时,我得到以下信息错误:
console.log(addon.add());
^
Error: A number was expected
我收到此特定消息而不是在if
块中写的消息是有原因的吗?
这是我导出函数的方式:
Napi::Object addon::Init(Napi::Env env, Napi::Object exports)
{
exports.Set("add", Napi::Function::New(env, addon::addWrapped));
exports.Set("getOsName", Napi::Function::New(env, addon::getOSNameWrapped));
exports.Set("writeToFile", Napi::Function::New(env, addon::writeFileWrapped));
return exports;
}
这是binding.gyp文件
{
"targets": [{
"target_name": "testaddon",
"cflags!": [ "-fno-exceptions"],
"cflags_cc!": [ "-fno-exceptions" ],
"cflags_cc":["-std=c++1z" ],
"sources": [
"cppsrc/main.cpp",
"cppsrc/functionexample.cpp"
],
'include_dirs': [
"<!@(node -p \"require('node-addon-api').include\")"
],
'libraries': [],
'dependencies': [
"<!(node -p \"require('node-addon-api').gyp\")"
],
'defines': [ 'NAPI_DISABLE_CPP_EXCEPTIONS' ]
}]
}
答案 0 :(得分:2)
假设您在binding.gyp中禁用了C ++异常(cflags / cflags_cc =“ -fno-exceptions ”,定义为:“ NAPI_DISABLE_CPP_EXCEPTIONS ”),则应阅读{ {3}}:
抛出JavaScript异常后,代码通常应该 执行任何操作后,从本机回调中立即返回 必要的清理。
一个例子:
Napi::Error::New(env, "Example exception").ThrowAsJavaScriptException();
return;
调用ThrowAsJavaScriptException()不会引发C ++异常,因此,如果您不返回,则C ++函数将继续运行。