mirror of
https://gitlab.freedesktop.org/monado/monado.git
synced 2025-01-19 13:18:32 +00:00
32 lines
1.5 KiB
Markdown
32 lines
1.5 KiB
Markdown
|
# Implementing OpenXR extensions {#implementing-extension}
|
||
|
|
||
|
<!--
|
||
|
Copyright 2021, Collabora, Ltd. and the Monado contributors
|
||
|
SPDX-License-Identifier: BSL-1.0
|
||
|
-->
|
||
|
|
||
|
Khronos often adds new functionality to the OpenXR specification as extensions.
|
||
|
|
||
|
The general steps to implement an OpenXR extension in Monado are as follows.
|
||
|
|
||
|
* Edit scripts/generate_oxr_ext_support.py. Usually you only need to add an
|
||
|
entry to the `EXTENSIONS` list at the top.
|
||
|
* Run the script `python scripts/generate_oxr_ext_support.py`.
|
||
|
* Format the regenerated file with
|
||
|
`clang-format -i src/xrt/state_trackers/oxr/oxr_extension_support.h`.
|
||
|
* Add entry points for each new function in
|
||
|
`src/xrt/state_trackers/oxr/oxr_api_negotiate.c`.
|
||
|
* Monado internal implementations of "objects" (think XrSession or
|
||
|
XrHandTracker) go into `src/xrt/state_trackers/oxr/oxr_objects.h`.
|
||
|
* Enums, defines and types go into `src/xrt/include/xrt/xrt_defines.h`. OpenXR
|
||
|
types are not used outside of the `oxr_api_*` files, instead equivalents with
|
||
|
the prefix `XRT_` are defined here.
|
||
|
* Add Monado specific prototypes for the new functions in
|
||
|
`src/xrt/state_trackers/oxr/oxr_objects.h`. The Monado implementations of
|
||
|
OpenXR functions are prefixed with `oxr_`.
|
||
|
* Implement the Monado specific functions in an appropriate source file
|
||
|
`src/state_trackers/oxr/oxr_api_*.c`. Trivial functions can be implemented
|
||
|
right there along with the usual parameter checks. More complex functions that
|
||
|
access more internal monado state should call functions implemented in the
|
||
|
relevant `oxr_*.c` file (without `_api_`).
|