diff options
Diffstat (limited to 'src/extensions/khr/xcb_surface.rs')
-rwxr-xr-x | src/extensions/khr/xcb_surface.rs | 64 |
1 files changed, 32 insertions, 32 deletions
diff --git a/src/extensions/khr/xcb_surface.rs b/src/extensions/khr/xcb_surface.rs index c01d2f3..967376e 100755 --- a/src/extensions/khr/xcb_surface.rs +++ b/src/extensions/khr/xcb_surface.rs @@ -1,49 +1,44 @@ use crate::prelude::*; use crate::vk; use crate::RawPtr; -use crate::{EntryCustom, Instance}; +use crate::{Entry, Instance}; use std::ffi::CStr; use std::mem; #[derive(Clone)] pub struct XcbSurface { handle: vk::Instance, - xcb_surface_fn: vk::KhrXcbSurfaceFn, + fp: vk::KhrXcbSurfaceFn, } impl XcbSurface { - pub fn new<L>(entry: &EntryCustom<L>, instance: &Instance) -> Self { - let surface_fn = vk::KhrXcbSurfaceFn::load(|name| unsafe { - mem::transmute(entry.get_instance_proc_addr(instance.handle(), name.as_ptr())) + pub fn new(entry: &Entry, instance: &Instance) -> Self { + let handle = instance.handle(); + let fp = vk::KhrXcbSurfaceFn::load(|name| unsafe { + mem::transmute(entry.get_instance_proc_addr(handle, name.as_ptr())) }); - Self { - handle: instance.handle(), - xcb_surface_fn: surface_fn, - } + Self { handle, fp } } - pub fn name() -> &'static CStr { - vk::KhrXcbSurfaceFn::name() - } - - #[doc = "<https://www.khronos.org/registry/vulkan/specs/1.2-extensions/man/html/vkCreateXcbSurfaceKHR.html>"] + /// <https://www.khronos.org/registry/vulkan/specs/1.3-extensions/man/html/vkCreateXcbSurfaceKHR.html> + #[inline] pub unsafe fn create_xcb_surface( &self, create_info: &vk::XcbSurfaceCreateInfoKHR, allocation_callbacks: Option<&vk::AllocationCallbacks>, ) -> VkResult<vk::SurfaceKHR> { let mut surface = mem::zeroed(); - self.xcb_surface_fn - .create_xcb_surface_khr( - self.handle, - create_info, - allocation_callbacks.as_raw_ptr(), - &mut surface, - ) - .result_with_success(surface) + (self.fp.create_xcb_surface_khr)( + self.handle, + create_info, + allocation_callbacks.as_raw_ptr(), + &mut surface, + ) + .result_with_success(surface) } - #[doc = "<https://www.khronos.org/registry/vulkan/specs/1.2-extensions/man/html/vkGetPhysicalDeviceXcbPresentationSupportKHR.html>"] + /// <https://www.khronos.org/registry/vulkan/specs/1.3-extensions/man/html/vkGetPhysicalDeviceXcbPresentationSupportKHR.html> + #[inline] pub unsafe fn get_physical_device_xcb_presentation_support( &self, physical_device: vk::PhysicalDevice, @@ -51,22 +46,27 @@ impl XcbSurface { connection: &mut vk::xcb_connection_t, visual_id: vk::xcb_visualid_t, ) -> bool { - let b = self - .xcb_surface_fn - .get_physical_device_xcb_presentation_support_khr( - physical_device, - queue_family_index, - connection, - visual_id, - ); + let b = (self.fp.get_physical_device_xcb_presentation_support_khr)( + physical_device, + queue_family_index, + connection, + visual_id, + ); b > 0 } + #[inline] + pub const fn name() -> &'static CStr { + vk::KhrXcbSurfaceFn::name() + } + + #[inline] pub fn fp(&self) -> &vk::KhrXcbSurfaceFn { - &self.xcb_surface_fn + &self.fp } + #[inline] pub fn instance(&self) -> vk::Instance { self.handle } |