From fca01159ab3470c0f348ff26536e6ae494f98f30 Mon Sep 17 00:00:00 2001 From: i509VCB Date: Sat, 6 May 2023 14:25:42 -0500 Subject: [PATCH] Add `Handle::is_null()` (#694) --- Changelog.md | 1 + ash/src/vk.rs | 15 ++++++++++++++- 2 files changed, 15 insertions(+), 1 deletion(-) diff --git a/Changelog.md b/Changelog.md index e16305c..7fcef9e 100644 --- a/Changelog.md +++ b/Changelog.md @@ -10,6 +10,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 ### Added - Added `VK_EXT_pipeline_properties` device extension (#622) +- Added `Handle::is_null()` to allow checking if a handle is a `NULL` value (#694) - Update Vulkan-Headers to 1.3.246 (#697, #723) - Added `VK_KHR_performance_query` device extension (#726) - Added `VK_EXT_shader_object` device extension (#732) diff --git a/ash/src/vk.rs b/ash/src/vk.rs index 02a5e9c..c145e7f 100644 --- a/ash/src/vk.rs +++ b/ash/src/vk.rs @@ -45,8 +45,21 @@ pub(crate) unsafe fn ptr_chain_iter(ptr: &mut T) -> impl Iterator 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 + } }