1 /*
2 * Copyright (c) 2022 Huawei Device Co., Ltd.
3 * Licensed under the Apache License, Version 2.0 (the "License");
4 * you may not use this file except in compliance with the License.
5 * You may obtain a copy of the License at
6 *
7 * http://www.apache.org/licenses/LICENSE-2.0
8 *
9 * Unless required by applicable law or agreed to in writing, software
10 * distributed under the License is distributed on an "AS IS" BASIS,
11 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12 * See the License for the specific language governing permissions and
13 * limitations under the License.
14 */
15
16 #include "napi/native_api.h"
17 #include "hilog/log.h"
18
OhIsLoggableTest(napi_env env,napi_callback_info info)19 static napi_value OhIsLoggableTest(napi_env env, napi_callback_info info)
20 {
21 napi_value res = nullptr;
22 bool isLoggable = OH_LOG_IsLoggable(0x3200, "testTag", LOG_DEBUG);
23 napi_get_boolean(env, isLoggable, &res);
24 return res;
25 }
26
OhPrintTest(napi_env env,napi_callback_info info)27 static napi_value OhPrintTest(napi_env env, napi_callback_info info)
28 {
29 napi_value res = nullptr;
30 LogType type = LOG_APP;
31 LogLevel level = LOG_ERROR;
32 int retLen = OH_LOG_Print(type, level, 0x3200, "testTag", "string for hilog test");
33 bool ret = (retLen > 0) ? true : false;
34 napi_get_boolean(env, ret, &res);
35 return res;
36 }
37
38
39
40 EXTERN_C_START
Init(napi_env env,napi_value exports)41 static napi_value Init(napi_env env, napi_value exports)
42 {
43 napi_property_descriptor desc[] = {
44 { "ohIsLoggableTest", nullptr, OhIsLoggableTest,
45 nullptr, nullptr, nullptr, napi_default, nullptr },
46 { "ohPrintTest", nullptr, OhPrintTest,
47 nullptr, nullptr, nullptr, napi_default, nullptr }
48 };
49 napi_define_properties(env, exports, sizeof(desc) / sizeof(desc[0]), desc);
50 return exports;
51 }
52 EXTERN_C_END
53
54 static napi_module demoModule = {
55 .nm_version =1,
56 .nm_flags = 0,
57 .nm_filename = nullptr,
58 .nm_register_func = Init,
59 .nm_modname = "libhilogndk",
60 .nm_priv = ((void*)0),
61 .reserved = { 0 },
62 };
63
RegisterModule(void)64 extern "C" __attribute__((constructor)) void RegisterModule(void)
65 {
66 napi_module_register(&demoModule);
67 }
68