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