monado/src/xrt/auxiliary/util/u_logging.h

118 lines
3.6 KiB
C
Raw Normal View History

2020-07-03 13:27:39 +00:00
// Copyright 2020, Collabora, Ltd.
// SPDX-License-Identifier: BSL-1.0
/*!
* @file
2020-07-07 19:14:07 +00:00
* @brief Basic logging functionality.
2020-07-03 13:27:39 +00:00
* @author Jakob Bornecrantz <jakob@collabora.com>
2020-07-07 19:14:07 +00:00
* @ingroup aux_log
2020-07-03 13:27:39 +00:00
*/
#pragma once
#include "xrt/xrt_compiler.h"
#ifdef __cplusplus
extern "C" {
#endif
struct xrt_device;
/*!
* @defgroup aux_log Logging functions.
2020-07-07 19:14:07 +00:00
* @ingroup aux_util
2020-07-03 13:27:39 +00:00
*/
/*!
2020-07-07 19:14:07 +00:00
* @ingroup aux_log
2020-07-03 13:27:39 +00:00
* @{
*/
/*!
* For places where you really just want printf, prints a new-line.
*/
#define U_LOG_RAW(...) \
do { \
u_log(__FILE__, __LINE__, __func__, U_LOGGING_RAW, \
__VA_ARGS__); \
} while (false)
#define U_LOG(level, ...) \
do { \
u_log(__FILE__, __LINE__, __func__, level, __VA_ARGS__); \
} while (false)
#define U_LOG_XDEV(level, xdev, ...) \
do { \
u_log_xdev(__FILE__, __LINE__, __func__, level, xdev, \
__VA_ARGS__); \
} while (false)
#define U_LOG_XDEV_IFL(level, cond_level, xdev, ...) \
do { \
if (cond_level <= level) { \
u_log_xdev(__FILE__, __LINE__, __func__, level, xdev, \
__VA_ARGS__); \
} \
} while (false)
// clang-format off
#define U_LOG_T(...) U_LOG(U_LOGGING_TRACE, __VA_ARGS__)
#define U_LOG_D(...) U_LOG(U_LOGGING_DEBUG, __VA_ARGS__)
#define U_LOG_I(...) U_LOG(U_LOGGING_INFO, __VA_ARGS__)
#define U_LOG_W(...) U_LOG(U_LOGGING_WARN, __VA_ARGS__)
#define U_LOG_E(...) U_LOG(U_LOGGING_ERROR, __VA_ARGS__)
#define U_LOG_XDEV_IFL_T(xdev, cond_level, ...) U_LOG_XDEV_IFL(U_LOGGING_TRACE, cond_level, xdev, __VA_ARGS__)
#define U_LOG_XDEV_IFL_D(xdev, cond_level, ...) U_LOG_XDEV_IFL(U_LOGGING_DEBUG, cond_level, xdev, __VA_ARGS__)
#define U_LOG_XDEV_IFL_I(xdev, cond_level, ...) U_LOG_XDEV_IFL(U_LOGGING_INFO, cond_level, xdev, __VA_ARGS__)
#define U_LOG_XDEV_IFL_W(xdev, cond_level, ...) U_LOG_XDEV_IFL(U_LOGGING_WARN, cond_level, xdev, __VA_ARGS__)
#define U_LOG_XDEV_IFL_E(xdev, cond_level, ...) U_LOG_XDEV_IFL(U_LOGGING_ERROR, cond_level, xdev, __VA_ARGS__)
#define U_LOG_XDEV_T(xdev, ...) U_LOG_XDEV(U_LOGGING_TRACE, xdev, __VA_ARGS__)
#define U_LOG_XDEV_D(xdev, ...) U_LOG_XDEV(U_LOGGING_DEBUG, xdev, __VA_ARGS__)
#define U_LOG_XDEV_I(xdev, ...) U_LOG_XDEV(U_LOGGING_INFO, xdev, __VA_ARGS__)
#define U_LOG_XDEV_W(xdev, ...) U_LOG_XDEV(U_LOGGING_WARN, xdev, __VA_ARGS__)
#define U_LOG_XDEV_E(xdev, ...) U_LOG_XDEV(U_LOGGING_ERROR, xdev, __VA_ARGS__)
// clang-format on
enum u_logging_level
{
U_LOGGING_TRACE,
U_LOGGING_DEBUG,
U_LOGGING_INFO,
U_LOGGING_WARN,
U_LOGGING_ERROR,
U_LOGGING_RAW, //!< Special level for raw printing, prints a new-line.
};
void
u_log(const char *file,
int line,
const char *func,
enum u_logging_level level,
const char *format,
...) XRT_PRINTF_FORMAT(5, 6);
void
u_log_xdev(const char *file,
int line,
const char *func,
enum u_logging_level level,
struct xrt_device *xdev,
const char *format,
...) XRT_PRINTF_FORMAT(6, 7);
/*!
* @}
*/
#ifdef __cplusplus
}
#endif