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 #ifndef SCAN_LOG
17 #define SCAN_LOG
18 
19 #define CONFIG_SCAN_LOG
20 #ifdef CONFIG_SCAN_LOG
21 #include "hilog/log.h"
22 
23 #ifdef SCAN_HILOGF
24 #undef SCAN_HILOGF
25 #endif
26 
27 #ifdef SCAN_HILOGE
28 #undef SCAN_HILOGE
29 #endif
30 
31 #ifdef SCAN_HILOGW
32 #undef SCAN_HILOGW
33 #endif
34 
35 #ifdef SCAN_HILOGD
36 #undef SCAN_HILOGD
37 #endif
38 
39 #ifdef SCAN_HILOGI
40 #undef SCAN_HILOGI
41 #endif
42 
43 #define SCAN_LOG_TAG "scankit"
44 #define SCAN_LOG_DOMAIN 0xD001C00
45 
46 #ifdef IS_RELEASE_VERSION
47 #define SCAN_MAKE_FILE_NAME ""
48 #else
49 #define SCAN_MAKE_FILE_NAME \
50     (__builtin_strrchr(__FILE_NAME__, '/') ? __builtin_strrchr(__FILE_NAME__, '/') + 1 : __FILE_NAME__)
51 #endif
52 
53 #define SCAN_HILOGF(fmt, ...)                                        								\
54     (void)HILOG_IMPL(LOG_CORE, LOG_FATAL, SCAN_LOG_DOMAIN, SCAN_LOG_TAG, "[%{public}s %{public}s %{public}d] " fmt,	\
55     SCAN_MAKE_FILE_NAME, __FUNCTION__, __LINE__, ##__VA_ARGS__)
56 
57 #define SCAN_HILOGE(fmt, ...)                                      									\
58     (void)HILOG_IMPL(LOG_CORE, LOG_ERROR, SCAN_LOG_DOMAIN, SCAN_LOG_TAG, "[%{public}s %{public}s %{public}d] " fmt,	\
59     SCAN_MAKE_FILE_NAME, __FUNCTION__, __LINE__, ##__VA_ARGS__)
60 
61 #define SCAN_HILOGW(fmt, ...)                                                        				\
62     (void)HILOG_IMPL(LOG_CORE, LOG_WARN, SCAN_LOG_DOMAIN, SCAN_LOG_TAG, "[%{public}s %{public}s %{public}d] " fmt,	\
63     SCAN_MAKE_FILE_NAME, __FUNCTION__, __LINE__, ##__VA_ARGS__)
64 
65 #define SCAN_HILOGD(fmt, ...)                                                            			\
66     (void)HILOG_IMPL(LOG_CORE, LOG_DEBUG, SCAN_LOG_DOMAIN, SCAN_LOG_TAG, "[%{public}s %{public}s %{public}d] " fmt,	\
67     SCAN_MAKE_FILE_NAME, __FUNCTION__, __LINE__, ##__VA_ARGS__)
68 
69 #define SCAN_HILOGI(fmt, ...)                                                     					\
70     (void)HILOG_IMPL(LOG_CORE, LOG_INFO, SCAN_LOG_DOMAIN, SCAN_LOG_TAG, "[%{public}s %{public}s %{public}d] " fmt,	\
71     SCAN_MAKE_FILE_NAME, __FUNCTION__, __LINE__, ##__VA_ARGS__)
72 
73 #else
74 
75 #define SCAN_HILOGF(fmt, ...)
76 #define SCAN_HILOGE(fmt, ...)
77 #define SCAN_HILOGW(fmt, ...)
78 #define SCAN_HILOGD(fmt, ...)
79 #define SCAN_HILOGI(fmt, ...)
80 #endif // CONFIG_SCAN_LOG
81 
82 #endif /* SCAN_LOG */
83