Как сохранить обратный вызов на потом с помощью node-addon-api?
Я хочу, чтобы моя библиотека C могла вызывать функцию JS несколько раз. Я заставил его работать с использованием Nan, но у меня возникли проблемы с преобразованием его в N-API/node-addon-api.
Как сохранить функцию обратного вызова JS и вызвать ее позже из C?
Вот что я использую с помощью Nan:
Persistent<Function> r_log;
void sendLogMessageToJS(char* msg) {
if (!r_log.IsEmpty()) {
Isolate* isolate = Isolate::GetCurrent();
Local<Function> func = Local<Function>::New(isolate, r_log);
if (!func.IsEmpty()) {
const unsigned argc = 1;
Local<Value> argv[argc] = {
String::NewFromUtf8(isolate, msg)
};
func->Call(Null(isolate), argc, argv);
}
}
}
NAN_METHOD(register_logger) {
Isolate* isolate = info.GetIsolate();
if (info[0]->IsFunction()) {
Local<Function> func = Local<Function>::Cast(info[0]);
Function * ptr = *func;
r_log.Reset(isolate, func);
myclibrary_register_logger(sendLogMessageToJS);
} else {
r_log.Reset();
}
}
Как мне сделать эквивалент с node-addon-api? Все примеры, которые я видел, немедленно вызывают обратный вызов или используют AsyncWorker, чтобы каким-то образом сохранить обратный вызов. Я не могу понять, как это делает AsyncWorker.
1 ответ
Решение
Я получил ответ от сопровождающих node-addon-api, который привел меня к этому решению:
FunctionReference r_log;
void emitLogInJS(char* msg) {
if (r_log != nullptr) {
Env env = r_log.Env();
String message = String::New(env, msg);
std::vector<napi_value> args = {message};
r_log.Call(args);
}
}
void register_logger(const CallbackInfo& info) {
r_log = Persistent(info[0].As<Function>());
myclibrary_register_logger(emitLogInJS);
}