2019-06-03 19:12:01 +00:00
|
|
|
// Copyright 2019, Collabora, Ltd.
|
|
|
|
// SPDX-License-Identifier: BSL-1.0
|
|
|
|
/*!
|
|
|
|
* @file
|
|
|
|
* @brief Utilities for accessing members in an OpenXR structure chain.
|
|
|
|
* @author Ryan Pavlik <ryan.pavlik@collabora.com>
|
|
|
|
*/
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include <xrt/xrt_openxr_includes.h>
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* @ingroup oxr_api
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* Finds an input struct of the given type in a next-chain.
|
|
|
|
*
|
|
|
|
* Returns NULL if nothing matching is found.
|
|
|
|
*
|
|
|
|
* Prefer using OXR_GET_INPUT_FROM_CHAIN() instead, since it includes the
|
|
|
|
* casting.
|
|
|
|
*/
|
2019-09-29 10:43:45 +00:00
|
|
|
static inline XrBaseInStructure const *
|
|
|
|
oxr_find_input_in_chain(const void *ptr, XrStructureType desired)
|
2019-06-03 19:12:01 +00:00
|
|
|
{
|
|
|
|
while (ptr != NULL) {
|
2019-09-29 10:43:45 +00:00
|
|
|
XrBaseInStructure const *base = (XrBaseInStructure const *)ptr;
|
2019-06-03 19:12:01 +00:00
|
|
|
if (base->type == desired) {
|
|
|
|
return base;
|
|
|
|
}
|
|
|
|
ptr = base->next;
|
|
|
|
}
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* Finds an input struct of the given type in a next-chain and casts it as
|
|
|
|
* desired.
|
|
|
|
*
|
|
|
|
* Returns NULL if nothing matching is found.
|
|
|
|
*
|
|
|
|
* Note: There is no protection here to ensure that STRUCTURE_TYPE_ENUM (an
|
|
|
|
* XrStructureType value) and TYPE (a type name) actually match!
|
|
|
|
*/
|
2021-01-14 14:13:48 +00:00
|
|
|
#define OXR_GET_INPUT_FROM_CHAIN(PTR, STRUCTURE_TYPE_ENUM, TYPE) \
|
2019-09-29 10:43:45 +00:00
|
|
|
((TYPE const *)oxr_find_input_in_chain(PTR, STRUCTURE_TYPE_ENUM))
|
2019-06-03 19:12:01 +00:00
|
|
|
|
|
|
|
/*!
|
|
|
|
* Finds an output struct of the given type in a next-chain.
|
|
|
|
*
|
|
|
|
* Returns NULL if nothing matching is found.
|
|
|
|
*
|
|
|
|
* Prefer using OXR_GET_OUTPUT_FROM_CHAIN() instead, since it includes the
|
|
|
|
* casting.
|
|
|
|
*/
|
2019-09-29 10:43:45 +00:00
|
|
|
static inline XrBaseOutStructure *
|
|
|
|
oxr_find_output_in_chain(void *ptr, XrStructureType desired)
|
2019-06-03 19:12:01 +00:00
|
|
|
{
|
|
|
|
while (ptr != NULL) {
|
2019-09-29 10:43:45 +00:00
|
|
|
XrBaseOutStructure *base = (XrBaseOutStructure *)ptr;
|
2019-06-03 19:12:01 +00:00
|
|
|
if (base->type == desired) {
|
|
|
|
return base;
|
|
|
|
}
|
|
|
|
ptr = base->next;
|
|
|
|
}
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*!
|
|
|
|
* Finds an output struct of the given type in a next-chain and casts it as
|
|
|
|
* desired.
|
|
|
|
*
|
|
|
|
* Returns NULL if nothing matching is found.
|
|
|
|
*
|
|
|
|
* Note: There is no protection here to ensure that STRUCTURE_TYPE_ENUM (an
|
|
|
|
* XrStructureType value) and TYPE (a type name) actually match!
|
|
|
|
*/
|
2021-01-14 14:13:48 +00:00
|
|
|
#define OXR_GET_OUTPUT_FROM_CHAIN(PTR, STRUCTURE_TYPE_ENUM, TYPE) \
|
2019-09-29 10:43:45 +00:00
|
|
|
((TYPE *)oxr_find_output_in_chain(PTR, STRUCTURE_TYPE_ENUM))
|
2019-06-03 19:12:01 +00:00
|
|
|
|
|
|
|
/*!
|
|
|
|
* @}
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|