aboutsummaryrefslogtreecommitdiff
path: root/src/extensions/khr/xcb_surface.rs
diff options
context:
space:
mode:
Diffstat (limited to 'src/extensions/khr/xcb_surface.rs')
-rwxr-xr-xsrc/extensions/khr/xcb_surface.rs64
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
}