1a34a8711Sopenharmony_ci/*
2a34a8711Sopenharmony_ci * Copyright (C) 2021 Huawei Device Co., Ltd.
3a34a8711Sopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License");
4a34a8711Sopenharmony_ci * you may not use this file except in compliance with the License.
5a34a8711Sopenharmony_ci * You may obtain a copy of the License at
6a34a8711Sopenharmony_ci *
7a34a8711Sopenharmony_ci *     http://www.apache.org/licenses/LICENSE-2.0
8a34a8711Sopenharmony_ci *
9a34a8711Sopenharmony_ci * Unless required by applicable law or agreed to in writing, software
10a34a8711Sopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS,
11a34a8711Sopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12a34a8711Sopenharmony_ci * See the License for the specific language governing permissions and
13a34a8711Sopenharmony_ci * limitations under the License.
14a34a8711Sopenharmony_ci */
15a34a8711Sopenharmony_ci
16a34a8711Sopenharmony_ci#ifndef OHOS_IPC_RPC_LOG_H
17a34a8711Sopenharmony_ci#define OHOS_IPC_RPC_LOG_H
18a34a8711Sopenharmony_ci
19a34a8711Sopenharmony_ci#include <stdio.h>
20a34a8711Sopenharmony_ci#include <stdbool.h>
21a34a8711Sopenharmony_ci
22a34a8711Sopenharmony_ci#ifndef IPCRPC_DEBUG
23a34a8711Sopenharmony_ci#if defined(__LITEOS_M__)
24a34a8711Sopenharmony_ci#define IPCRPC_PRINTF
25a34a8711Sopenharmony_ci#include "log.h"
26a34a8711Sopenharmony_ci#else
27a34a8711Sopenharmony_ci#include "hilog/log.h"
28a34a8711Sopenharmony_ci#endif
29a34a8711Sopenharmony_ci#endif
30a34a8711Sopenharmony_ci
31a34a8711Sopenharmony_ci#ifdef __cplusplus
32a34a8711Sopenharmony_ciextern "C" {
33a34a8711Sopenharmony_ci#endif
34a34a8711Sopenharmony_ci
35a34a8711Sopenharmony_ci#ifndef IPCRPC_DEBUG
36a34a8711Sopenharmony_ci#if defined(__LITEOS_M__)
37a34a8711Sopenharmony_ci#define RPC_LOG_DEBUG(fmt, ...)  HILOG_DEBUG(HILOG_MODULE_SOFTBUS, fmt, ##__VA_ARGS__)
38a34a8711Sopenharmony_ci#define RPC_LOG_INFO(fmt, ...)   HILOG_INFO(HILOG_MODULE_SOFTBUS, fmt, ##__VA_ARGS__)
39a34a8711Sopenharmony_ci#define RPC_LOG_WARN(fmt, ...)   HILOG_WARN(HILOG_MODULE_SOFTBUS, fmt, ##__VA_ARGS__)
40a34a8711Sopenharmony_ci#define RPC_LOG_ERROR(fmt, ...)  HILOG_ERROR(HILOG_MODULE_SOFTBUS, fmt, ##__VA_ARGS__)
41a34a8711Sopenharmony_ci#else
42a34a8711Sopenharmony_ci#undef LOG_DOMAIN
43a34a8711Sopenharmony_ci#undef LOG_TAG
44a34a8711Sopenharmony_ci#define LOG_DOMAIN 0xD001518
45a34a8711Sopenharmony_ci#define LOG_TAG "IPCRPC"
46a34a8711Sopenharmony_ci
47a34a8711Sopenharmony_ci#define RPC_LOG_DEBUG(fmt, ...) HILOG_DEBUG(LOG_CORE, fmt, ##__VA_ARGS__)
48a34a8711Sopenharmony_ci#define RPC_LOG_INFO(fmt, ...)  HILOG_INFO(LOG_CORE, fmt, ##__VA_ARGS__)
49a34a8711Sopenharmony_ci#define RPC_LOG_WARN(fmt, ...)  HILOG_WARN(LOG_CORE, fmt, ##__VA_ARGS__)
50a34a8711Sopenharmony_ci#define RPC_LOG_ERROR(fmt, ...) HILOG_ERROR(LOG_CORE, fmt, ##__VA_ARGS__)
51a34a8711Sopenharmony_ci#endif
52a34a8711Sopenharmony_ci#else
53a34a8711Sopenharmony_cienum {
54a34a8711Sopenharmony_ci    RPC_LOG_LEVEL_DEBUG = 0,
55a34a8711Sopenharmony_ci    RPC_LOG_LEVEL_INFO,
56a34a8711Sopenharmony_ci    RPC_LOG_LEVEL_WARNING,
57a34a8711Sopenharmony_ci    RPC_LOG_LEVEL_ERROR
58a34a8711Sopenharmony_ci};
59a34a8711Sopenharmony_ci
60a34a8711Sopenharmony_ci#define RPC_LOG_LEVEL RPC_LOG_LEVEL_INFO
61a34a8711Sopenharmony_ci
62a34a8711Sopenharmony_ci#define LOG_DBG(fmt, ...) do { \
63a34a8711Sopenharmony_ci    if (RPC_LOG_LEVEL_DEBUG >= RPC_LOG_LEVEL) { \
64a34a8711Sopenharmony_ci        printf("DEBUG: " fmt "\n", ##__VA_ARGS__); \
65a34a8711Sopenharmony_ci    } \
66a34a8711Sopenharmony_ci} while (0)
67a34a8711Sopenharmony_ci
68a34a8711Sopenharmony_ci#define LOG_INFO(fmt, ...) do { \
69a34a8711Sopenharmony_ci    if (RPC_LOG_LEVEL_INFO >= RPC_LOG_LEVEL) { \
70a34a8711Sopenharmony_ci        printf("INFO: " fmt "\n", ##__VA_ARGS__); \
71a34a8711Sopenharmony_ci    } \
72a34a8711Sopenharmony_ci} while (0)
73a34a8711Sopenharmony_ci
74a34a8711Sopenharmony_ci#define LOG_WARN(fmt, ...) do { \
75a34a8711Sopenharmony_ci    if (RPC_LOG_LEVEL_WARNING >= RPC_LOG_LEVEL) { \
76a34a8711Sopenharmony_ci        printf("WARN: " fmt "\n", ##__VA_ARGS__); \
77a34a8711Sopenharmony_ci    } \
78a34a8711Sopenharmony_ci} while (0)
79a34a8711Sopenharmony_ci
80a34a8711Sopenharmony_ci#define LOG_ERR(fmt, ...) do { \
81a34a8711Sopenharmony_ci    if (RPC_LOG_LEVEL_ERROR >= RPC_LOG_LEVEL) { \
82a34a8711Sopenharmony_ci        printf("ERROR: " fmt "\n", ##__VA_ARGS__); \
83a34a8711Sopenharmony_ci    } \
84a34a8711Sopenharmony_ci} while (0)
85a34a8711Sopenharmony_ci#endif
86a34a8711Sopenharmony_ci
87a34a8711Sopenharmony_ci#if defined(__LITEOS_M__)
88a34a8711Sopenharmony_ci#define RPC_HILOG_ID HILOG_MODULE_SOFTBUS
89a34a8711Sopenharmony_ci#else
90a34a8711Sopenharmony_ci#define RPC_HILOG_ID LOG_CORE
91a34a8711Sopenharmony_ci#endif
92a34a8711Sopenharmony_ci
93a34a8711Sopenharmony_citypedef enum {
94a34a8711Sopenharmony_ci    RPC_LOG_DBG,
95a34a8711Sopenharmony_ci    RPC_LOG_INFO,
96a34a8711Sopenharmony_ci    RPC_LOG_WARN,
97a34a8711Sopenharmony_ci    RPC_LOG_ERROR,
98a34a8711Sopenharmony_ci    RPC_LOG_LEVEL_MAX,
99a34a8711Sopenharmony_ci} RpcLogLevel;
100a34a8711Sopenharmony_ci
101a34a8711Sopenharmony_citypedef enum {
102a34a8711Sopenharmony_ci    RPC_LOG_IPC,
103a34a8711Sopenharmony_ci    RPC_LOG_RPC,
104a34a8711Sopenharmony_ci    RPC_LOG_SER,
105a34a8711Sopenharmony_ci    RPC_LOG_MODULE_MAX,
106a34a8711Sopenharmony_ci} RpcLogModule;
107a34a8711Sopenharmony_ci
108a34a8711Sopenharmony_civoid RpcLog(RpcLogModule module, RpcLogLevel level, const char *fmt, ...);
109a34a8711Sopenharmony_ci
110a34a8711Sopenharmony_ci#ifdef __cplusplus
111a34a8711Sopenharmony_ci}
112a34a8711Sopenharmony_ci#endif /* __cplusplus */
113a34a8711Sopenharmony_ci#endif /* OHOS_IPC_RPC_LOG_H */