2022-05-07 12:20:32 +00:00
|
|
|
// Copyright 2022, Collabora, Ltd.
|
|
|
|
// SPDX-License-Identifier: BSL-1.0
|
|
|
|
/*!
|
|
|
|
* @file
|
|
|
|
* @brief Helpers for system objects like @ref xrt_system_devices.
|
|
|
|
* @author Jakob Bornecrantz <jakob@collabora.com>
|
|
|
|
* @ingroup aux_util
|
|
|
|
*/
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include "xrt/xrt_results.h"
|
|
|
|
#include "xrt/xrt_frame.h"
|
|
|
|
#include "xrt/xrt_system.h"
|
|
|
|
#include "xrt/xrt_instance.h"
|
2022-05-14 13:43:20 +00:00
|
|
|
#include "xrt/xrt_tracking.h"
|
2022-05-07 12:20:32 +00:00
|
|
|
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* Helper struct to manage devices by implementing the @ref xrt_system_devices.
|
|
|
|
*
|
|
|
|
* The default destroy function that is set by @ref u_system_devices_allocate
|
|
|
|
* will first destroy all of the @ref xrt_device and then destroy all nodes
|
|
|
|
* in the @ref xrt_frame_context.
|
|
|
|
*
|
|
|
|
* @ingroup aux_util
|
|
|
|
*/
|
|
|
|
struct u_system_devices
|
|
|
|
{
|
|
|
|
struct xrt_system_devices base;
|
|
|
|
|
2022-05-14 13:43:20 +00:00
|
|
|
//! Optional frame context for visual tracking.
|
2022-05-07 12:20:32 +00:00
|
|
|
struct xrt_frame_context xfctx;
|
2022-05-14 13:43:20 +00:00
|
|
|
|
|
|
|
//! Optional shared tracking origin.
|
|
|
|
struct xrt_tracking_origin origin;
|
2022-05-07 12:20:32 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* Small inline helper to cast from @ref xrt_system_devices.
|
|
|
|
*
|
|
|
|
* @ingroup aux_util
|
|
|
|
*/
|
|
|
|
static inline struct u_system_devices *
|
|
|
|
u_system_devices(struct xrt_system_devices *xsysd)
|
|
|
|
{
|
|
|
|
return (struct u_system_devices *)xsysd;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* Allocates a empty @ref u_system_devices to be filled in by the caller, only
|
|
|
|
* the destroy function is filled in.
|
|
|
|
*
|
|
|
|
* @ingroup aux_util
|
|
|
|
*/
|
|
|
|
struct u_system_devices *
|
|
|
|
u_system_devices_allocate(void);
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* Takes a @ref xrt_instance, gets the prober from it and then uses the prober
|
|
|
|
* to allocate a filled in @ref u_system_devices.
|
|
|
|
*
|
|
|
|
* @ingroup aux_util
|
|
|
|
*/
|
|
|
|
xrt_result_t
|
|
|
|
u_system_devices_create_from_prober(struct xrt_instance *xinst, struct xrt_system_devices **out_xsysd);
|
|
|
|
|
2022-06-22 15:32:36 +00:00
|
|
|
/*!
|
|
|
|
* Helper function.
|
|
|
|
*
|
|
|
|
* Looks through @ref u_system_devices's devices and returns the first device that supports hand tracking and the
|
|
|
|
* supplied input name.
|
|
|
|
*
|
|
|
|
* Used by target_builder_lighthouse to find Knuckles controllers in the list of devices returned.
|
|
|
|
*
|
|
|
|
* @ingroup aux_util
|
|
|
|
*/
|
|
|
|
struct xrt_device *
|
|
|
|
u_system_devices_get_ht_device(struct u_system_devices *usysd, enum xrt_input_name name);
|
|
|
|
|
2022-05-07 12:20:32 +00:00
|
|
|
/*!
|
|
|
|
* Destroy an u_system_devices_allocate and owned devices - helper function.
|
|
|
|
*
|
|
|
|
* @param[in,out] usysd_ptr A pointer to the u_system_devices_allocate struct pointer.
|
|
|
|
*
|
|
|
|
* Will destroy the system devices if *usysd_ptr is not NULL. Will then set *usysd_ptr to NULL.
|
|
|
|
*
|
|
|
|
* @public @memberof u_system_devices_allocate
|
|
|
|
*/
|
|
|
|
static inline void
|
|
|
|
u_system_devices_destroy(struct u_system_devices **usysd_ptr)
|
|
|
|
{
|
|
|
|
struct u_system_devices *usysd = *usysd_ptr;
|
|
|
|
if (usysd == NULL) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
*usysd_ptr = NULL;
|
|
|
|
usysd->base.destroy(&usysd->base);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|