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 FILEMGMT_LIBHILOG_H 17 #define FILEMGMT_LIBHILOG_H 18 19 #include "hilog/log.h" 20 21 #include <string> 22 23 namespace OHOS { 24 namespace FileManagement { 25 26 #if defined __FILE_NAME__ 27 #define FILEMGMT_FILE_NAME __FILE_NAME__ 28 #else 29 #define FILEMGMT_FILE_NAME (strrchr(__FILE__, '/') ? strrchr(__FILE__, '/') + 1 : __FILE__) 30 #endif 31 32 #ifndef FILEMGMT_LOG_DOMAIN 33 #define FILEMGMT_LOG_DOMAIN 0xD004388 34 #endif 35 36 #undef FILEMGMT_LOG_TAG 37 #define FILEMGMT_LOG_TAG "file_api" 38 39 40 #ifdef HILOGD 41 #undef HILOGD 42 #endif 43 44 #ifdef HILOGF 45 #undef HILOGF 46 #endif 47 48 #ifdef HILOGE 49 #undef HILOGE 50 #endif 51 52 #ifdef HILOGW 53 #undef HILOGW 54 #endif 55 56 #ifdef HILOGI 57 #undef HILOGI 58 #endif 59 60 #define HILOGF(fmt, ...) \ 61 ((void)HILOG_IMPL(LOG_CORE, LOG_FATAL, FILEMGMT_LOG_DOMAIN, FILEMGMT_LOG_TAG, \ 62 "[%{public}s:%{public}d->%{public}s] " fmt, FILEMGMT_FILE_NAME, __LINE__, __FUNCTION__, ##__VA_ARGS__)) 63 #define HILOGE(fmt, ...) \ 64 ((void)HILOG_IMPL(LOG_CORE, LOG_ERROR, FILEMGMT_LOG_DOMAIN, FILEMGMT_LOG_TAG, \ 65 "[%{public}s:%{public}d->%{public}s] " fmt, FILEMGMT_FILE_NAME, __LINE__, __FUNCTION__, ##__VA_ARGS__)) 66 #define HILOGW(fmt, ...) \ 67 ((void)HILOG_IMPL(LOG_CORE, LOG_WARN, FILEMGMT_LOG_DOMAIN, FILEMGMT_LOG_TAG, \ 68 "[%{public}s:%{public}d->%{public}s] " fmt, FILEMGMT_FILE_NAME, __LINE__, __FUNCTION__, ##__VA_ARGS__)) 69 #define HILOGI(fmt, ...) \ 70 ((void)HILOG_IMPL(LOG_CORE, LOG_INFO, FILEMGMT_LOG_DOMAIN, FILEMGMT_LOG_TAG, \ 71 "[%{public}s:%{public}d->%{public}s] " fmt, FILEMGMT_FILE_NAME, __LINE__, __FUNCTION__, ##__VA_ARGS__)) 72 #define HILOGD(fmt, ...) \ 73 ((void)HILOG_IMPL(LOG_CORE, LOG_DEBUG, FILEMGMT_LOG_DOMAIN, FILEMGMT_LOG_TAG, \ 74 "[%{public}s:%{public}d->%{public}s] " fmt, FILEMGMT_FILE_NAME, __LINE__, __FUNCTION__, ##__VA_ARGS__)) 75 } // namespace FileManagement 76 } // namespace OHOS 77 78 #endif // FILEMGMT_LIBHILOG_H