/* * Copyright (c) 2021-2022 Huawei Device Co., Ltd. * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #ifndef BEGET_EXT_API_H #define BEGET_EXT_API_H #include #include #include #ifdef __cplusplus #if __cplusplus extern "C" { #endif #endif #ifndef INIT_LOG_PATH #define INIT_LOG_PATH "/data/init_agent/" #endif #if defined(__GNUC__) && (__GNUC__ >= 4) #define INIT_PUBLIC_API __attribute__((visibility ("default"))) #define INIT_INNER_API __attribute__((visibility ("default"))) #define INIT_LOCAL_API __attribute__((visibility("hidden"))) #else #define INIT_PUBLIC_API #define INIT_INNER_API #define INIT_LOCAL_API #endif typedef enum InitLogLevel { INIT_DEBUG = 0, INIT_INFO, INIT_WARN, INIT_ERROR, INIT_FATAL } InitLogLevel; typedef void (*InitCommLog)(InitLogLevel logLevel, uint32_t domain, const char *tag, const char *fmt, va_list vargs); #define FILE_NAME (strrchr((__FILE__), '/') ? strrchr((__FILE__), '/') + 1 : (__FILE__)) INIT_PUBLIC_API void StartupLog(InitLogLevel logLevel, uint32_t domain, const char *tag, const char *fmt, ...); INIT_PUBLIC_API void EnableInitLog(InitLogLevel level); INIT_PUBLIC_API void SetInitCommLog(InitCommLog logFunc); #define STARTUP_LOGV(domain, tag, fmt, ...) \ StartupLog(INIT_DEBUG, domain, tag, "[%s:%d]" fmt, (FILE_NAME), (__LINE__), ##__VA_ARGS__) #define STARTUP_LOGI(domain, tag, fmt, ...) \ StartupLog(INIT_INFO, domain, tag, "[%s:%d]" fmt, (FILE_NAME), (__LINE__), ##__VA_ARGS__) #define STARTUP_LOGW(domain, tag, fmt, ...) \ StartupLog(INIT_WARN, domain, tag, "[%s:%d]" fmt, (FILE_NAME), (__LINE__), ##__VA_ARGS__) #define STARTUP_LOGE(domain, tag, fmt, ...) \ StartupLog(INIT_ERROR, domain, tag, "[%s:%d]" fmt, (FILE_NAME), (__LINE__), ##__VA_ARGS__) #define STARTUP_LOGF(domain, tag, fmt, ...) \ StartupLog(INIT_FATAL, domain, tag, "[%s:%d]" fmt, (FILE_NAME), (__LINE__), ##__VA_ARGS__) #define BASE_DOMAIN 0xA000 #ifndef BEGET_DOMAIN #define BEGET_DOMAIN (BASE_DOMAIN + 0xb) #endif #define BEGET_LABEL "BEGET" #define BEGET_LOGI(fmt, ...) STARTUP_LOGI(BEGET_DOMAIN, BEGET_LABEL, fmt, ##__VA_ARGS__) #define BEGET_LOGE(fmt, ...) STARTUP_LOGE(BEGET_DOMAIN, BEGET_LABEL, fmt, ##__VA_ARGS__) #define BEGET_LOGV(fmt, ...) STARTUP_LOGV(BEGET_DOMAIN, BEGET_LABEL, fmt, ##__VA_ARGS__) #define BEGET_LOGW(fmt, ...) STARTUP_LOGW(BEGET_DOMAIN, BEGET_LABEL, fmt, ##__VA_ARGS__) #define InitLogPrint(outFileName, logLevel, kLevel, fmt, ...) \ StartupLog(logLevel, BEGET_DOMAIN, kLevel, fmt, ##__VA_ARGS__) #define BEGET_ERROR_CHECK(ret, statement, format, ...) \ if (!(ret)) { \ BEGET_LOGE(format, ##__VA_ARGS__); \ statement; \ } \ #define BEGET_INFO_CHECK(ret, statement, format, ...) \ if (!(ret)) { \ BEGET_LOGI(format, ##__VA_ARGS__); \ statement; \ } \ #define BEGET_WARNING_CHECK(ret, statement, format, ...) \ if (!(ret)) { \ BEGET_LOGW(format, ##__VA_ARGS__); \ statement; \ } \ #define BEGET_CHECK(ret, statement) \ if (!(ret)) { \ statement; \ } \ #define BEGET_CHECK_RETURN_VALUE(ret, result) \ do { \ if (!(ret)) { \ return result; \ } \ } while (0) #define BEGET_CHECK_ONLY_RETURN(ret) \ do { \ if (!(ret)) { \ return; \ } \ } while (0) #define BEGET_CHECK_ONLY_ELOG(ret, format, ...) \ do { \ if (!(ret)) { \ BEGET_LOGE(format, ##__VA_ARGS__); \ } \ } while (0) #ifdef __cplusplus #if __cplusplus } #endif #endif #endif