1094332d3Sopenharmony_ci/*
2094332d3Sopenharmony_ci * Copyright (c) 2021 Huawei Device Co., Ltd.
3094332d3Sopenharmony_ci * Licensed under the Apache License, Version 2.0 (the "License");
4094332d3Sopenharmony_ci * you may not use this file except in compliance with the License.
5094332d3Sopenharmony_ci * You may obtain a copy of the License at
6094332d3Sopenharmony_ci *
7094332d3Sopenharmony_ci *     http://www.apache.org/licenses/LICENSE-2.0
8094332d3Sopenharmony_ci *
9094332d3Sopenharmony_ci * Unless required by applicable law or agreed to in writing, software
10094332d3Sopenharmony_ci * distributed under the License is distributed on an "AS IS" BASIS,
11094332d3Sopenharmony_ci * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12094332d3Sopenharmony_ci * See the License for the specific language governing permissions and
13094332d3Sopenharmony_ci * limitations under the License.
14094332d3Sopenharmony_ci */
15094332d3Sopenharmony_ci
16094332d3Sopenharmony_ci#ifndef DISP_COMMON_H
17094332d3Sopenharmony_ci#define DISP_COMMON_H
18094332d3Sopenharmony_ci#include <string.h>
19094332d3Sopenharmony_ci#include <stdint.h>
20094332d3Sopenharmony_ci#include "hilog/log.h"
21094332d3Sopenharmony_ci#include "stdio.h"
22094332d3Sopenharmony_ci#ifdef HDF_LOG_TAG
23094332d3Sopenharmony_ci#undef HDF_LOG_TAG
24094332d3Sopenharmony_ci#endif
25094332d3Sopenharmony_ci
26094332d3Sopenharmony_ci#if defined(__cplusplus)
27094332d3Sopenharmony_ciextern "C" {
28094332d3Sopenharmony_ci#endif
29094332d3Sopenharmony_ci
30094332d3Sopenharmony_ci#undef LOG_TAG
31094332d3Sopenharmony_ci#undef LOG_DOMAIN
32094332d3Sopenharmony_ci#define LOG_TAG "DISP"
33094332d3Sopenharmony_ci#define LOG_DOMAIN 0xD001400
34094332d3Sopenharmony_ci
35094332d3Sopenharmony_ci#ifndef DISPLAY_UNUSED
36094332d3Sopenharmony_ci#define DISPLAY_UNUSED(x) (void)x
37094332d3Sopenharmony_ci#endif
38094332d3Sopenharmony_ci
39094332d3Sopenharmony_ci#define DISPLAY_FILENAME (strrchr(__FILE__, '/') ? (strrchr(__FILE__, '/') + 1) : __FILE__)
40094332d3Sopenharmony_ci
41094332d3Sopenharmony_ci#ifndef DISPLAY_DEBUG_ENABLE
42094332d3Sopenharmony_ci#define DISPLAY_DEBUG_ENABLE 0
43094332d3Sopenharmony_ci#endif
44094332d3Sopenharmony_ci
45094332d3Sopenharmony_ci#ifndef DISPLAY_LOGD
46094332d3Sopenharmony_ci#define DISPLAY_LOGD(format, ...)                                                                                     \
47094332d3Sopenharmony_ci    do {                                                                                                              \
48094332d3Sopenharmony_ci        if (DISPLAY_DEBUG_ENABLE) {                                                                                   \
49094332d3Sopenharmony_ci            HILOG_DEBUG(LOG_CORE, "[%{public}s@%{public}s:%{public}d] " format "\n",                                  \
50094332d3Sopenharmony_ci                __FUNCTION__, DISPLAY_FILENAME, __LINE__,                                                             \
51094332d3Sopenharmony_ci                ##__VA_ARGS__);                                                                                       \
52094332d3Sopenharmony_ci        }                                                                                                             \
53094332d3Sopenharmony_ci    } while (0)
54094332d3Sopenharmony_ci#endif
55094332d3Sopenharmony_ci
56094332d3Sopenharmony_ci#ifndef DISPLAY_LOGI
57094332d3Sopenharmony_ci#define DISPLAY_LOGI(format, ...)                                                                                     \
58094332d3Sopenharmony_ci    do {                                                                                                              \
59094332d3Sopenharmony_ci        HILOG_INFO(LOG_CORE, "[%{public}s@%{public}s:%{public}d] "                                                    \
60094332d3Sopenharmony_ci            format "\n", __FUNCTION__, DISPLAY_FILENAME, __LINE__,                                                    \
61094332d3Sopenharmony_ci            ##__VA_ARGS__);                                                                                           \
62094332d3Sopenharmony_ci    } while (0)
63094332d3Sopenharmony_ci#endif
64094332d3Sopenharmony_ci
65094332d3Sopenharmony_ci#ifndef DISPLAY_LOGW
66094332d3Sopenharmony_ci#define DISPLAY_LOGW(format, ...)                                                                                     \
67094332d3Sopenharmony_ci    do {                                                                                                              \
68094332d3Sopenharmony_ci        HILOG_WARN(LOG_CORE, "[%{public}s@%{public}s:%{public}d] "                                                    \
69094332d3Sopenharmony_ci            format "\n", __FUNCTION__, DISPLAY_FILENAME, __LINE__,                                                    \
70094332d3Sopenharmony_ci            ##__VA_ARGS__);                                                                                           \
71094332d3Sopenharmony_ci    } while (0)
72094332d3Sopenharmony_ci#endif
73094332d3Sopenharmony_ci
74094332d3Sopenharmony_ci#ifndef DISPLAY_LOGE
75094332d3Sopenharmony_ci#define DISPLAY_LOGE(format, ...)                                 \
76094332d3Sopenharmony_ci    do {                                                          \
77094332d3Sopenharmony_ci        HILOG_ERROR(LOG_CORE,                                     \
78094332d3Sopenharmony_ci            "\033[0;32;31m"                                       \
79094332d3Sopenharmony_ci            "[%{public}s@%{public}s:%{public}d] " format "\033[m" \
80094332d3Sopenharmony_ci            "\n",                                                 \
81094332d3Sopenharmony_ci            __FUNCTION__, DISPLAY_FILENAME, __LINE__, ##__VA_ARGS__); \
82094332d3Sopenharmony_ci    } while (0)
83094332d3Sopenharmony_ci#endif
84094332d3Sopenharmony_ci
85094332d3Sopenharmony_ci#ifndef CHECK_NULLPOINTER_RETURN_VALUE
86094332d3Sopenharmony_ci#define CHECK_NULLPOINTER_RETURN_VALUE(pointer, ret)          \
87094332d3Sopenharmony_ci    do {                                                      \
88094332d3Sopenharmony_ci        if ((pointer) == NULL) {                              \
89094332d3Sopenharmony_ci            DISPLAY_LOGE("pointer is null and return ret\n"); \
90094332d3Sopenharmony_ci            return (ret);                                     \
91094332d3Sopenharmony_ci        }                                                     \
92094332d3Sopenharmony_ci    } while (0)
93094332d3Sopenharmony_ci#endif
94094332d3Sopenharmony_ci
95094332d3Sopenharmony_ci#ifndef CHECK_NULLPOINTER_RETURN
96094332d3Sopenharmony_ci#define CHECK_NULLPOINTER_RETURN(pointer)                 \
97094332d3Sopenharmony_ci    do {                                                  \
98094332d3Sopenharmony_ci        if ((pointer) == NULL) {                          \
99094332d3Sopenharmony_ci            DISPLAY_LOGE("pointer is null and return\n"); \
100094332d3Sopenharmony_ci            return;                                       \
101094332d3Sopenharmony_ci        }                                                 \
102094332d3Sopenharmony_ci    } while (0)
103094332d3Sopenharmony_ci#endif
104094332d3Sopenharmony_ci
105094332d3Sopenharmony_ci#ifndef DISPLAY_CHK_RETURN
106094332d3Sopenharmony_ci#define DISPLAY_CHK_RETURN(val, ret, ...) \
107094332d3Sopenharmony_ci    do {                                  \
108094332d3Sopenharmony_ci        if (val) {                        \
109094332d3Sopenharmony_ci            __VA_ARGS__;                  \
110094332d3Sopenharmony_ci            return (ret);                 \
111094332d3Sopenharmony_ci        }                                 \
112094332d3Sopenharmony_ci    } while (0)
113094332d3Sopenharmony_ci#endif
114094332d3Sopenharmony_ci
115094332d3Sopenharmony_ci#ifndef DISPLAY_CHK_RETURN_NOT_VALUE
116094332d3Sopenharmony_ci#define DISPLAY_CHK_RETURN_NOT_VALUE(val, ...) \
117094332d3Sopenharmony_ci    do {                                            \
118094332d3Sopenharmony_ci        if (val) {                                  \
119094332d3Sopenharmony_ci            __VA_ARGS__;                            \
120094332d3Sopenharmony_ci            return;                                 \
121094332d3Sopenharmony_ci        }                                           \
122094332d3Sopenharmony_ci    } while (0)
123094332d3Sopenharmony_ci#endif
124094332d3Sopenharmony_ci
125094332d3Sopenharmony_ci#ifdef __cplusplus
126094332d3Sopenharmony_ci}
127094332d3Sopenharmony_ci#endif
128094332d3Sopenharmony_ci
129094332d3Sopenharmony_ci#endif /* DISP_COMMON_H */
130