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 HAPVERIFY_LOG_H
17 #define HAPVERIFY_LOG_H
18 
19 #include "hilog/log.h"
20 
21 namespace OHOS {
22 namespace Security {
23 namespace Verify {
24 
25 #ifndef HAPVERIFY_LOG_DOMAIN
26 #define HAPVERIFY_LOG_DOMAIN 0xD0011FE
27 #endif
28 
29 #ifndef HAPVERIFY_APP_LOG_TAG
30 #define HAPVERIFY_APP_LOG_TAG "HapVerify"
31 #endif
32 
33 #define FILENAME (__builtin_strrchr(__FILE__, '/') ? __builtin_strrchr(__FILE__, '/') + 1 : __FILE__)
34 #define HAPVERIFY_LOG_DEBUG(fmt, ...)            \
35     ((void)HILOG_IMPL(LOG_CORE, LOG_DEBUG, HAPVERIFY_LOG_DOMAIN, HAPVERIFY_APP_LOG_TAG, \
36     "[%{public}s(%{public}s:%{public}d)]" fmt, FILENAME, __FUNCTION__, __LINE__, ##__VA_ARGS__))
37 
38 #define HAPVERIFY_LOG_INFO(fmt, ...)            \
39     ((void)HILOG_IMPL(LOG_CORE, LOG_INFO, HAPVERIFY_LOG_DOMAIN, HAPVERIFY_APP_LOG_TAG, \
40     "[%{public}s(%{public}s:%{public}d)]" fmt, FILENAME, __FUNCTION__, __LINE__, ##__VA_ARGS__))
41 
42 #define HAPVERIFY_LOG_WARN(fmt, ...)            \
43     ((void)HILOG_IMPL(LOG_CORE, LOG_WARN, HAPVERIFY_LOG_DOMAIN, HAPVERIFY_APP_LOG_TAG, \
44     "[%{public}s(%{public}s:%{public}d)]" fmt, FILENAME, __FUNCTION__, __LINE__, ##__VA_ARGS__))
45 
46 #define HAPVERIFY_LOG_ERROR(fmt, ...)            \
47     ((void)HILOG_IMPL(LOG_CORE, LOG_ERROR, HAPVERIFY_LOG_DOMAIN, HAPVERIFY_APP_LOG_TAG, \
48     "[%{public}s(%{public}s:%{public}d)]" fmt, FILENAME, __FUNCTION__, __LINE__, ##__VA_ARGS__))
49 
50 #define HAPVERIFY_LOG_FATAL(fmt, ...)            \
51     ((void)HILOG_IMPL(LOG_CORE, LOG_FATAL, HAPVERIFY_LOG_DOMAIN, HAPVERIFY_APP_LOG_TAG, \
52     "[%{public}s(%{public}s:%{public}d)]" fmt, FILENAME, __FUNCTION__, __LINE__, ##__VA_ARGS__))
53 } // namespace Verify
54 } // namespace Security
55 } // namespace OHOS
56 #endif // HAPVERIFY_LOG_H
57