From 4f41c00896d1f254b899b78926658ca7058dd8b8 Mon Sep 17 00:00:00 2001 From: Marijn Suijten Date: Sat, 7 Dec 2024 01:07:59 +0100 Subject: [PATCH] Inline `predule` module contents into their parent modules We've never used `prelude` in a sensible way, both modules inside the crate root and `vk` namespace have always abused these modules to store a random combination of private utilities next to a few extra hand-written type/trait definitions and implementations. Neither of these need to glob-imported by users to make easy use of `ash` functionality besides perhaps ensuring traits like `Handle` and `TaggedStructure` are in scope. Their glob imports were only useful to `ash` itself, and even then the `vk::prelude` was already fully glob-reexported in `vk`. Besides inlining its contents, I've shuffled some private helpers like `debug_flags()` closer to where they are being used. --- Changelog.md | 4 + ash-window/src/lib.rs | 3 +- ash/src/device.rs | 3 +- ash/src/entry.rs | 3 +- ash/src/extensions/amd/shader_info.rs | 3 +- ash/src/extensions/amdx/shader_enqueue.rs | 2 +- ...external_memory_android_hardware_buffer.rs | 2 +- ash/src/extensions/ext/acquire_drm_display.rs | 2 +- .../extensions/ext/calibrated_timestamps.rs | 3 +- ash/src/extensions/ext/debug_marker.rs | 2 +- ash/src/extensions/ext/debug_report.rs | 2 +- ash/src/extensions/ext/debug_utils.rs | 2 +- ash/src/extensions/ext/descriptor_buffer.rs | 2 +- .../extensions/ext/full_screen_exclusive.rs | 3 +- ash/src/extensions/ext/headless_surface.rs | 2 +- ash/src/extensions/ext/host_image_copy.rs | 2 +- .../ext/image_drm_format_modifier.rs | 2 +- ash/src/extensions/ext/metal_surface.rs | 2 +- ash/src/extensions/ext/pipeline_properties.rs | 2 +- ash/src/extensions/ext/private_data.rs | 2 +- ash/src/extensions/ext/shader_object.rs | 3 +- .../extensions/ext/swapchain_maintenance1.rs | 2 +- ash/src/extensions/ext/tooling_info.rs | 2 +- ash/src/extensions/google/display_timing.rs | 3 +- .../extensions/khr/acceleration_structure.rs | 2 +- ash/src/extensions/khr/android_surface.rs | 2 +- .../extensions/khr/calibrated_timestamps.rs | 3 +- ash/src/extensions/khr/cooperative_matrix.rs | 2 +- ash/src/extensions/khr/create_renderpass2.rs | 2 +- .../khr/deferred_host_operations.rs | 2 +- ash/src/extensions/khr/device_group.rs | 3 +- .../extensions/khr/device_group_creation.rs | 2 +- ash/src/extensions/khr/display.rs | 3 +- ash/src/extensions/khr/display_swapchain.rs | 2 +- ash/src/extensions/khr/external_fence_fd.rs | 2 +- .../extensions/khr/external_fence_win32.rs | 2 +- ash/src/extensions/khr/external_memory_fd.rs | 2 +- .../extensions/khr/external_memory_win32.rs | 2 +- .../extensions/khr/external_semaphore_fd.rs | 2 +- .../khr/external_semaphore_win32.rs | 2 +- .../extensions/khr/get_display_properties2.rs | 2 +- .../khr/get_physical_device_properties2.rs | 2 +- .../khr/get_surface_capabilities2.rs | 2 +- ash/src/extensions/khr/performance_query.rs | 2 +- .../khr/pipeline_executable_properties.rs | 2 +- ash/src/extensions/khr/present_wait.rs | 2 +- .../extensions/khr/ray_tracing_pipeline.rs | 2 +- .../khr/sampler_ycbcr_conversion.rs | 2 +- ash/src/extensions/khr/surface.rs | 3 +- ash/src/extensions/khr/swapchain.rs | 3 +- ash/src/extensions/khr/synchronization2.rs | 2 +- ash/src/extensions/khr/timeline_semaphore.rs | 2 +- ash/src/extensions/khr/wayland_surface.rs | 2 +- ash/src/extensions/khr/win32_surface.rs | 2 +- ash/src/extensions/khr/xcb_surface.rs | 2 +- ash/src/extensions/khr/xlib_surface.rs | 2 +- ash/src/extensions/mvk/ios_surface.rs | 2 +- ash/src/extensions/mvk/macos_surface.rs | 2 +- ash/src/extensions/nn/vi_surface.rs | 2 +- .../extensions/nv/coverage_reduction_mode.rs | 2 +- ash/src/extensions/nv/cuda_kernel_launch.rs | 3 +- ash/src/extensions/nv/low_latency2.rs | 2 +- ash/src/extensions/nv/ray_tracing.rs | 2 +- ash/src/instance.rs | 3 +- ash/src/lib.rs | 84 ++++++-- ash/src/prelude.rs | 93 --------- ash/src/vk.rs | 192 ++++++++++++++++-- ash/src/vk/aliases.rs | 6 +- ash/src/vk/bitflags.rs | 2 +- ash/src/vk/const_debugs.rs | 8 +- ash/src/vk/constants.rs | 2 +- ash/src/vk/definitions.rs | 18 +- ash/src/vk/extensions.rs | 10 +- ash/src/vk/feature_extensions.rs | 4 +- ash/src/vk/features.rs | 6 +- ash/src/vk/prelude.rs | 109 ---------- generator/src/lib.rs | 60 +++--- 77 files changed, 378 insertions(+), 361 deletions(-) delete mode 100644 ash/src/prelude.rs delete mode 100644 ash/src/vk/prelude.rs diff --git a/Changelog.md b/Changelog.md index 799498481..0c7f1b280 100644 --- a/Changelog.md +++ b/Changelog.md @@ -27,6 +27,10 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 The expected length of this array can be queried with the respective `*_len()` variant of these functions. - `push_next()` has been renamed to `extend()` and marked as `unsafe`. Users are encouraged to call `push()` for singular structs instead. (#909) +### Removed + +- Removed `ash::prelude` and `ash::vk::prelude` in favour of capturing all contents directly in their parent module. (#972) + ## [0.38.0] - 2024-04-01 With over two years of collecting breaking changes (since the `0.37.0` release in March 2022), April 2024 marks the next breaking release of `ash`. This release introduces an overhaul of all Vulkan structures, restructures modules around extensions, and separates extension wrappers between `Instance` and `Device` functions. The crate contains all bindings defined by the latest `1.3.281` Vulkan specification, and many old and new extensions have received a hand-written extension wrapper. For a full overview of all individual changes, see the list at the end of this post. diff --git a/ash-window/src/lib.rs b/ash-window/src/lib.rs index edb001a29..3a72ffe48 100644 --- a/ash-window/src/lib.rs +++ b/ash-window/src/lib.rs @@ -5,8 +5,7 @@ use std::os::raw::c_char; use ash::{ ext::metal_surface, khr::{android_surface, surface, wayland_surface, win32_surface, xcb_surface, xlib_surface}, - prelude::*, - vk, Entry, Instance, + vk, Entry, Instance, VkResult, }; use raw_window_handle::{RawDisplayHandle, RawWindowHandle}; diff --git a/ash/src/device.rs b/ash/src/device.rs index 76fc814fa..a1547d616 100644 --- a/ash/src/device.rs +++ b/ash/src/device.rs @@ -1,7 +1,8 @@ #![allow(clippy::trivially_copy_pass_by_ref)] -use crate::prelude::*; +use crate::read_into_uninitialized_vector; use crate::vk; use crate::RawPtr; +use crate::VkResult; use alloc::vec::Vec; use core::ffi; use core::mem; diff --git a/ash/src/entry.rs b/ash/src/entry.rs index 3a26b18a9..5f4cca8ca 100644 --- a/ash/src/entry.rs +++ b/ash/src/entry.rs @@ -1,9 +1,10 @@ use crate::instance::Instance; #[cfg(doc)] use crate::khr; -use crate::prelude::*; +use crate::read_into_uninitialized_vector; use crate::vk; use crate::RawPtr; +use crate::VkResult; use alloc::vec::Vec; use core::ffi; use core::fmt; diff --git a/ash/src/extensions/amd/shader_info.rs b/ash/src/extensions/amd/shader_info.rs index 47d0cd7a0..0436d6fef 100644 --- a/ash/src/extensions/amd/shader_info.rs +++ b/ash/src/extensions/amd/shader_info.rs @@ -1,7 +1,8 @@ //! -use crate::prelude::*; +use crate::read_into_uninitialized_vector; use crate::vk; +use crate::VkResult; use alloc::vec::Vec; use core::mem; use core::mem::size_of_val; // TODO: Remove when bumping MSRV to 1.80 diff --git a/ash/src/extensions/amdx/shader_enqueue.rs b/ash/src/extensions/amdx/shader_enqueue.rs index d0f31ea34..79c1f90cd 100644 --- a/ash/src/extensions/amdx/shader_enqueue.rs +++ b/ash/src/extensions/amdx/shader_enqueue.rs @@ -1,8 +1,8 @@ //! -use crate::prelude::*; use crate::vk; use crate::RawPtr; +use crate::VkResult; use alloc::vec::Vec; use core::mem; diff --git a/ash/src/extensions/android/external_memory_android_hardware_buffer.rs b/ash/src/extensions/android/external_memory_android_hardware_buffer.rs index d94deb3d2..225659fdc 100644 --- a/ash/src/extensions/android/external_memory_android_hardware_buffer.rs +++ b/ash/src/extensions/android/external_memory_android_hardware_buffer.rs @@ -1,7 +1,7 @@ //! -use crate::prelude::*; use crate::vk; +use crate::VkResult; use core::mem; impl crate::android::external_memory_android_hardware_buffer::Device { diff --git a/ash/src/extensions/ext/acquire_drm_display.rs b/ash/src/extensions/ext/acquire_drm_display.rs index 9ed928f73..402401a59 100644 --- a/ash/src/extensions/ext/acquire_drm_display.rs +++ b/ash/src/extensions/ext/acquire_drm_display.rs @@ -1,7 +1,7 @@ //! -use crate::prelude::*; use crate::vk; +use crate::VkResult; use core::mem; impl crate::ext::acquire_drm_display::Instance { diff --git a/ash/src/extensions/ext/calibrated_timestamps.rs b/ash/src/extensions/ext/calibrated_timestamps.rs index 3005d3b63..416949e72 100644 --- a/ash/src/extensions/ext/calibrated_timestamps.rs +++ b/ash/src/extensions/ext/calibrated_timestamps.rs @@ -1,7 +1,8 @@ //! -use crate::prelude::*; +use crate::read_into_uninitialized_vector; use crate::vk; +use crate::VkResult; use alloc::vec::Vec; use core::mem; diff --git a/ash/src/extensions/ext/debug_marker.rs b/ash/src/extensions/ext/debug_marker.rs index 0e584fe2d..b25e0aaef 100755 --- a/ash/src/extensions/ext/debug_marker.rs +++ b/ash/src/extensions/ext/debug_marker.rs @@ -1,7 +1,7 @@ //! -use crate::prelude::*; use crate::vk; +use crate::VkResult; impl crate::ext::debug_marker::Device { /// diff --git a/ash/src/extensions/ext/debug_report.rs b/ash/src/extensions/ext/debug_report.rs index d29a322f5..fec574f9d 100755 --- a/ash/src/extensions/ext/debug_report.rs +++ b/ash/src/extensions/ext/debug_report.rs @@ -1,8 +1,8 @@ //! -use crate::prelude::*; use crate::vk; use crate::RawPtr; +use crate::VkResult; use core::mem; impl crate::ext::debug_report::Instance { diff --git a/ash/src/extensions/ext/debug_utils.rs b/ash/src/extensions/ext/debug_utils.rs index ac697f423..c8449cf0d 100755 --- a/ash/src/extensions/ext/debug_utils.rs +++ b/ash/src/extensions/ext/debug_utils.rs @@ -1,8 +1,8 @@ //! -use crate::prelude::*; use crate::vk; use crate::RawPtr; +use crate::VkResult; use core::mem; impl crate::ext::debug_utils::Device { diff --git a/ash/src/extensions/ext/descriptor_buffer.rs b/ash/src/extensions/ext/descriptor_buffer.rs index a5e9ab857..b703c600e 100644 --- a/ash/src/extensions/ext/descriptor_buffer.rs +++ b/ash/src/extensions/ext/descriptor_buffer.rs @@ -1,7 +1,7 @@ //! -use crate::prelude::*; use crate::vk; +use crate::VkResult; use core::mem; impl crate::ext::descriptor_buffer::Device { diff --git a/ash/src/extensions/ext/full_screen_exclusive.rs b/ash/src/extensions/ext/full_screen_exclusive.rs index f2b9791f7..77e86b37a 100644 --- a/ash/src/extensions/ext/full_screen_exclusive.rs +++ b/ash/src/extensions/ext/full_screen_exclusive.rs @@ -1,7 +1,8 @@ //! -use crate::prelude::*; +use crate::read_into_uninitialized_vector; use crate::vk; +use crate::VkResult; use alloc::vec::Vec; use core::mem; diff --git a/ash/src/extensions/ext/headless_surface.rs b/ash/src/extensions/ext/headless_surface.rs index a3066e81c..75a389e33 100644 --- a/ash/src/extensions/ext/headless_surface.rs +++ b/ash/src/extensions/ext/headless_surface.rs @@ -1,8 +1,8 @@ //! -use crate::prelude::*; use crate::vk; use crate::RawPtr; +use crate::VkResult; use core::mem; impl crate::ext::headless_surface::Instance { diff --git a/ash/src/extensions/ext/host_image_copy.rs b/ash/src/extensions/ext/host_image_copy.rs index 204896407..ed6e38390 100644 --- a/ash/src/extensions/ext/host_image_copy.rs +++ b/ash/src/extensions/ext/host_image_copy.rs @@ -1,7 +1,7 @@ //! -use crate::prelude::*; use crate::vk; +use crate::VkResult; #[cfg(doc)] use crate::{ext, khr}; diff --git a/ash/src/extensions/ext/image_drm_format_modifier.rs b/ash/src/extensions/ext/image_drm_format_modifier.rs index c07e14719..601b3e384 100644 --- a/ash/src/extensions/ext/image_drm_format_modifier.rs +++ b/ash/src/extensions/ext/image_drm_format_modifier.rs @@ -1,7 +1,7 @@ //! -use crate::prelude::*; use crate::vk; +use crate::VkResult; impl crate::ext::image_drm_format_modifier::Device { /// diff --git a/ash/src/extensions/ext/metal_surface.rs b/ash/src/extensions/ext/metal_surface.rs index 99bcb6195..0e246934b 100644 --- a/ash/src/extensions/ext/metal_surface.rs +++ b/ash/src/extensions/ext/metal_surface.rs @@ -1,8 +1,8 @@ //! -use crate::prelude::*; use crate::vk; use crate::RawPtr; +use crate::VkResult; use core::mem; impl crate::ext::metal_surface::Instance { diff --git a/ash/src/extensions/ext/pipeline_properties.rs b/ash/src/extensions/ext/pipeline_properties.rs index 3ef7d4065..5e66e3ea1 100644 --- a/ash/src/extensions/ext/pipeline_properties.rs +++ b/ash/src/extensions/ext/pipeline_properties.rs @@ -1,7 +1,7 @@ //! -use crate::prelude::*; use crate::vk; +use crate::VkResult; impl crate::ext::pipeline_properties::Device { /// diff --git a/ash/src/extensions/ext/private_data.rs b/ash/src/extensions/ext/private_data.rs index 535fe37cb..7079e7fa7 100644 --- a/ash/src/extensions/ext/private_data.rs +++ b/ash/src/extensions/ext/private_data.rs @@ -1,8 +1,8 @@ //! -use crate::prelude::*; use crate::vk; use crate::RawPtr; +use crate::VkResult; use core::mem; impl crate::ext::private_data::Device { diff --git a/ash/src/extensions/ext/shader_object.rs b/ash/src/extensions/ext/shader_object.rs index 27e53c580..f395cd814 100644 --- a/ash/src/extensions/ext/shader_object.rs +++ b/ash/src/extensions/ext/shader_object.rs @@ -1,8 +1,9 @@ //! -use crate::prelude::*; +use crate::read_into_uninitialized_vector; use crate::vk; use crate::RawPtr; +use crate::VkResult; use alloc::vec::Vec; use core::ptr; diff --git a/ash/src/extensions/ext/swapchain_maintenance1.rs b/ash/src/extensions/ext/swapchain_maintenance1.rs index 531474226..58a1c59a1 100644 --- a/ash/src/extensions/ext/swapchain_maintenance1.rs +++ b/ash/src/extensions/ext/swapchain_maintenance1.rs @@ -1,7 +1,7 @@ //! -use crate::prelude::*; use crate::vk; +use crate::VkResult; impl crate::ext::swapchain_maintenance1::Device { /// diff --git a/ash/src/extensions/ext/tooling_info.rs b/ash/src/extensions/ext/tooling_info.rs index e756b6276..5ba24dc98 100644 --- a/ash/src/extensions/ext/tooling_info.rs +++ b/ash/src/extensions/ext/tooling_info.rs @@ -1,7 +1,7 @@ //! -use crate::prelude::*; use crate::vk; +use crate::VkResult; use core::mem; use core::ptr; diff --git a/ash/src/extensions/google/display_timing.rs b/ash/src/extensions/google/display_timing.rs index 06de20926..1a0f11368 100644 --- a/ash/src/extensions/google/display_timing.rs +++ b/ash/src/extensions/google/display_timing.rs @@ -1,7 +1,8 @@ //! -use crate::prelude::*; +use crate::read_into_uninitialized_vector; use crate::vk; +use crate::VkResult; use alloc::vec::Vec; use core::mem; diff --git a/ash/src/extensions/khr/acceleration_structure.rs b/ash/src/extensions/khr/acceleration_structure.rs index 87e98c049..44e6521b7 100644 --- a/ash/src/extensions/khr/acceleration_structure.rs +++ b/ash/src/extensions/khr/acceleration_structure.rs @@ -1,8 +1,8 @@ //! -use crate::prelude::*; use crate::vk; use crate::RawPtr; +use crate::VkResult; use alloc::vec::Vec; use core::mem; diff --git a/ash/src/extensions/khr/android_surface.rs b/ash/src/extensions/khr/android_surface.rs index 6aa5267f6..2283f2409 100755 --- a/ash/src/extensions/khr/android_surface.rs +++ b/ash/src/extensions/khr/android_surface.rs @@ -1,8 +1,8 @@ //! -use crate::prelude::*; use crate::vk; use crate::RawPtr; +use crate::VkResult; use core::mem; impl crate::khr::android_surface::Instance { diff --git a/ash/src/extensions/khr/calibrated_timestamps.rs b/ash/src/extensions/khr/calibrated_timestamps.rs index 2ed93a45c..bc8cacc72 100644 --- a/ash/src/extensions/khr/calibrated_timestamps.rs +++ b/ash/src/extensions/khr/calibrated_timestamps.rs @@ -1,7 +1,8 @@ //! -use crate::prelude::*; +use crate::read_into_uninitialized_vector; use crate::vk; +use crate::VkResult; use alloc::vec::Vec; use core::mem; diff --git a/ash/src/extensions/khr/cooperative_matrix.rs b/ash/src/extensions/khr/cooperative_matrix.rs index 1a15eda34..2ed80327d 100644 --- a/ash/src/extensions/khr/cooperative_matrix.rs +++ b/ash/src/extensions/khr/cooperative_matrix.rs @@ -1,7 +1,7 @@ //! -use crate::prelude::*; use crate::vk; +use crate::VkResult; use core::mem; use core::ptr; diff --git a/ash/src/extensions/khr/create_renderpass2.rs b/ash/src/extensions/khr/create_renderpass2.rs index 7ff94dc70..e0a4a4078 100644 --- a/ash/src/extensions/khr/create_renderpass2.rs +++ b/ash/src/extensions/khr/create_renderpass2.rs @@ -1,8 +1,8 @@ //! -use crate::prelude::*; use crate::vk; use crate::RawPtr; +use crate::VkResult; use core::mem; impl crate::khr::create_renderpass2::Device { diff --git a/ash/src/extensions/khr/deferred_host_operations.rs b/ash/src/extensions/khr/deferred_host_operations.rs index 3f71788cc..dfe285214 100644 --- a/ash/src/extensions/khr/deferred_host_operations.rs +++ b/ash/src/extensions/khr/deferred_host_operations.rs @@ -1,8 +1,8 @@ //! -use crate::prelude::*; use crate::vk; use crate::RawPtr; +use crate::VkResult; use core::mem; impl crate::khr::deferred_host_operations::Device { diff --git a/ash/src/extensions/khr/device_group.rs b/ash/src/extensions/khr/device_group.rs index 44e807d20..6ce3b2696 100644 --- a/ash/src/extensions/khr/device_group.rs +++ b/ash/src/extensions/khr/device_group.rs @@ -2,8 +2,9 @@ #[cfg(doc)] use crate::khr; -use crate::prelude::*; +use crate::read_into_uninitialized_vector; use crate::vk; +use crate::VkResult; use alloc::vec::Vec; use core::mem; diff --git a/ash/src/extensions/khr/device_group_creation.rs b/ash/src/extensions/khr/device_group_creation.rs index ad85ee079..1bd8e1f12 100644 --- a/ash/src/extensions/khr/device_group_creation.rs +++ b/ash/src/extensions/khr/device_group_creation.rs @@ -1,7 +1,7 @@ //! -use crate::prelude::*; use crate::vk; +use crate::VkResult; use core::mem; use core::ptr; diff --git a/ash/src/extensions/khr/display.rs b/ash/src/extensions/khr/display.rs index 801efbb21..632523da8 100755 --- a/ash/src/extensions/khr/display.rs +++ b/ash/src/extensions/khr/display.rs @@ -1,8 +1,9 @@ //! -use crate::prelude::*; +use crate::read_into_uninitialized_vector; use crate::vk; use crate::RawPtr; +use crate::VkResult; use alloc::vec::Vec; use core::mem; diff --git a/ash/src/extensions/khr/display_swapchain.rs b/ash/src/extensions/khr/display_swapchain.rs index b5d3e8b42..2210cb41c 100755 --- a/ash/src/extensions/khr/display_swapchain.rs +++ b/ash/src/extensions/khr/display_swapchain.rs @@ -1,8 +1,8 @@ //! -use crate::prelude::*; use crate::vk; use crate::RawPtr; +use crate::VkResult; use alloc::vec::Vec; impl crate::khr::display_swapchain::Device { diff --git a/ash/src/extensions/khr/external_fence_fd.rs b/ash/src/extensions/khr/external_fence_fd.rs index 8b7334acc..f772d29e5 100644 --- a/ash/src/extensions/khr/external_fence_fd.rs +++ b/ash/src/extensions/khr/external_fence_fd.rs @@ -1,7 +1,7 @@ //! -use crate::prelude::*; use crate::vk; +use crate::VkResult; use core::mem; impl crate::khr::external_fence_fd::Device { diff --git a/ash/src/extensions/khr/external_fence_win32.rs b/ash/src/extensions/khr/external_fence_win32.rs index e2c2e058d..7a45a9c86 100644 --- a/ash/src/extensions/khr/external_fence_win32.rs +++ b/ash/src/extensions/khr/external_fence_win32.rs @@ -1,7 +1,7 @@ //! -use crate::prelude::*; use crate::vk; +use crate::VkResult; use core::mem; impl crate::khr::external_fence_win32::Device { diff --git a/ash/src/extensions/khr/external_memory_fd.rs b/ash/src/extensions/khr/external_memory_fd.rs index f77e382cc..bee6f104a 100644 --- a/ash/src/extensions/khr/external_memory_fd.rs +++ b/ash/src/extensions/khr/external_memory_fd.rs @@ -1,7 +1,7 @@ //! -use crate::prelude::*; use crate::vk; +use crate::VkResult; use core::mem; impl crate::khr::external_memory_fd::Device { diff --git a/ash/src/extensions/khr/external_memory_win32.rs b/ash/src/extensions/khr/external_memory_win32.rs index 4bf2fc1f8..8af008ad2 100644 --- a/ash/src/extensions/khr/external_memory_win32.rs +++ b/ash/src/extensions/khr/external_memory_win32.rs @@ -1,7 +1,7 @@ //! -use crate::prelude::*; use crate::vk; +use crate::VkResult; use core::mem; impl crate::khr::external_memory_win32::Device { diff --git a/ash/src/extensions/khr/external_semaphore_fd.rs b/ash/src/extensions/khr/external_semaphore_fd.rs index 181ea3613..1b2997681 100644 --- a/ash/src/extensions/khr/external_semaphore_fd.rs +++ b/ash/src/extensions/khr/external_semaphore_fd.rs @@ -1,7 +1,7 @@ //! -use crate::prelude::*; use crate::vk; +use crate::VkResult; use core::mem; impl crate::khr::external_semaphore_fd::Device { diff --git a/ash/src/extensions/khr/external_semaphore_win32.rs b/ash/src/extensions/khr/external_semaphore_win32.rs index 889887e1b..5ef53ace3 100644 --- a/ash/src/extensions/khr/external_semaphore_win32.rs +++ b/ash/src/extensions/khr/external_semaphore_win32.rs @@ -1,7 +1,7 @@ //! -use crate::prelude::*; use crate::vk; +use crate::VkResult; use core::mem; impl crate::khr::external_semaphore_win32::Device { diff --git a/ash/src/extensions/khr/get_display_properties2.rs b/ash/src/extensions/khr/get_display_properties2.rs index 061269f8d..7cb6a5ce8 100644 --- a/ash/src/extensions/khr/get_display_properties2.rs +++ b/ash/src/extensions/khr/get_display_properties2.rs @@ -1,7 +1,7 @@ //! -use crate::prelude::*; use crate::vk; +use crate::VkResult; use core::mem; use core::ptr; diff --git a/ash/src/extensions/khr/get_physical_device_properties2.rs b/ash/src/extensions/khr/get_physical_device_properties2.rs index 3c0e88d64..5d3375390 100644 --- a/ash/src/extensions/khr/get_physical_device_properties2.rs +++ b/ash/src/extensions/khr/get_physical_device_properties2.rs @@ -1,7 +1,7 @@ //! -use crate::prelude::*; use crate::vk; +use crate::VkResult; use core::mem; use core::ptr; diff --git a/ash/src/extensions/khr/get_surface_capabilities2.rs b/ash/src/extensions/khr/get_surface_capabilities2.rs index 135334c10..9c238e950 100644 --- a/ash/src/extensions/khr/get_surface_capabilities2.rs +++ b/ash/src/extensions/khr/get_surface_capabilities2.rs @@ -1,7 +1,7 @@ //! -use crate::prelude::*; use crate::vk; +use crate::VkResult; use core::mem; use core::ptr; diff --git a/ash/src/extensions/khr/performance_query.rs b/ash/src/extensions/khr/performance_query.rs index f5bcbc0ad..27785df08 100644 --- a/ash/src/extensions/khr/performance_query.rs +++ b/ash/src/extensions/khr/performance_query.rs @@ -1,7 +1,7 @@ //! -use crate::prelude::*; use crate::vk; +use crate::VkResult; use core::mem; use core::ptr; diff --git a/ash/src/extensions/khr/pipeline_executable_properties.rs b/ash/src/extensions/khr/pipeline_executable_properties.rs index a42f7baf7..500744c66 100644 --- a/ash/src/extensions/khr/pipeline_executable_properties.rs +++ b/ash/src/extensions/khr/pipeline_executable_properties.rs @@ -1,7 +1,7 @@ //! -use crate::prelude::*; use crate::vk; +use crate::VkResult; use core::mem; use core::ptr; diff --git a/ash/src/extensions/khr/present_wait.rs b/ash/src/extensions/khr/present_wait.rs index 7ade6fbdf..4cba3ac9f 100644 --- a/ash/src/extensions/khr/present_wait.rs +++ b/ash/src/extensions/khr/present_wait.rs @@ -1,7 +1,7 @@ //! -use crate::prelude::*; use crate::vk; +use crate::VkResult; impl crate::khr::present_wait::Device { /// diff --git a/ash/src/extensions/khr/ray_tracing_pipeline.rs b/ash/src/extensions/khr/ray_tracing_pipeline.rs index 2e41eda26..39be9d599 100644 --- a/ash/src/extensions/khr/ray_tracing_pipeline.rs +++ b/ash/src/extensions/khr/ray_tracing_pipeline.rs @@ -1,8 +1,8 @@ //! -use crate::prelude::*; use crate::vk; use crate::RawPtr; +use crate::VkResult; use alloc::vec::Vec; impl crate::khr::ray_tracing_pipeline::Device { diff --git a/ash/src/extensions/khr/sampler_ycbcr_conversion.rs b/ash/src/extensions/khr/sampler_ycbcr_conversion.rs index 48e9cad5f..a4a6e10c8 100644 --- a/ash/src/extensions/khr/sampler_ycbcr_conversion.rs +++ b/ash/src/extensions/khr/sampler_ycbcr_conversion.rs @@ -1,8 +1,8 @@ //! -use crate::prelude::*; use crate::vk; use crate::RawPtr; +use crate::VkResult; use core::mem; impl crate::khr::sampler_ycbcr_conversion::Device { diff --git a/ash/src/extensions/khr/surface.rs b/ash/src/extensions/khr/surface.rs index c8218f267..1fe738579 100755 --- a/ash/src/extensions/khr/surface.rs +++ b/ash/src/extensions/khr/surface.rs @@ -1,8 +1,9 @@ //! -use crate::prelude::*; +use crate::read_into_uninitialized_vector; use crate::vk; use crate::RawPtr; +use crate::VkResult; use alloc::vec::Vec; use core::mem; diff --git a/ash/src/extensions/khr/swapchain.rs b/ash/src/extensions/khr/swapchain.rs index 7d972e02a..7a1c6c1b4 100755 --- a/ash/src/extensions/khr/swapchain.rs +++ b/ash/src/extensions/khr/swapchain.rs @@ -2,9 +2,10 @@ #[cfg(doc)] use crate::khr; -use crate::prelude::*; +use crate::read_into_uninitialized_vector; use crate::vk; use crate::RawPtr; +use crate::VkResult; use alloc::vec::Vec; use core::mem; diff --git a/ash/src/extensions/khr/synchronization2.rs b/ash/src/extensions/khr/synchronization2.rs index 2cfeef7a7..8da8177dd 100644 --- a/ash/src/extensions/khr/synchronization2.rs +++ b/ash/src/extensions/khr/synchronization2.rs @@ -1,7 +1,7 @@ //! -use crate::prelude::*; use crate::vk; +use crate::VkResult; impl crate::khr::synchronization2::Device { /// diff --git a/ash/src/extensions/khr/timeline_semaphore.rs b/ash/src/extensions/khr/timeline_semaphore.rs index 01af37554..d0a2d2517 100644 --- a/ash/src/extensions/khr/timeline_semaphore.rs +++ b/ash/src/extensions/khr/timeline_semaphore.rs @@ -1,7 +1,7 @@ //! -use crate::prelude::*; use crate::vk; +use crate::VkResult; use core::mem; impl crate::khr::timeline_semaphore::Device { diff --git a/ash/src/extensions/khr/wayland_surface.rs b/ash/src/extensions/khr/wayland_surface.rs index b5d91b488..9b842ec2d 100755 --- a/ash/src/extensions/khr/wayland_surface.rs +++ b/ash/src/extensions/khr/wayland_surface.rs @@ -1,8 +1,8 @@ //! -use crate::prelude::*; use crate::vk; use crate::RawPtr; +use crate::VkResult; use core::mem; impl crate::khr::wayland_surface::Instance { diff --git a/ash/src/extensions/khr/win32_surface.rs b/ash/src/extensions/khr/win32_surface.rs index 1aa359f7d..367328b11 100755 --- a/ash/src/extensions/khr/win32_surface.rs +++ b/ash/src/extensions/khr/win32_surface.rs @@ -1,8 +1,8 @@ //! -use crate::prelude::*; use crate::vk; use crate::RawPtr; +use crate::VkResult; use core::mem; impl crate::khr::win32_surface::Instance { diff --git a/ash/src/extensions/khr/xcb_surface.rs b/ash/src/extensions/khr/xcb_surface.rs index 5623026a9..1ebc4cab5 100755 --- a/ash/src/extensions/khr/xcb_surface.rs +++ b/ash/src/extensions/khr/xcb_surface.rs @@ -1,8 +1,8 @@ //! -use crate::prelude::*; use crate::vk; use crate::RawPtr; +use crate::VkResult; use core::mem; impl crate::khr::xcb_surface::Instance { diff --git a/ash/src/extensions/khr/xlib_surface.rs b/ash/src/extensions/khr/xlib_surface.rs index ddd01f060..ddbc60c38 100755 --- a/ash/src/extensions/khr/xlib_surface.rs +++ b/ash/src/extensions/khr/xlib_surface.rs @@ -1,8 +1,8 @@ //! -use crate::prelude::*; use crate::vk; use crate::RawPtr; +use crate::VkResult; use core::mem; impl crate::khr::xlib_surface::Instance { diff --git a/ash/src/extensions/mvk/ios_surface.rs b/ash/src/extensions/mvk/ios_surface.rs index e3e60f647..836fc1967 100755 --- a/ash/src/extensions/mvk/ios_surface.rs +++ b/ash/src/extensions/mvk/ios_surface.rs @@ -1,8 +1,8 @@ //! -use crate::prelude::*; use crate::vk; use crate::RawPtr; +use crate::VkResult; use core::mem; impl crate::mvk::ios_surface::Instance { diff --git a/ash/src/extensions/mvk/macos_surface.rs b/ash/src/extensions/mvk/macos_surface.rs index d8a873536..48eda6cc3 100755 --- a/ash/src/extensions/mvk/macos_surface.rs +++ b/ash/src/extensions/mvk/macos_surface.rs @@ -1,8 +1,8 @@ //! -use crate::prelude::*; use crate::vk; use crate::RawPtr; +use crate::VkResult; use core::mem; impl crate::mvk::macos_surface::Instance { diff --git a/ash/src/extensions/nn/vi_surface.rs b/ash/src/extensions/nn/vi_surface.rs index 0e2b41acb..5ead94138 100644 --- a/ash/src/extensions/nn/vi_surface.rs +++ b/ash/src/extensions/nn/vi_surface.rs @@ -1,8 +1,8 @@ //! -use crate::prelude::*; use crate::vk; use crate::RawPtr; +use crate::VkResult; use core::mem; impl crate::nn::vi_surface::Instance { diff --git a/ash/src/extensions/nv/coverage_reduction_mode.rs b/ash/src/extensions/nv/coverage_reduction_mode.rs index 61161ef54..b8a4f8223 100644 --- a/ash/src/extensions/nv/coverage_reduction_mode.rs +++ b/ash/src/extensions/nv/coverage_reduction_mode.rs @@ -1,7 +1,7 @@ //! -use crate::prelude::*; use crate::vk; +use crate::VkResult; use core::mem; use core::ptr; diff --git a/ash/src/extensions/nv/cuda_kernel_launch.rs b/ash/src/extensions/nv/cuda_kernel_launch.rs index f1fa7115f..cb83a7f7c 100644 --- a/ash/src/extensions/nv/cuda_kernel_launch.rs +++ b/ash/src/extensions/nv/cuda_kernel_launch.rs @@ -1,8 +1,9 @@ //! -use crate::prelude::*; +use crate::read_into_uninitialized_vector; use crate::vk; use crate::RawPtr; +use crate::VkResult; use alloc::vec::Vec; use core::mem; diff --git a/ash/src/extensions/nv/low_latency2.rs b/ash/src/extensions/nv/low_latency2.rs index f20f1c8da..84beec4c8 100644 --- a/ash/src/extensions/nv/low_latency2.rs +++ b/ash/src/extensions/nv/low_latency2.rs @@ -1,8 +1,8 @@ //! -use crate::prelude::*; use crate::vk; use crate::RawPtr; +use crate::VkResult; impl crate::nv::low_latency2::Device { /// diff --git a/ash/src/extensions/nv/ray_tracing.rs b/ash/src/extensions/nv/ray_tracing.rs index 0ec8d7f6e..cfa9db5cd 100755 --- a/ash/src/extensions/nv/ray_tracing.rs +++ b/ash/src/extensions/nv/ray_tracing.rs @@ -1,8 +1,8 @@ //! -use crate::prelude::*; use crate::vk; use crate::RawPtr; +use crate::VkResult; use alloc::vec::Vec; use core::mem; use core::mem::size_of_val; // TODO: Remove when bumping MSRV to 1.80 diff --git a/ash/src/instance.rs b/ash/src/instance.rs index 79995e19e..9995976e7 100644 --- a/ash/src/instance.rs +++ b/ash/src/instance.rs @@ -1,9 +1,10 @@ #[cfg(doc)] use super::Entry; use crate::device::Device; -use crate::prelude::*; +use crate::read_into_uninitialized_vector; use crate::vk; use crate::RawPtr; +use crate::VkResult; use alloc::vec::Vec; use core::ffi; use core::mem; diff --git a/ash/src/lib.rs b/ash/src/lib.rs index 05dd68a6a..bbdc88e97 100644 --- a/ash/src/lib.rs +++ b/ash/src/lib.rs @@ -55,6 +55,11 @@ extern crate alloc; +use alloc::vec::Vec; +use core::convert::TryInto; +use core::mem; +use core::ptr; + pub use crate::device::Device; pub use crate::entry::Entry; #[cfg(feature = "loaded")] @@ -67,7 +72,6 @@ mod device; mod entry; mod extensions_generated; mod instance; -pub mod prelude; mod tables; pub mod util; /// Raw Vulkan bindings and types, generated from `vk.xml` @@ -192,26 +196,62 @@ macro_rules! match_in_struct { }; } -#[cfg(test)] -mod tests { - use super::vk; - use alloc::vec::Vec; - #[test] - fn test_ptr_chains() { - let mut variable_pointers = vk::PhysicalDeviceVariablePointerFeatures::default(); - let mut corner = vk::PhysicalDeviceCornerSampledImageFeaturesNV::default(); - let chain = alloc::vec![ - <*mut _>::cast(&mut variable_pointers), - <*mut _>::cast(&mut corner), - ]; - let mut device_create_info = vk::DeviceCreateInfo::default() - .push(&mut corner) - .push(&mut variable_pointers); - let chain2: Vec<*mut vk::BaseOutStructure<'_>> = unsafe { - vk::ptr_chain_iter(&mut device_create_info) - .skip(1) - .collect() - }; - assert_eq!(chain, chain2); +pub type VkResult = Result; + +impl vk::Result { + #[inline] + pub fn result(self) -> VkResult<()> { + self.result_with_success(()) + } + + #[inline] + pub fn result_with_success(self, v: T) -> VkResult { + match self { + Self::SUCCESS => Ok(v), + _ => Err(self), + } + } + + #[inline] + pub unsafe fn assume_init_on_success(self, v: mem::MaybeUninit) -> VkResult { + self.result().map(move |()| v.assume_init()) + } + + #[inline] + pub unsafe fn set_vec_len_on_success(self, mut v: Vec, len: usize) -> VkResult> { + self.result().map(move |()| { + v.set_len(len); + v + }) + } +} + +/// Repeatedly calls `f` until it does not return [`vk::Result::INCOMPLETE`] anymore, ensuring all +/// available data has been read into the vector. +/// +/// See for example [`vkEnumerateInstanceExtensionProperties`]: the number of available items may +/// change between calls; [`vk::Result::INCOMPLETE`] is returned when the count increased (and the +/// vector is not large enough after querying the initial size), requiring Ash to try again. +/// +/// [`vkEnumerateInstanceExtensionProperties`]: https://registry.khronos.org/vulkan/specs/1.3-extensions/man/html/vkEnumerateInstanceExtensionProperties.html +pub(crate) unsafe fn read_into_uninitialized_vector, T>( + f: impl Fn(&mut N, *mut T) -> vk::Result, +) -> VkResult> +where + >::Error: core::fmt::Debug, +{ + loop { + let mut count = N::default(); + f(&mut count, ptr::null_mut()).result()?; + let mut data = + Vec::with_capacity(count.try_into().expect("`N` failed to convert to `usize`")); + + let err_code = f(&mut count, data.as_mut_ptr()); + if err_code != vk::Result::INCOMPLETE { + break err_code.set_vec_len_on_success( + data, + count.try_into().expect("`N` failed to convert to `usize`"), + ); + } } } diff --git a/ash/src/prelude.rs b/ash/src/prelude.rs deleted file mode 100644 index 74aa3f186..000000000 --- a/ash/src/prelude.rs +++ /dev/null @@ -1,93 +0,0 @@ -use alloc::vec::Vec; -use core::convert::TryInto; -use core::mem; -use core::ptr; - -use crate::vk; -pub type VkResult = Result; - -impl vk::Result { - #[inline] - pub fn result(self) -> VkResult<()> { - self.result_with_success(()) - } - - #[inline] - pub fn result_with_success(self, v: T) -> VkResult { - match self { - Self::SUCCESS => Ok(v), - _ => Err(self), - } - } - - #[inline] - pub unsafe fn assume_init_on_success(self, v: mem::MaybeUninit) -> VkResult { - self.result().map(move |()| v.assume_init()) - } - - #[inline] - pub unsafe fn set_vec_len_on_success(self, mut v: Vec, len: usize) -> VkResult> { - self.result().map(move |()| { - v.set_len(len); - v - }) - } -} - -/// Repeatedly calls `f` until it does not return [`vk::Result::INCOMPLETE`] anymore, ensuring all -/// available data has been read into the vector. -/// -/// See for example [`vkEnumerateInstanceExtensionProperties`]: the number of available items may -/// change between calls; [`vk::Result::INCOMPLETE`] is returned when the count increased (and the -/// vector is not large enough after querying the initial size), requiring Ash to try again. -/// -/// [`vkEnumerateInstanceExtensionProperties`]: https://registry.khronos.org/vulkan/specs/1.3-extensions/man/html/vkEnumerateInstanceExtensionProperties.html -pub(crate) unsafe fn read_into_uninitialized_vector, T>( - f: impl Fn(&mut N, *mut T) -> vk::Result, -) -> VkResult> -where - >::Error: core::fmt::Debug, -{ - loop { - let mut count = N::default(); - f(&mut count, ptr::null_mut()).result()?; - let mut data = - Vec::with_capacity(count.try_into().expect("`N` failed to convert to `usize`")); - - let err_code = f(&mut count, data.as_mut_ptr()); - if err_code != vk::Result::INCOMPLETE { - break err_code.set_vec_len_on_success( - data, - count.try_into().expect("`N` failed to convert to `usize`"), - ); - } - } -} - -#[cfg(feature = "debug")] -pub(crate) fn debug_flags + Copy>( - f: &mut core::fmt::Formatter<'_>, - known: &[(Value, &'static str)], - value: Value, -) -> core::fmt::Result { - let mut first = true; - let mut accum = value.into(); - for &(bit, name) in known { - let bit = bit.into(); - if bit != 0 && accum & bit == bit { - if !first { - f.write_str(" | ")?; - } - f.write_str(name)?; - first = false; - accum &= !bit; - } - } - if accum != 0 { - if !first { - f.write_str(" | ")?; - } - write!(f, "{accum:b}")?; - } - Ok(()) -} diff --git a/ash/src/vk.rs b/ash/src/vk.rs index 312741709..1f518112f 100644 --- a/ash/src/vk.rs +++ b/ash/src/vk.rs @@ -4,6 +4,7 @@ clippy::wrong_self_convention, unused_qualifications )] + #[macro_use] mod macros; mod aliases; @@ -23,13 +24,38 @@ pub use extensions::*; mod feature_extensions; mod features; pub use features::*; -mod prelude; -pub use prelude::*; /// Native bindings from Vulkan headers, generated by bindgen #[allow(clippy::useless_transmute, nonstandard_style)] pub mod native; mod platform_types; pub use platform_types::*; + +pub trait Handle: Sized { + const TYPE: ObjectType; + fn as_raw(self) -> u64; + fn from_raw(_: u64) -> Self; + + /// Returns whether the handle is a `NULL` value. + /// + /// # Example + /// + /// ``` + /// # use ash::vk::{Handle, Instance}; + /// let instance = Instance::null(); + /// assert!(instance.is_null()); + /// ``` + fn is_null(self) -> bool { + self.as_raw() == 0 + } +} + +/// Structures implementing this trait are layout-compatible with [`BaseInStructure`] and +/// [`aseOutStructure`]. Such structures have an `s_type` field indicating its type, which +/// must always match the value of [`TaggedStructure::STRUCTURE_TYPE`]. +pub unsafe trait TaggedStructure { + const STRUCTURE_TYPE: StructureType; +} + /// Iterates through the pointer chain. Includes the item that is passed into the function. /// Stops at the last [`BaseOutStructure`] that has a null [`BaseOutStructure::p_next`] field. pub(crate) unsafe fn ptr_chain_iter( @@ -46,21 +72,153 @@ pub(crate) unsafe fn ptr_chain_iter( Some(old) }) } -pub trait Handle: Sized { - const TYPE: ObjectType; - fn as_raw(self) -> u64; - fn from_raw(_: u64) -> Self; - /// Returns whether the handle is a `NULL` value. - /// - /// # Example - /// - /// ``` - /// # use ash::vk::{Handle, Instance}; - /// let instance = Instance::null(); - /// assert!(instance.is_null()); - /// ``` - fn is_null(self) -> bool { - self.as_raw() == 0 +#[cfg(test)] +mod tests { + use crate::vk; + use alloc::vec::Vec; + #[test] + fn test_ptr_chains() { + let mut variable_pointers = vk::PhysicalDeviceVariablePointerFeatures::default(); + let mut corner = vk::PhysicalDeviceCornerSampledImageFeaturesNV::default(); + let chain = alloc::vec![ + <*mut _>::cast(&mut variable_pointers), + <*mut _>::cast(&mut corner), + ]; + let mut device_create_info = vk::DeviceCreateInfo::default() + .push(&mut corner) + .push(&mut variable_pointers); + let chain2: Vec<*mut vk::BaseOutStructure<'_>> = unsafe { + vk::ptr_chain_iter(&mut device_create_info) + .skip(1) + .collect() + }; + assert_eq!(chain, chain2); + } +} + +/// Holds 24 bits in the least significant bits of memory, +/// and 8 bytes in the most significant bits of that memory, +/// occupying a single [`u32`] in total. This is commonly used in +/// [acceleration structure instances] such as +/// [`AccelerationStructureInstanceKHR`], +/// [`AccelerationStructureSRTMotionInstanceNV`] and +/// [`AccelerationStructureMatrixMotionInstanceNV`]. +/// +/// [acceleration structure instances]: https://registry.khronos.org/vulkan/specs/1.3-extensions/man/html/VkAccelerationStructureInstanceKHR.html#_description +#[derive(Clone, Copy, PartialEq, Eq, PartialOrd, Ord, Debug)] +#[repr(transparent)] +pub struct Packed24_8(u32); + +impl Packed24_8 { + pub fn new(low_24: u32, high_8: u8) -> Self { + Self((low_24 & 0x00ff_ffff) | (u32::from(high_8) << 24)) + } + + /// Extracts the least-significant 24 bits (3 bytes) of this integer + pub fn low_24(&self) -> u32 { + self.0 & 0xffffff + } + + /// Extracts the most significant 8 bits (single byte) of this integer + pub fn high_8(&self) -> u8 { + (self.0 >> 24) as u8 + } +} + +impl ColorComponentFlags { + /// Contraction of [`R`][Self::R] | [`G`][Self::G] | [`B`][Self::B] | [`A`][Self::A] + pub const RGBA: Self = Self(Self::R.0 | Self::G.0 | Self::B.0 | Self::A.0); +} + +impl From for Extent3D { + fn from(value: Extent2D) -> Self { + Self { + width: value.width, + height: value.height, + depth: 1, + } + } +} + +impl From for Rect2D { + fn from(extent: Extent2D) -> Self { + Self { + offset: Default::default(), + extent, + } + } +} + +#[inline] +pub(crate) fn wrap_c_str_slice_until_nul( + str: &[core::ffi::c_char], +) -> core::result::Result<&core::ffi::CStr, core::ffi::FromBytesUntilNulError> { + // SAFETY: The cast from c_char to u8 is ok because a c_char is always one byte. + let bytes = unsafe { core::slice::from_raw_parts(str.as_ptr().cast(), str.len()) }; + core::ffi::CStr::from_bytes_until_nul(bytes) +} + +#[derive(Debug)] +pub struct CStrTooLargeForStaticArray { + pub static_array_size: usize, + pub c_str_size: usize, +} +#[cfg(feature = "std")] +impl std::error::Error for CStrTooLargeForStaticArray {} +impl core::fmt::Display for CStrTooLargeForStaticArray { + fn fmt(&self, f: &mut core::fmt::Formatter<'_>) -> core::fmt::Result { + write!( + f, + "static `c_char` target array of length `{}` is too small to write a `CStr` (with `NUL`-terminator) of length `{}`", + self.static_array_size, self.c_str_size + ) + } +} + +#[inline] +pub(crate) fn write_c_str_slice_with_nul( + target: &mut [core::ffi::c_char], + str: &core::ffi::CStr, +) -> core::result::Result<(), CStrTooLargeForStaticArray> { + let bytes = str.to_bytes_with_nul(); + // SAFETY: The cast from c_char to u8 is ok because a c_char is always one byte. + let bytes = unsafe { core::slice::from_raw_parts(bytes.as_ptr().cast(), bytes.len()) }; + let static_array_size = target.len(); + target + .get_mut(..bytes.len()) + .ok_or(CStrTooLargeForStaticArray { + static_array_size, + c_str_size: bytes.len(), + })? + .copy_from_slice(bytes); + Ok(()) +} + +#[cfg(feature = "debug")] +pub(crate) fn debug_flags + Copy>( + f: &mut core::fmt::Formatter<'_>, + known: &[(Value, &'static str)], + value: Value, +) -> core::fmt::Result { + let mut first = true; + let mut accum = value.into(); + for &(bit, name) in known { + let bit = bit.into(); + if bit != 0 && accum & bit == bit { + if !first { + f.write_str(" | ")?; + } + f.write_str(name)?; + first = false; + accum &= !bit; + } + } + if accum != 0 { + if !first { + f.write_str(" | ")?; + } + write!(f, "{accum:b}")?; } + Ok(()) } diff --git a/ash/src/vk/aliases.rs b/ash/src/vk/aliases.rs index f049d0087..5f172454f 100644 --- a/ash/src/vk/aliases.rs +++ b/ash/src/vk/aliases.rs @@ -1,6 +1,6 @@ -use crate::vk::bitflags::*; -use crate::vk::definitions::*; -use crate::vk::enums::*; +use super::bitflags::*; +use super::definitions::*; +use super::enums::*; pub type GeometryFlagsNV = GeometryFlagsKHR; pub type GeometryInstanceFlagsNV = GeometryInstanceFlagsKHR; pub type BuildAccelerationStructureFlagsNV = BuildAccelerationStructureFlagsKHR; diff --git a/ash/src/vk/bitflags.rs b/ash/src/vk/bitflags.rs index c2f24094a..3809cfff1 100644 --- a/ash/src/vk/bitflags.rs +++ b/ash/src/vk/bitflags.rs @@ -1,4 +1,4 @@ -use crate::vk::definitions::*; +use super::definitions::*; #[repr(transparent)] #[derive(Clone, Copy, PartialEq, Eq, PartialOrd, Ord, Hash)] #[doc = ""] diff --git a/ash/src/vk/const_debugs.rs b/ash/src/vk/const_debugs.rs index b0d032397..5f638518d 100644 --- a/ash/src/vk/const_debugs.rs +++ b/ash/src/vk/const_debugs.rs @@ -1,7 +1,7 @@ -use crate::prelude::debug_flags; -use crate::vk::bitflags::*; -use crate::vk::definitions::*; -use crate::vk::enums::*; +use super::bitflags::*; +use super::debug_flags; +use super::definitions::*; +use super::enums::*; use core::fmt; impl fmt::Debug for AccelerationStructureBuildTypeKHR { fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { diff --git a/ash/src/vk/constants.rs b/ash/src/vk/constants.rs index 7abea7fa6..a46e34f8e 100644 --- a/ash/src/vk/constants.rs +++ b/ash/src/vk/constants.rs @@ -1,4 +1,4 @@ -use crate::vk::definitions::*; +use super::definitions::*; pub const MAX_PHYSICAL_DEVICE_NAME_SIZE: usize = 256; pub const UUID_SIZE: usize = 16; pub const LUID_SIZE: usize = 8; diff --git a/ash/src/vk/definitions.rs b/ash/src/vk/definitions.rs index 394510891..f1bb21a94 100644 --- a/ash/src/vk/definitions.rs +++ b/ash/src/vk/definitions.rs @@ -1,12 +1,14 @@ #![allow(clippy::needless_lifetimes)] -use crate::vk::aliases::*; -use crate::vk::bitflags::*; -use crate::vk::constants::*; -use crate::vk::enums::*; -use crate::vk::native::*; -use crate::vk::platform_types::*; -use crate::vk::prelude::*; -use crate::vk::{ptr_chain_iter, Handle}; +use super::aliases::*; +use super::bitflags::*; +use super::constants::*; +use super::enums::*; +use super::native::*; +use super::platform_types::*; +use super::{ + ptr_chain_iter, wrap_c_str_slice_until_nul, write_c_str_slice_with_nul, + CStrTooLargeForStaticArray, Handle, Packed24_8, TaggedStructure, +}; use core::ffi::*; use core::fmt; use core::marker::PhantomData; diff --git a/ash/src/vk/extensions.rs b/ash/src/vk/extensions.rs index 8d84a766e..0002e9a72 100644 --- a/ash/src/vk/extensions.rs +++ b/ash/src/vk/extensions.rs @@ -1,9 +1,9 @@ #![allow(unused_qualifications)] -use crate::vk::aliases::*; -use crate::vk::bitflags::*; -use crate::vk::definitions::*; -use crate::vk::enums::*; -use crate::vk::platform_types::*; +use super::aliases::*; +use super::bitflags::*; +use super::definitions::*; +use super::enums::*; +use super::platform_types::*; use core::ffi::*; #[doc = "Generated from 'VK_KHR_surface'"] impl ObjectType { diff --git a/ash/src/vk/feature_extensions.rs b/ash/src/vk/feature_extensions.rs index 4b1820c9a..f82b567bc 100644 --- a/ash/src/vk/feature_extensions.rs +++ b/ash/src/vk/feature_extensions.rs @@ -1,5 +1,5 @@ -use crate::vk::bitflags::*; -use crate::vk::enums::*; +use super::bitflags::*; +use super::enums::*; #[doc = "Generated from 'VK_VERSION_1_1'"] impl BufferCreateFlags { #[doc = "Buffer requires protected memory"] diff --git a/ash/src/vk/features.rs b/ash/src/vk/features.rs index cda77a97d..6da5d7cec 100644 --- a/ash/src/vk/features.rs +++ b/ash/src/vk/features.rs @@ -1,6 +1,6 @@ -use crate::vk::bitflags::*; -use crate::vk::definitions::*; -use crate::vk::enums::*; +use super::bitflags::*; +use super::definitions::*; +use super::enums::*; use core::ffi::*; #[allow(non_camel_case_types)] pub type PFN_vkGetInstanceProcAddr = unsafe extern "system" fn( diff --git a/ash/src/vk/prelude.rs b/ash/src/vk/prelude.rs deleted file mode 100644 index 5f77f1472..000000000 --- a/ash/src/vk/prelude.rs +++ /dev/null @@ -1,109 +0,0 @@ -use core::ffi::c_char; -use core::fmt; - -use crate::vk; - -/// Holds 24 bits in the least significant bits of memory, -/// and 8 bytes in the most significant bits of that memory, -/// occupying a single [`u32`] in total. This is commonly used in -/// [acceleration structure instances] such as -/// [`vk::AccelerationStructureInstanceKHR`], -/// [`vk::AccelerationStructureSRTMotionInstanceNV`] and -/// [`vk::AccelerationStructureMatrixMotionInstanceNV`]. -/// -/// [acceleration structure instances]: https://registry.khronos.org/vulkan/specs/1.3-extensions/man/html/VkAccelerationStructureInstanceKHR.html#_description -#[derive(Clone, Copy, PartialEq, Eq, PartialOrd, Ord, Debug)] -#[repr(transparent)] -pub struct Packed24_8(u32); - -impl Packed24_8 { - pub fn new(low_24: u32, high_8: u8) -> Self { - Self((low_24 & 0x00ff_ffff) | (u32::from(high_8) << 24)) - } - - /// Extracts the least-significant 24 bits (3 bytes) of this integer - pub fn low_24(&self) -> u32 { - self.0 & 0xffffff - } - - /// Extracts the most significant 8 bits (single byte) of this integer - pub fn high_8(&self) -> u8 { - (self.0 >> 24) as u8 - } -} - -impl vk::ColorComponentFlags { - /// Contraction of [`R`][Self::R] | [`G`][Self::G] | [`B`][Self::B] | [`A`][Self::A] - pub const RGBA: Self = Self(Self::R.0 | Self::G.0 | Self::B.0 | Self::A.0); -} - -impl From for vk::Extent3D { - fn from(value: vk::Extent2D) -> Self { - Self { - width: value.width, - height: value.height, - depth: 1, - } - } -} - -impl From for vk::Rect2D { - fn from(extent: vk::Extent2D) -> Self { - Self { - offset: Default::default(), - extent, - } - } -} - -/// Structures implementing this trait are layout-compatible with [`vk::BaseInStructure`] and -/// [`vk::BaseOutStructure`]. Such structures have an `s_type` field indicating its type, which -/// must always match the value of [`TaggedStructure::STRUCTURE_TYPE`]. -pub unsafe trait TaggedStructure { - const STRUCTURE_TYPE: vk::StructureType; -} - -#[inline] -pub(crate) fn wrap_c_str_slice_until_nul( - str: &[c_char], -) -> Result<&core::ffi::CStr, core::ffi::FromBytesUntilNulError> { - // SAFETY: The cast from c_char to u8 is ok because a c_char is always one byte. - let bytes = unsafe { core::slice::from_raw_parts(str.as_ptr().cast(), str.len()) }; - core::ffi::CStr::from_bytes_until_nul(bytes) -} - -#[derive(Debug)] -pub struct CStrTooLargeForStaticArray { - pub static_array_size: usize, - pub c_str_size: usize, -} -#[cfg(feature = "std")] -impl std::error::Error for CStrTooLargeForStaticArray {} -impl fmt::Display for CStrTooLargeForStaticArray { - fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { - write!( - f, - "static `c_char` target array of length `{}` is too small to write a `CStr` (with `NUL`-terminator) of length `{}`", - self.static_array_size, self.c_str_size - ) - } -} - -#[inline] -pub(crate) fn write_c_str_slice_with_nul( - target: &mut [c_char], - str: &core::ffi::CStr, -) -> Result<(), CStrTooLargeForStaticArray> { - let bytes = str.to_bytes_with_nul(); - // SAFETY: The cast from c_char to u8 is ok because a c_char is always one byte. - let bytes = unsafe { core::slice::from_raw_parts(bytes.as_ptr().cast(), bytes.len()) }; - let static_array_size = target.len(); - target - .get_mut(..bytes.len()) - .ok_or(CStrTooLargeForStaticArray { - static_array_size, - c_str_size: bytes.len(), - })? - .copy_from_slice(bytes); - Ok(()) -} diff --git a/generator/src/lib.rs b/generator/src/lib.rs index 9350bf383..8d2ba04df 100644 --- a/generator/src/lib.rs +++ b/generator/src/lib.rs @@ -3406,26 +3406,28 @@ pub fn write_source_code>(vk_headers_dir: &Path, src_dir: P) { let feature_code = quote! { use core::ffi::*; - use crate::vk::bitflags::*; - use crate::vk::definitions::*; - use crate::vk::enums::*; + use super::bitflags::*; + use super::definitions::*; + use super::enums::*; #(#feature_fp_code)* }; let definition_code = quote! { #![allow(clippy::needless_lifetimes)] // Omitting these correctly in the generator is complex - use core::marker::PhantomData; - use core::fmt; + use super::aliases::*; + use super::bitflags::*; + use super::constants::*; + use super::enums::*; + use super::native::*; + use super::platform_types::*; + use super::{ + ptr_chain_iter, wrap_c_str_slice_until_nul, write_c_str_slice_with_nul, + CStrTooLargeForStaticArray, Handle, Packed24_8, TaggedStructure, + }; use core::ffi::*; - use crate::vk::{Handle, ptr_chain_iter}; - use crate::vk::aliases::*; - use crate::vk::bitflags::*; - use crate::vk::constants::*; - use crate::vk::enums::*; - use crate::vk::native::*; - use crate::vk::platform_types::*; - use crate::vk::prelude::*; + use core::fmt; + use core::marker::PhantomData; #(#definition_code)* }; @@ -3436,47 +3438,47 @@ pub fn write_source_code>(vk_headers_dir: &Path, src_dir: P) { }; let bitflags_code = quote! { - use crate::vk::definitions::*; + use super::definitions::*; #(#bitflags_code)* }; let constants_code = quote! { - use crate::vk::definitions::*; + use super::definitions::*; #(#constants_code)* }; let extension_code = quote! { #![allow(unused_qualifications)] // For simplicity, we always generate absolute paths for `Device`/`Instance` + use super::platform_types::*; + use super::aliases::*; + use super::bitflags::*; + use super::definitions::*; + use super::enums::*; use core::ffi::*; - use crate::vk::platform_types::*; - use crate::vk::aliases::*; - use crate::vk::bitflags::*; - use crate::vk::definitions::*; - use crate::vk::enums::*; #(#extension_constants)* #(#extension_cmds)* }; let feature_extensions_code = quote! { - use crate::vk::bitflags::*; - use crate::vk::enums::*; + use super::bitflags::*; + use super::enums::*; #feature_extensions_code }; let const_debugs = quote! { + use super::debug_flags; + use super::bitflags::*; + use super::definitions::*; + use super::enums::*; use core::fmt; - use crate::vk::bitflags::*; - use crate::vk::definitions::*; - use crate::vk::enums::*; - use crate::prelude::debug_flags; #const_debugs }; let aliases = quote! { - use crate::vk::bitflags::*; - use crate::vk::definitions::*; - use crate::vk::enums::*; + use super::bitflags::*; + use super::definitions::*; + use super::enums::*; #(#aliases)* };