2019-08-31 11:46:25 +00:00
|
|
|
// Copyright 2019, Collabora, Ltd.
|
|
|
|
// SPDX-License-Identifier: BSL-1.0
|
|
|
|
/*!
|
|
|
|
* @file
|
|
|
|
* @brief Variable tracking code.
|
|
|
|
* @author Jakob Bornecrantz <jakob@collabora.com>
|
|
|
|
* @ingroup aux_util
|
|
|
|
*/
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include "xrt/xrt_defines.h"
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
2019-09-21 17:17:38 +00:00
|
|
|
struct xrt_frame_sink;
|
|
|
|
|
2019-08-31 11:46:25 +00:00
|
|
|
/*!
|
|
|
|
* @ingroup aux_util
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* What kind of variable is this tracking.
|
|
|
|
*/
|
|
|
|
enum u_var_kind
|
|
|
|
{
|
|
|
|
U_VAR_KIND_BOOL,
|
|
|
|
U_VAR_KIND_RGB_U8,
|
|
|
|
U_VAR_KIND_RGB_F32,
|
2019-09-06 17:10:08 +00:00
|
|
|
U_VAR_KIND_U8,
|
|
|
|
U_VAR_KIND_I32,
|
|
|
|
U_VAR_KIND_F32,
|
|
|
|
U_VAR_KIND_VEC3_I32,
|
|
|
|
U_VAR_KIND_VEC3_F32,
|
2019-09-21 17:17:38 +00:00
|
|
|
U_VAR_KIND_SINK,
|
2019-09-06 17:10:08 +00:00
|
|
|
U_VAR_KIND_RO_TEXT,
|
|
|
|
U_VAR_KIND_RO_I32,
|
|
|
|
U_VAR_KIND_RO_F32,
|
|
|
|
U_VAR_KIND_RO_VEC3_I32,
|
|
|
|
U_VAR_KIND_RO_VEC3_F32,
|
2019-09-18 00:27:22 +00:00
|
|
|
U_VAR_KIND_RO_QUAT_F32,
|
2019-09-07 13:31:06 +00:00
|
|
|
U_VAR_KIND_GUI_HEADER,
|
2019-08-31 11:46:25 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* Callback for entering and leaving root nodes.
|
|
|
|
*/
|
|
|
|
typedef void (*u_var_root_cb)(const char *, void *);
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* Callback on each variable a root node has.
|
|
|
|
*/
|
|
|
|
typedef void (*u_var_elm_cb)(const char *, enum u_var_kind, void *, void *);
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* Add a named root object, the u_var subsystem is completely none-invasive
|
|
|
|
* to the object it's tracking. The root pointer is used as a entry into a
|
|
|
|
* hashmap of hidden objecrs. When not active all calls are stubs and have no
|
|
|
|
* side-effects.
|
|
|
|
*
|
|
|
|
* This is intended only for debugging and is turned off by default, as this all
|
|
|
|
* very very unsafe. It is just pointers straight into objects, completely
|
|
|
|
* ignores ownership or any safe practices.
|
|
|
|
*
|
|
|
|
* If it's stupid, but it works, it ain't stupid.
|
|
|
|
*
|
|
|
|
* ```c
|
|
|
|
* // On create
|
2019-11-11 23:24:06 +00:00
|
|
|
* u_var_add_root((void*)psmv, "PS Move Controller", true);
|
2019-08-31 11:46:25 +00:00
|
|
|
* u_var_add_rgb_u8((void*)psmv, &psmv->led_color, "LED");
|
|
|
|
* u_var_add_bool((void*)psmv, &psmv->print_spew, "Spew");
|
|
|
|
* u_var_add_bool((void*)psmv, &psmv->print_debug, "Debug");
|
|
|
|
*
|
|
|
|
* // On destroy, only need to destroy the root object.
|
|
|
|
* u_var_remove_root((void*)psmv);
|
|
|
|
* ```
|
|
|
|
*
|
|
|
|
* @ingroup aux_util
|
|
|
|
*/
|
|
|
|
void
|
2019-11-11 23:24:06 +00:00
|
|
|
u_var_add_root(void *root, const char *c_name, bool number);
|
2019-08-31 11:46:25 +00:00
|
|
|
|
|
|
|
/*!
|
|
|
|
* Remove the root node.
|
|
|
|
*/
|
|
|
|
void
|
2019-11-11 23:24:06 +00:00
|
|
|
u_var_remove_root(void *root);
|
2019-08-31 11:46:25 +00:00
|
|
|
|
|
|
|
/*!
|
|
|
|
* Visit all root nodes and their variables.
|
|
|
|
*/
|
|
|
|
void
|
|
|
|
u_var_visit(u_var_root_cb enter,
|
|
|
|
u_var_root_cb exit,
|
|
|
|
u_var_elm_cb e_cb,
|
|
|
|
void *priv);
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* This forces the variable tracking code to on, it is disabled by default.
|
|
|
|
*/
|
|
|
|
void
|
|
|
|
u_var_force_on(void);
|
|
|
|
|
2019-09-06 17:10:08 +00:00
|
|
|
#define ADD_FUNC(SUFFIX, TYPE, ENUM) \
|
|
|
|
void u_var_add_##SUFFIX(void *, TYPE *, const char *)
|
|
|
|
|
|
|
|
ADD_FUNC(bool, bool, BOOL);
|
|
|
|
ADD_FUNC(rgb_u8, struct xrt_colour_rgb_u8, RGB_U8);
|
|
|
|
ADD_FUNC(rgb_f32, struct xrt_colour_rgb_f32, RGB_F32);
|
|
|
|
ADD_FUNC(u8, uint8_t, U8);
|
|
|
|
ADD_FUNC(i32, int32_t, I32);
|
|
|
|
ADD_FUNC(f32, float, F32);
|
|
|
|
ADD_FUNC(vec3_i32, struct xrt_vec3_i32, VEC3_I32);
|
|
|
|
ADD_FUNC(vec3_f32, struct xrt_vec3, VEC3_F32);
|
2019-09-21 17:17:38 +00:00
|
|
|
ADD_FUNC(sink, struct xrt_frame_sink *, SINK);
|
2019-09-06 17:10:08 +00:00
|
|
|
ADD_FUNC(ro_text, const char, RO_TEXT);
|
|
|
|
ADD_FUNC(ro_i32, int32_t, RO_I32);
|
|
|
|
ADD_FUNC(ro_f32, float, RO_F32);
|
|
|
|
ADD_FUNC(ro_vec3_i32, struct xrt_vec3_i32, RO_VEC3_I32);
|
|
|
|
ADD_FUNC(ro_vec3_f32, struct xrt_vec3, RO_VEC3_F32);
|
2019-09-18 00:27:22 +00:00
|
|
|
ADD_FUNC(ro_quat_f32, struct xrt_quat, RO_QUAT_F32);
|
2019-09-07 13:31:06 +00:00
|
|
|
ADD_FUNC(gui_header, bool, GUI_HEADER);
|
2019-09-06 17:10:08 +00:00
|
|
|
|
|
|
|
#undef ADD_FUNC
|
2019-08-31 11:46:25 +00:00
|
|
|
|
|
|
|
/*!
|
|
|
|
* @}
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|