• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2  * Copyright (c) 2021 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 #ifndef TIME_HILOG_WRAPPER_H
17 #define TIME_HILOG_WRAPPER_H
18 
19 #include "hilog/log.h"
20 
21 namespace OHOS {
22 namespace MiscServices {
23 // param of log interface, such as TIME_HILOGF.
24 enum TimeSubModule {
25     TIME_MODULE_INNERKIT = 0,
26     TIME_MODULE_CLIENT,
27     TIME_MODULE_SERVICE,
28     TIME_MODULE_JAVAKIT, // java kit, defined to avoid repeated use of domain.
29     TIME_MODULE_JNI,
30     TIME_MODULE_COMMON,
31     TIME_MODULE_JS_NAPI,
32     TIME_MODULE_BUTT,
33 };
34 
35 // 0xD001C00: subsystem:TIME module:TimeManager, 8 bits reserved.
36 static constexpr unsigned int BASE_TIME_DOMAIN_ID = 0xD001C00;
37 
38 enum TimeDomainId {
39     TIME_INNERKIT_DOMAIN = BASE_TIME_DOMAIN_ID + TIME_MODULE_INNERKIT,
40     TIME_CLIENT_DOMAIN,
41     TIME_SERVICE_DOMAIN,
42     TIME_JAVAKIT_DOMAIN,
43     TIME_JNI_DOMAIN,
44     TIME_COMMON_DOMAIN,
45     TIME_JS_NAPI,
46     TIME_BUTT,
47 };
48 
49 static constexpr OHOS::HiviewDFX::HiLogLabel TIME_MODULE_LABEL[TIME_MODULE_BUTT] = {
50     {LOG_CORE, TIME_INNERKIT_DOMAIN, "TimeInnerKit"},
51     {LOG_CORE, TIME_CLIENT_DOMAIN, "TimeClient"},
52     {LOG_CORE, TIME_SERVICE_DOMAIN, "TimeService"},
53     {LOG_CORE, TIME_JAVAKIT_DOMAIN, "TimeJavaKit"},
54     {LOG_CORE, TIME_JNI_DOMAIN, "TimeJni"},
55     {LOG_CORE, TIME_COMMON_DOMAIN, "TimeCommon"},
56     {LOG_CORE, TIME_JS_NAPI, "TimeJSNAPI"},
57 };
58 
59 #define R_FILENAME__            (__builtin_strrchr(__FILE__, '/') ? __builtin_strrchr(__FILE__, '/') + 1 : __FILE__)
60 #define R_FORMATED(fmt, ...)    "[%{public}s] %{public}s# " fmt, R_FILENAME__, __FUNCTION__, ##__VA_ARGS__
61 
62 // In order to improve performance, do not check the module range.
63 // Besides, make sure module is less than TIME_MODULE_BUTT.
64 #define TIME_HILOGF(module, ...) (void)OHOS::HiviewDFX::HiLog::Fatal(TIME_MODULE_LABEL[module], R_FORMATED(__VA_ARGS__))
65 #define TIME_HILOGE(module, ...) (void)OHOS::HiviewDFX::HiLog::Error(TIME_MODULE_LABEL[module], R_FORMATED(__VA_ARGS__))
66 #define TIME_HILOGW(module, ...) (void)OHOS::HiviewDFX::HiLog::Warn(TIME_MODULE_LABEL[module], R_FORMATED(__VA_ARGS__))
67 #define TIME_HILOGI(module, ...) (void)OHOS::HiviewDFX::HiLog::Info(TIME_MODULE_LABEL[module], R_FORMATED(__VA_ARGS__))
68 #define TIME_HILOGD(module, ...) (void)OHOS::HiviewDFX::HiLog::Debug(TIME_MODULE_LABEL[module], R_FORMATED(__VA_ARGS__))
69 } // namespace MiscServices
70 } // namespace OHOS
71 #endif // TIME_HILOG_WRAPPER_H
72