mirror of
https://gitlab.freedesktop.org/monado/monado.git
synced 2025-01-12 09:55:33 +00:00
117 lines
3.6 KiB
C
117 lines
3.6 KiB
C
|
// Copyright 2020, Collabora, Ltd.
|
||
|
// SPDX-License-Identifier: BSL-1.0
|
||
|
/*!
|
||
|
* @file
|
||
|
* @brief Tiny JSON wrapper around cJSON header.
|
||
|
* @author Jakob Bornecrantz <jakob@collabora.com>
|
||
|
* @ingroup aux_util aux_log
|
||
|
*/
|
||
|
|
||
|
|
||
|
#pragma once
|
||
|
|
||
|
#include "xrt/xrt_compiler.h"
|
||
|
|
||
|
|
||
|
#ifdef __cplusplus
|
||
|
extern "C" {
|
||
|
#endif
|
||
|
|
||
|
|
||
|
struct xrt_device;
|
||
|
|
||
|
|
||
|
/*!
|
||
|
* @defgroup aux_log Logging functions.
|
||
|
*/
|
||
|
|
||
|
/*!
|
||
|
* @ingroup aux_util aux_log
|
||
|
* @{
|
||
|
*/
|
||
|
|
||
|
/*!
|
||
|
* 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
|