• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
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