diff --git a/src/node_api.cc b/src/node_api.cc index 20bec452e7..972702bd8b 100644 --- a/src/node_api.cc +++ b/src/node_api.cc @@ -455,7 +455,7 @@ class CallbackWrapper { CallbackWrapper(napi_value this_arg, size_t args_length, void* data) : _this(this_arg), _args_length(args_length), _data(data) {} - virtual napi_value NewTarget() = 0; + virtual napi_value GetNewTarget() = 0; virtual void Args(napi_value* buffer, size_t bufferlength) = 0; virtual void SetReturnValue(napi_value value) = 0; @@ -484,7 +484,7 @@ class CallbackWrapperBase : public CallbackWrapper { ->Value(); } - napi_value NewTarget() override { return nullptr; } + napi_value GetNewTarget() override { return nullptr; } protected: void InvokeCallback() { @@ -532,7 +532,7 @@ class FunctionCallbackWrapper const v8::FunctionCallbackInfo& cbinfo) : CallbackWrapperBase(cbinfo, cbinfo.Length()) {} - napi_value NewTarget() override { + napi_value GetNewTarget() override { if (_cbinfo.IsConstructCall()) { return v8impl::JsValueFromV8LocalValue(_cbinfo.NewTarget()); } else { @@ -854,8 +854,12 @@ void napi_module_register_cb(v8::Local exports, // Registers a NAPI module. void napi_module_register(napi_module* mod) { + int module_version = -1; +#ifdef EXTERNAL_NAPI + module_version = NODE_MODULE_VERSION; +#endif // EXTERNAL_NAPI node::node_module* nm = new node::node_module { - -1, + module_version, mod->nm_flags, nullptr, mod->nm_filename, @@ -1930,7 +1934,7 @@ napi_status napi_get_new_target(napi_env env, v8impl::CallbackWrapper* info = reinterpret_cast(cbinfo); - *result = info->NewTarget(); + *result = info->GetNewTarget(); return napi_clear_last_error(env); } @@ -3357,7 +3361,7 @@ class Work : public node::AsyncResource { void* data = nullptr) : AsyncResource(env->isolate, async_resource, - async_resource_name), + *v8::String::Utf8Value(async_resource_name)), _env(env), _data(data), _execute(execute),