n-api: re-write test_make_callback
This re-writes the test in C by dropping std::vector<napi_value> in favour of a C99 variable length array, and by dropping the anonymous namespace in favour of static function declarations. PR-URL: https://github.com/nodejs/node/pull/19448 Reviewed-By: James M Snell <jasnell@gmail.com> Reviewed-By: Luigi Pinca <luigipinca@gmail.com> Reviewed-By: Michael Dawson <michael_dawson@ca.ibm.com>
This commit is contained in:
parent
9b34ea6161
commit
be470943fb
@ -1,13 +1,13 @@
|
|||||||
#include <node_api.h>
|
#include <node_api.h>
|
||||||
#include "../common.h"
|
#include "../common.h"
|
||||||
#include <vector>
|
|
||||||
|
|
||||||
namespace {
|
#define MAX_ARGUMENTS 10
|
||||||
|
|
||||||
|
static
|
||||||
napi_value MakeCallback(napi_env env, napi_callback_info info) {
|
napi_value MakeCallback(napi_env env, napi_callback_info info) {
|
||||||
const int kMaxArgs = 10;
|
size_t argc = MAX_ARGUMENTS;
|
||||||
size_t argc = kMaxArgs;
|
size_t n;
|
||||||
napi_value args[kMaxArgs];
|
napi_value args[MAX_ARGUMENTS];
|
||||||
// NOLINTNEXTLINE (readability/null_usage)
|
// NOLINTNEXTLINE (readability/null_usage)
|
||||||
NAPI_CALL(env, napi_get_cb_info(env, info, &argc, args, NULL, NULL));
|
NAPI_CALL(env, napi_get_cb_info(env, info, &argc, args, NULL, NULL));
|
||||||
|
|
||||||
@ -16,9 +16,9 @@ napi_value MakeCallback(napi_env env, napi_callback_info info) {
|
|||||||
napi_value recv = args[0];
|
napi_value recv = args[0];
|
||||||
napi_value func = args[1];
|
napi_value func = args[1];
|
||||||
|
|
||||||
std::vector<napi_value> argv;
|
napi_value argv[MAX_ARGUMENTS - 2];
|
||||||
for (size_t n = 2; n < argc; n += 1) {
|
for (n = 2; n < argc; n += 1) {
|
||||||
argv.push_back(args[n]);
|
argv[n - 2] = args[n];
|
||||||
}
|
}
|
||||||
|
|
||||||
napi_valuetype func_type;
|
napi_valuetype func_type;
|
||||||
@ -35,7 +35,7 @@ napi_value MakeCallback(napi_env env, napi_callback_info info) {
|
|||||||
napi_value result;
|
napi_value result;
|
||||||
if (func_type == napi_function) {
|
if (func_type == napi_function) {
|
||||||
NAPI_CALL(env, napi_make_callback(
|
NAPI_CALL(env, napi_make_callback(
|
||||||
env, context, recv, func, argv.size(), argv.data(), &result));
|
env, context, recv, func, argc - 2, argv, &result));
|
||||||
} else {
|
} else {
|
||||||
NAPI_ASSERT(env, false, "Unexpected argument type");
|
NAPI_ASSERT(env, false, "Unexpected argument type");
|
||||||
}
|
}
|
||||||
@ -45,6 +45,7 @@ napi_value MakeCallback(napi_env env, napi_callback_info info) {
|
|||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static
|
||||||
napi_value Init(napi_env env, napi_value exports) {
|
napi_value Init(napi_env env, napi_value exports) {
|
||||||
napi_value fn;
|
napi_value fn;
|
||||||
NAPI_CALL(env, napi_create_function(
|
NAPI_CALL(env, napi_create_function(
|
||||||
@ -54,6 +55,4 @@ napi_value Init(napi_env env, napi_value exports) {
|
|||||||
return exports;
|
return exports;
|
||||||
}
|
}
|
||||||
|
|
||||||
} // anonymous namespace
|
|
||||||
|
|
||||||
NAPI_MODULE(NODE_GYP_MODULE_NAME, Init)
|
NAPI_MODULE(NODE_GYP_MODULE_NAME, Init)
|
@ -3,7 +3,7 @@
|
|||||||
{
|
{
|
||||||
'target_name': 'binding',
|
'target_name': 'binding',
|
||||||
'defines': [ 'V8_DEPRECATION_WARNINGS=1' ],
|
'defines': [ 'V8_DEPRECATION_WARNINGS=1' ],
|
||||||
'sources': [ 'binding.cc' ]
|
'sources': [ 'binding.c' ]
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user