mirror of
https://github.com/nodejs/node.git
synced 2025-05-02 20:46:16 +00:00

* Prefix functions with `static` to make them local * Remove anonymous namespaces * `nullptr` -> `NULL` * .cc -> .c and update binding.gyp * `static_cast<x>()` -> `(x)()` * Replace `new`/`delete` with `malloc()`/`free()` (only in test_callback_scope) * Move lambda out and convert to local function (only in test_callback_scope) * Remove superfluous `#include <vector>` (only in test_callback_scope_recurse) Some tests are best left as C++. ```bash ls -l test/{node-api,js-native-api}/*/*.cc ``` for those remaining as C++ tests. Signed-off-by: Gabriel Schulhof <gabriel.schulhof@intel.com> PR-URL: https://github.com/nodejs/node/pull/34615 Reviewed-By: James M Snell <jasnell@gmail.com> Reviewed-By: Anna Henningsen <anna@addaleax.net> Reviewed-By: Jiawen Geng <technicalcute@gmail.com> Reviewed-By: Joyee Cheung <joyeec9h3@gmail.com> Reviewed-By: Gerhard Stöbich <deb2001-github@yahoo.de>
125 lines
4.0 KiB
C
125 lines
4.0 KiB
C
#include <stdlib.h>
|
|
#include "node_api.h"
|
|
#include "uv.h"
|
|
#include "../../js-native-api/common.h"
|
|
|
|
static napi_value RunInCallbackScope(napi_env env, napi_callback_info info) {
|
|
size_t argc;
|
|
napi_value args[3];
|
|
|
|
NAPI_CALL(env, napi_get_cb_info(env, info, &argc, NULL, NULL, NULL));
|
|
NAPI_ASSERT(env, argc == 3 , "Wrong number of arguments");
|
|
|
|
NAPI_CALL(env, napi_get_cb_info(env, info, &argc, args, NULL, NULL));
|
|
|
|
napi_valuetype valuetype;
|
|
NAPI_CALL(env, napi_typeof(env, args[0], &valuetype));
|
|
NAPI_ASSERT(env, valuetype == napi_object,
|
|
"Wrong type of arguments. Expects an object as first argument.");
|
|
|
|
NAPI_CALL(env, napi_typeof(env, args[1], &valuetype));
|
|
NAPI_ASSERT(env, valuetype == napi_string,
|
|
"Wrong type of arguments. Expects a string as second argument.");
|
|
|
|
NAPI_CALL(env, napi_typeof(env, args[2], &valuetype));
|
|
NAPI_ASSERT(env, valuetype == napi_function,
|
|
"Wrong type of arguments. Expects a function as third argument.");
|
|
|
|
napi_async_context context;
|
|
NAPI_CALL(env, napi_async_init(env, args[0], args[1], &context));
|
|
|
|
napi_callback_scope scope = NULL;
|
|
NAPI_CALL(
|
|
env,
|
|
napi_open_callback_scope(env,
|
|
args[0],
|
|
context,
|
|
&scope));
|
|
|
|
// if the function has an exception pending after the call that is ok
|
|
// so we don't use NAPI_CALL as we must close the callback scope regardless
|
|
napi_value result = NULL;
|
|
napi_status function_call_result =
|
|
napi_call_function(env, args[0], args[2], 0, NULL, &result);
|
|
if (function_call_result != napi_ok) {
|
|
GET_AND_THROW_LAST_ERROR((env));
|
|
}
|
|
|
|
NAPI_CALL(env, napi_close_callback_scope(env, scope));
|
|
NAPI_CALL(env, napi_async_destroy(env, context));
|
|
|
|
return result;
|
|
}
|
|
|
|
static napi_env shared_env = NULL;
|
|
static napi_deferred deferred = NULL;
|
|
|
|
static void Callback(uv_work_t* req, int ignored) {
|
|
napi_env env = shared_env;
|
|
|
|
napi_handle_scope handle_scope = NULL;
|
|
NAPI_CALL_RETURN_VOID(env, napi_open_handle_scope(env, &handle_scope));
|
|
|
|
napi_value resource_name;
|
|
NAPI_CALL_RETURN_VOID(env, napi_create_string_utf8(
|
|
env, "test", NAPI_AUTO_LENGTH, &resource_name));
|
|
napi_async_context context;
|
|
NAPI_CALL_RETURN_VOID(env,
|
|
napi_async_init(env, NULL, resource_name, &context));
|
|
|
|
napi_value resource_object;
|
|
NAPI_CALL_RETURN_VOID(env, napi_create_object(env, &resource_object));
|
|
|
|
napi_value undefined_value;
|
|
NAPI_CALL_RETURN_VOID(env, napi_get_undefined(env, &undefined_value));
|
|
|
|
napi_callback_scope scope = NULL;
|
|
NAPI_CALL_RETURN_VOID(env, napi_open_callback_scope(env,
|
|
resource_object,
|
|
context,
|
|
&scope));
|
|
|
|
NAPI_CALL_RETURN_VOID(env,
|
|
napi_resolve_deferred(env, deferred, undefined_value));
|
|
|
|
NAPI_CALL_RETURN_VOID(env, napi_close_callback_scope(env, scope));
|
|
|
|
NAPI_CALL_RETURN_VOID(env, napi_close_handle_scope(env, handle_scope));
|
|
NAPI_CALL_RETURN_VOID(env, napi_async_destroy(env, context));
|
|
free(req);
|
|
}
|
|
|
|
static void NoopWork(uv_work_t* work) { (void) work; }
|
|
|
|
static napi_value TestResolveAsync(napi_env env, napi_callback_info info) {
|
|
napi_value promise = NULL;
|
|
if (deferred == NULL) {
|
|
shared_env = env;
|
|
NAPI_CALL(env, napi_create_promise(env, &deferred, &promise));
|
|
|
|
uv_loop_t* loop = NULL;
|
|
NAPI_CALL(env, napi_get_uv_event_loop(env, &loop));
|
|
|
|
uv_work_t* req = malloc(sizeof(*req));
|
|
uv_queue_work(loop,
|
|
req,
|
|
NoopWork,
|
|
Callback);
|
|
}
|
|
return promise;
|
|
}
|
|
|
|
static napi_value Init(napi_env env, napi_value exports) {
|
|
napi_property_descriptor descriptors[] = {
|
|
DECLARE_NAPI_PROPERTY("runInCallbackScope", RunInCallbackScope),
|
|
DECLARE_NAPI_PROPERTY("testResolveAsync", TestResolveAsync)
|
|
};
|
|
|
|
NAPI_CALL(env, napi_define_properties(
|
|
env, exports, sizeof(descriptors) / sizeof(*descriptors), descriptors));
|
|
|
|
return exports;
|
|
}
|
|
|
|
NAPI_MODULE(NODE_GYP_MODULE_NAME, Init)
|