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