代码讲解 napi_value NapiCipher::CreateCipher(napi_env env, napi_callback_info info) { size_t expectedArgc = ARGS_SIZE_ONE; size_t argc = ARGS_SIZE_ONE; napi_value argv[ARGS_SIZE_ONE] = { nullptr }; NAPI_CALL(env, napi_get_cb_info(env, info, &argc, argv, nullptr, nullptr)); if (argc != expectedArgc) { napi_throw(env, GenerateBusinessError(env, HCF_INVALID_PARAMS, "The input args num is invalid.")); LOGE("The input args num is invalid."); return nullptr; } // create instance according to input js object napi_value instance = nullptr; napi_value constructor = nullptr; NAPI_CALL(env, napi_get_reference_value(env, classRef_, &constructor)); NAPI_CALL(env, napi_new_instance(env, constructor, argc, argv, &instance)); // parse input string std::string algoName; if (!GetStringFromJSParams(env, argv[0], algoName)) { LOGE("GetStringFromJSParams failed!"); return nullptr; } // execute C function, generate C object HcfCipher *cipher = nullptr; HcfResult res = HcfCipherCreate(algoName.c_str(), &cipher); if (res != HCF_SUCCESS) { napi_throw(env, GenerateBusinessError(env, res, "create C cipher fail!")); LOGE("create C cipher fail!"); return nullptr; } NapiCipher *napiCipher = new (std::nothrow) NapiCipher(cipher); if (napiCipher == nullptr) { LOGE("new napiCipher failed!"); HcfObjDestroy(cipher); return nullptr; } napi_status status = napi_wrap(env, instance, napiCipher, [](napi_env env, void *data, void *hint) { NapiCipher *napiCipher = static_cast<NapiCipher *>(data); delete napiCipher; return; }, nullptr, nullptr); if (status != napi_ok) { LOGE("failed to wrap napiCipher obj!"); delete napiCipher; return nullptr; } return instance; }
时间: 2024-04-28 15:23:16 浏览: 140
Improving Passive Packet Capture:Beyond Device Polling(中文版)
4星 · 用户满意度95%
这段代码是一个C++的函数,用于创建一个NapiCipher对象的实例。它接受两个参数:napi_env env和napi_callback_info info,分别表示N-API的执行环境和回调信息。该函数的返回值是一个napi_value类型的对象。
在函数中,首先定义了expectedArgc、argc和argv三个变量,用于存储期望的参数个数、实际的参数个数和参数值。然后调用napi_get_cb_info函数获取回调信息,并根据参数个数进行判断,如果不符合期望,则抛出异常并返回空指针。
接下来,根据输入的JS对象创建一个实例,并解析出算法名称。然后执行一个C函数HcfCipherCreate,用于创建一个HcfCipher对象。如果创建失败,则抛出异常并返回空指针。否则,创建一个NapiCipher对象,并将其封装到JS对象中。最后返回JS对象。
需要注意的是,该函数中使用了一些宏定义,如ARGS_SIZE_ONE和NAPI_CALL等,这些宏定义是为了简化代码,提高可读性和可维护性。
阅读全文