代码讲解 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 17:23:16 浏览: 148
这段代码是一个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等,这些宏定义是为了简化代码,提高可读性和可维护性。
相关问题
代码讲解 napi_value NapiMd::CreateMd(napi_env env, napi_callback_info info) { size_t expectedArgc = ARGS_SIZE_ONE; size_t argc = expectedArgc; napi_value argv[ARGS_SIZE_ONE] = { nullptr }; napi_get_cb_info(env, info, &argc, argv, nullptr, nullptr); if (argc != expectedArgc) { LOGE("The input args num is invalid."); return nullptr; } std::string algoName; if (!GetStringFromJSParams(env, argv[PARAM0], algoName)) { LOGE("Failed to get algorithm."); return nullptr; } HcfMd *mdObj = nullptr; HcfResult res = HcfMdCreate(algoName.c_str(), &mdObj); if (res != HCF_SUCCESS) { napi_throw(env, GenerateBusinessError(env, res, "create C obj failed.")); LOGE("create c mdObj failed."); return nullptr; } napi_value napiAlgName = nullptr; napi_create_string_utf8(env, algoName.c_str(), NAPI_AUTO_LENGTH, &napiAlgName); napi_value instance = nullptr; napi_value constructor = nullptr; napi_get_reference_value(env, classRef_, &constructor); napi_new_instance(env, constructor, argc, argv, &instance); napi_set_named_property(env, instance, CRYPTO_TAG_ALG_NAME.c_str(), napiAlgName); NapiMd *mdNapiObj = new (std::nothrow) NapiMd(mdObj); if (mdNapiObj == nullptr) { LOGE("create napi obj failed"); return nullptr; } napi_wrap( env, instance, mdNapiObj, [](napi_env env, void *data, void *hint) { NapiMd *md = static_cast<NapiMd *>(data); delete md; return; }, nullptr, nullptr); return instance; }
这是一个 C++ 的函数,用于创建一个 MD 对象,并返回一个与 JavaScript 对象绑定的 N-API 对象。以下是函数的代码解释:
- 首先声明了变量 expectedArgc 来保存函数期望的参数个数,同时声明了变量 argc 和数组 argv 用于保存实际传入的参数。
- 接着调用 napi_get_cb_info 函数来获取在 JavaScript 中传入的参数个数和值,并检查传入参数的个数是否符合预期。如果不符合,则返回 nullptr。
- 使用 GetStringFromJSParams 函数从参数中获取算法名称的字符串,如果获取失败,则返回 nullptr。
- 调用 HcfMdCreate 函数创建一个 HcfMd 对象,并将其保存在 mdObj 指针中。如果创建失败,则抛出一个异常,并返回 nullptr。
- 使用 napi_create_string_utf8 函数创建一个算法名称的 N-API 字符串。
- 使用 napi_get_reference_value 函数获取类的构造函数,并使用 napi_new_instance 函数创建一个新的 JavaScript 对象实例。
- 使用 napi_set_named_property 函数将算法名称的 N-API 字符串设置为对象的属性。
- 创建一个 NapiMd 对象并将其保存在 mdNapiObj 指针中。
- 使用 napi_wrap 函数将 NapiMd 对象与 JavaScript 对象实例绑定,使得 JavaScript 中的对象可以访问 NapiMd 对象的属性和方法。
- 最后,返回绑定后的 JavaScript 对象实例。
napi_value RdbStoreProxy::OnEvent(napi_env env, napi_callback_info info) { size_t argc = 3; napi_value argv[3]{}; napi_value self = nullptr; napi_status status = napi_get_cb_info(env, info, &argc, argv, &self, nullptr); RDB_NAPI_ASSERT(env, status == napi_ok && (argc == 3), std::make_shared<ParamNumError>("3")); auto proxy = GetNativeInstance(env, self); RDB_NAPI_ASSERT(env, proxy != nullptr, std::make_shared<ParamError>("RdbStore", "valid"));解释一下这段代码
这段代码是一个名为`RdbStoreProxy`的类中的成员函数`OnEvent`的实现。该函数是一个 `napi_value` 类型的回调函数,用于在事件发生时被调用。
函数的参数包括 `napi_env` 环境变量、`napi_callback_info` 回调信息,用于获取函数的参数和上下文信息。
在函数内部,首先定义了变量 `argc` 并赋值为 3,表示参数数量为 3。然后定义了一个长度为 3 的 `napi_value` 数组 `argv`,用于存储参数值。
接下来调用了 `napi_get_cb_info` 函数,用于获取回调函数的详细信息。其中传入了 `env`、`info`、`argc`、`argv` 和 `self` 等参数,并将返回值保存在 `status` 变量中。
然后通过调用 `GetNativeInstance` 函数,从 `self` 中获取 `RdbStoreProxy` 类的实例,并将结果保存在 `proxy` 变量中。
最后使用 `RDB_NAPI_ASSERT` 宏进行断言检查,确保 `proxy` 不为空。如果为空,则抛出一个自定义的异常。
这段代码的作用是在事件发生时,获取回调函数的参数和上下文,并从上下文中获取 `RdbStoreProxy` 类的实例。然后进行进一步的处理或异常处理。
阅读全文