From 41b9a43214396f18adb1fd72a098d65541e26226 Mon Sep 17 00:00:00 2001 From: galister <22305755+galister@users.noreply.github.com> Date: Wed, 10 Apr 2024 10:10:31 +0900 Subject: [PATCH] fix: support provisional extensions --- generator/src/main.rs | 21 ++++++-- openxr/src/generated.rs | 114 ++++++++++++++++++++++++++++++++++++++++ sys/src/generated.rs | 9 ++++ 3 files changed, 139 insertions(+), 5 deletions(-) diff --git a/generator/src/main.rs b/generator/src/main.rs index 5fc23422..3a4850ac 100644 --- a/generator/src/main.rs +++ b/generator/src/main.rs @@ -313,13 +313,24 @@ impl Parser { if attr(attrs, "supported").map_or(false, |x| x == "disabled") { self.disabled_exts.insert(ext_name); } else { + let provisional = attr(attrs, "provisional").map_or(false, |x| x == "true"); + let (tag_name, _) = split_ext_tag(&ext_name); + let ext = Extension { + name: ext_name.clone(), + version: ext_version.unwrap(), + commands, + }; + if let Some(tag) = self.extensions.get_mut(tag_name) { - tag.extensions.push(Extension { - name: ext_name, - version: ext_version.unwrap(), - commands, - }); + tag.extensions.push(ext); + } else if provisional { + self.extensions.insert( + tag_name.into(), + Tag { + extensions: vec![ext], + }, + ); } else { eprintln!("ignoring extension with unlisted tag: {}", ext_name); } diff --git a/openxr/src/generated.rs b/openxr/src/generated.rs index 724de1fd..1d692073 100644 --- a/openxr/src/generated.rs +++ b/openxr/src/generated.rs @@ -207,6 +207,10 @@ pub struct ExtensionSet { pub varjo_marker_tracking: bool, pub varjo_view_offset: bool, pub yvr_controller_interaction: bool, + pub extx_overlay: bool, + pub mndx_egl_enable: bool, + pub mndx_force_feedback_curl: bool, + pub htcx_vive_tracker_interaction: bool, #[doc = r" Extensions unknown to the high-level bindings"] pub other: Vec, } @@ -642,6 +646,18 @@ impl ExtensionSet { raw::ControllerInteractionYVR::NAME => { out.yvr_controller_interaction = true; } + raw::OverlayEXTX::NAME => { + out.extx_overlay = true; + } + raw::EglEnableMNDX::NAME => { + out.mndx_egl_enable = true; + } + raw::ForceFeedbackCurlMNDX::NAME => { + out.mndx_force_feedback_curl = true; + } + raw::ViveTrackerInteractionHTCX::NAME => { + out.htcx_vive_tracker_interaction = true; + } bytes => { if let Ok(name) = std::str::from_utf8(bytes) { out.other.push(name.into()); @@ -1356,6 +1372,26 @@ impl ExtensionSet { out.push(raw::ControllerInteractionYVR::NAME.into()); } } + { + if self.extx_overlay { + out.push(raw::OverlayEXTX::NAME.into()); + } + } + { + if self.mndx_egl_enable { + out.push(raw::EglEnableMNDX::NAME.into()); + } + } + { + if self.mndx_force_feedback_curl { + out.push(raw::ForceFeedbackCurlMNDX::NAME.into()); + } + } + { + if self.htcx_vive_tracker_interaction { + out.push(raw::ViveTrackerInteractionHTCX::NAME.into()); + } + } for name in &self.other { let mut bytes = Vec::with_capacity(name.len() + 1); bytes.extend_from_slice(name.as_bytes()); @@ -1521,6 +1557,10 @@ pub struct InstanceExtensions { pub varjo_marker_tracking: Option, pub varjo_view_offset: Option, pub yvr_controller_interaction: Option, + pub extx_overlay: Option, + pub mndx_egl_enable: Option, + pub mndx_force_feedback_curl: Option, + pub htcx_vive_tracker_interaction: Option, } impl InstanceExtensions { #[doc = r" Load extension function pointer tables"] @@ -2257,6 +2297,26 @@ impl InstanceExtensions { } else { None }, + extx_overlay: if required.extx_overlay { + Some(raw::OverlayEXTX {}) + } else { + None + }, + mndx_egl_enable: if required.mndx_egl_enable { + Some(raw::EglEnableMNDX {}) + } else { + None + }, + mndx_force_feedback_curl: if required.mndx_force_feedback_curl { + Some(raw::ForceFeedbackCurlMNDX::load(entry, instance)?) + } else { + None + }, + htcx_vive_tracker_interaction: if required.htcx_vive_tracker_interaction { + Some(raw::ViveTrackerInteractionHTCX::load(entry, instance)?) + } else { + None + }, }) } } @@ -5961,6 +6021,60 @@ pub mod raw { pub const VERSION: u32 = sys::YVR_controller_interaction_SPEC_VERSION; pub const NAME: &'static [u8] = sys::YVR_CONTROLLER_INTERACTION_EXTENSION_NAME; } + #[derive(Copy, Clone)] + pub struct OverlayEXTX {} + impl OverlayEXTX { + pub const VERSION: u32 = sys::EXTX_overlay_SPEC_VERSION; + pub const NAME: &'static [u8] = sys::EXTX_OVERLAY_EXTENSION_NAME; + } + #[derive(Copy, Clone)] + pub struct EglEnableMNDX {} + impl EglEnableMNDX { + pub const VERSION: u32 = sys::MNDX_egl_enable_SPEC_VERSION; + pub const NAME: &'static [u8] = sys::MNDX_EGL_ENABLE_EXTENSION_NAME; + } + #[derive(Copy, Clone)] + pub struct ForceFeedbackCurlMNDX { + pub apply_force_feedback_curl: pfn::ApplyForceFeedbackCurlMNDX, + } + impl ForceFeedbackCurlMNDX { + pub const VERSION: u32 = sys::MNDX_force_feedback_curl_SPEC_VERSION; + pub const NAME: &'static [u8] = sys::MNDX_FORCE_FEEDBACK_CURL_EXTENSION_NAME; + #[doc = r" Load the extension's function pointer table"] + #[doc = r""] + #[doc = r" # Safety"] + #[doc = r""] + #[doc = r" `instance` must be a valid instance handle."] + pub unsafe fn load(entry: &Entry, instance: sys::Instance) -> Result { + Ok(Self { + apply_force_feedback_curl: mem::transmute(entry.get_instance_proc_addr( + instance, + CStr::from_bytes_with_nul_unchecked(b"xrApplyForceFeedbackCurlMNDX\0"), + )?), + }) + } + } + #[derive(Copy, Clone)] + pub struct ViveTrackerInteractionHTCX { + pub enumerate_vive_tracker_paths: pfn::EnumerateViveTrackerPathsHTCX, + } + impl ViveTrackerInteractionHTCX { + pub const VERSION: u32 = sys::HTCX_vive_tracker_interaction_SPEC_VERSION; + pub const NAME: &'static [u8] = sys::HTCX_VIVE_TRACKER_INTERACTION_EXTENSION_NAME; + #[doc = r" Load the extension's function pointer table"] + #[doc = r""] + #[doc = r" # Safety"] + #[doc = r""] + #[doc = r" `instance` must be a valid instance handle."] + pub unsafe fn load(entry: &Entry, instance: sys::Instance) -> Result { + Ok(Self { + enumerate_vive_tracker_paths: mem::transmute(entry.get_instance_proc_addr( + instance, + CStr::from_bytes_with_nul_unchecked(b"xrEnumerateViveTrackerPathsHTCX\0"), + )?), + }) + } + } } #[allow(unused)] pub(crate) mod builder { diff --git a/sys/src/generated.rs b/sys/src/generated.rs index 3bd0e191..b5584071 100644 --- a/sys/src/generated.rs +++ b/sys/src/generated.rs @@ -12200,6 +12200,15 @@ pub const VARJO_view_offset_SPEC_VERSION: u32 = 1u32; pub const VARJO_VIEW_OFFSET_EXTENSION_NAME: &[u8] = b"XR_VARJO_view_offset\0"; pub const YVR_controller_interaction_SPEC_VERSION: u32 = 1u32; pub const YVR_CONTROLLER_INTERACTION_EXTENSION_NAME: &[u8] = b"XR_YVR_controller_interaction\0"; +pub const EXTX_overlay_SPEC_VERSION: u32 = 5u32; +pub const EXTX_OVERLAY_EXTENSION_NAME: &[u8] = b"XR_EXTX_overlay\0"; +pub const MNDX_egl_enable_SPEC_VERSION: u32 = 1u32; +pub const MNDX_EGL_ENABLE_EXTENSION_NAME: &[u8] = b"XR_MNDX_egl_enable\0"; +pub const MNDX_force_feedback_curl_SPEC_VERSION: u32 = 1u32; +pub const MNDX_FORCE_FEEDBACK_CURL_EXTENSION_NAME: &[u8] = b"XR_MNDX_force_feedback_curl\0"; +pub const HTCX_vive_tracker_interaction_SPEC_VERSION: u32 = 3u32; +pub const HTCX_VIVE_TRACKER_INTERACTION_EXTENSION_NAME: &[u8] = + b"XR_HTCX_vive_tracker_interaction\0"; #[cfg(feature = "linked")] extern "system" { #[link_name = "xrGetInstanceProcAddr"]