monado/src/xrt/auxiliary/util/u_debug.h
2022-07-27 10:49:29 +00:00

125 lines
7.3 KiB
C

// Copyright 2019, Collabora, Ltd.
// SPDX-License-Identifier: BSL-1.0
/*!
* @file
* @brief Small debug helpers.
* @author Jakob Bornecrantz <jakob@collabora.com>
* @ingroup aux_util
*
* Debug get option helpers heavily inspired from mesa ones.
*/
#pragma once
#include "xrt/xrt_compiler.h"
#include "util/u_logging.h"
#ifdef __cplusplus
extern "C" {
#endif
enum debug_tristate_option
{
DEBUG_TRISTATE_OFF,
DEBUG_TRISTATE_AUTO,
DEBUG_TRISTATE_ON
};
const char *
debug_get_option(const char *name, const char *_default);
bool
debug_string_to_bool(const char *string);
enum debug_tristate_option
debug_get_tristate_option(const char *name);
bool
debug_get_bool_option(const char *name, bool _default);
long
debug_get_num_option(const char *name, long _default);
float
debug_get_float_option(const char *name, float _default);
enum u_logging_level
debug_get_log_option(const char *name, enum u_logging_level _default);
#define DEBUG_GET_ONCE_OPTION(suffix, name, _default) \
static const char *debug_get_option_##suffix() \
{ \
static bool gotten = false; \
static const char *stored; \
if (!gotten) { \
gotten = true; \
stored = debug_get_option(name, _default); \
} \
return stored; \
}
#define DEBUG_GET_ONCE_TRISTATE_OPTION(suffix, name) \
static enum debug_tristate_option debug_get_tristate_option_##suffix() \
{ \
static bool gotten = false; \
static enum debug_tristate_option stored; \
if (!gotten) { \
gotten = true; \
stored = debug_get_tristate_option(name); \
} \
return stored; \
}
#define DEBUG_GET_ONCE_BOOL_OPTION(suffix, name, _default) \
static bool debug_get_bool_option_##suffix() \
{ \
static bool gotten = false; \
static bool stored; \
if (!gotten) { \
gotten = true; \
stored = debug_get_bool_option(name, _default); \
} \
return stored; \
}
#define DEBUG_GET_ONCE_NUM_OPTION(suffix, name, _default) \
static long debug_get_num_option_##suffix() \
{ \
static long gotten = false; \
static long stored; \
if (!gotten) { \
gotten = true; \
stored = debug_get_num_option(name, _default); \
} \
return stored; \
}
#define DEBUG_GET_ONCE_FLOAT_OPTION(suffix, name, _default) \
static float debug_get_float_option_##suffix() \
{ \
static long gotten = false; \
static float stored; \
if (!gotten) { \
gotten = true; \
stored = debug_get_float_option(name, _default); \
} \
return stored; \
}
#define DEBUG_GET_ONCE_LOG_OPTION(suffix, name, _default) \
static enum u_logging_level debug_get_log_option_##suffix() \
{ \
static long gotten = false; \
static enum u_logging_level stored; \
if (!gotten) { \
gotten = true; \
stored = debug_get_log_option(name, _default); \
} \
return stored; \
}
#ifdef __cplusplus
}
#endif