diff --git a/.cargo/config.toml b/.cargo/config.toml index 99eede00d8..daaafd8c8d 100644 --- a/.cargo/config.toml +++ b/.cargo/config.toml @@ -5,4 +5,3 @@ run-wasm = "run --release --package run-wasm --" rustflags = [ "--cfg=web_sys_unstable_apis" ] -target = "wasm32-unknown-unknown" diff --git a/CHANGELOG.md b/CHANGELOG.md index 70c2c791a6..4264429f04 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -115,6 +115,7 @@ Additionally `Surface::get_default_config` now returns an Option and returns Non - Make `Surface::get_default_config` return an Option to prevent panics. By @cwfitzgerald in [#3157](https://github.com/gfx-rs/wgpu/pull/3157) - Lower the `max_buffer_size` limit value for compatibility with Apple2 and WebGPU compliance. By @jinleili in [#3255](https://github.com/gfx-rs/wgpu/pull/3255) - Dereferencing a buffer view is now marked inline. By @Wumpf in [#3307](https://github.com/gfx-rs/wgpu/pull/3307) +- The `strict_assert` family of macros was moved to `wgpu-types`. By @i509VCB in [#3051](https://github.com/gfx-rs/wgpu/pull/3051) #### WebGPU diff --git a/wgpu-core/Cargo.toml b/wgpu-core/Cargo.toml index fb7c90d5ec..bc2c212fc7 100644 --- a/wgpu-core/Cargo.toml +++ b/wgpu-core/Cargo.toml @@ -34,7 +34,7 @@ emscripten = ["hal/emscripten"] # Apply run-time checks, even in release builds. These are in addition # to the validation carried out at public APIs in all builds. -strict_asserts = [] +strict_asserts = ["wgt/strict_asserts"] angle = ["hal/gles"] # Enable API tracing trace = ["ron", "serde", "wgt/trace", "arrayvec/serde", "naga/serialize"] diff --git a/wgpu-core/src/lib.rs b/wgpu-core/src/lib.rs index c8b3fb7296..ff9f3d4b65 100644 --- a/wgpu-core/src/lib.rs +++ b/wgpu-core/src/lib.rs @@ -35,9 +35,6 @@ clippy::pattern_type_mismatch, )] -#[macro_use] -mod assertions; - pub mod binding_model; pub mod command; mod conv; diff --git a/wgpu-core/src/track/buffer.rs b/wgpu-core/src/track/buffer.rs index 65f02c467d..b7682968b2 100644 --- a/wgpu-core/src/track/buffer.rs +++ b/wgpu-core/src/track/buffer.rs @@ -19,6 +19,7 @@ use crate::{ LifeGuard, RefCount, }; use hal::BufferUses; +use wgt::{strict_assert, strict_assert_eq}; impl ResourceUses for BufferUses { const EXCLUSIVE: Self = Self::EXCLUSIVE; diff --git a/wgpu-core/src/track/metadata.rs b/wgpu-core/src/track/metadata.rs index 728ff5ca0e..73da0d6c5d 100644 --- a/wgpu-core/src/track/metadata.rs +++ b/wgpu-core/src/track/metadata.rs @@ -7,6 +7,7 @@ use crate::{ }; use bit_vec::BitVec; use std::{borrow::Cow, marker::PhantomData, mem}; +use wgt::strict_assert; /// A set of resources, holding a [`RefCount`] and epoch for each member. /// diff --git a/wgpu-core/src/track/mod.rs b/wgpu-core/src/track/mod.rs index 9d85e1ab7b..4fdb64850c 100644 --- a/wgpu-core/src/track/mod.rs +++ b/wgpu-core/src/track/mod.rs @@ -114,6 +114,7 @@ pub(crate) use stateless::{StatelessBindGroupSate, StatelessTracker}; pub(crate) use texture::{ TextureBindGroupState, TextureSelector, TextureTracker, TextureUsageScope, }; +use wgt::strict_assert_ne; /// A structure containing all the information about a particular resource /// transition. User code should be able to generate a pipeline barrier diff --git a/wgpu-core/src/track/texture.rs b/wgpu-core/src/track/texture.rs index 635a7cecaf..6db2bab725 100644 --- a/wgpu-core/src/track/texture.rs +++ b/wgpu-core/src/track/texture.rs @@ -34,6 +34,7 @@ use hal::TextureUses; use arrayvec::ArrayVec; use naga::FastHashMap; +use wgt::{strict_assert, strict_assert_eq}; use std::{borrow::Cow, iter, marker::PhantomData, ops::Range, vec::Drain}; diff --git a/wgpu-types/Cargo.toml b/wgpu-types/Cargo.toml index 4b608b472f..c6b1ed6aa9 100644 --- a/wgpu-types/Cargo.toml +++ b/wgpu-types/Cargo.toml @@ -18,6 +18,7 @@ rustdoc-args = ["--cfg", "docsrs"] [features] trace = ["serde"] replay = ["serde"] +strict_asserts = [] [dependencies] bitflags = "1" diff --git a/wgpu-types/src/assertions.rs b/wgpu-types/src/assertions.rs index e69de29bb2..87b4de33ef 100644 --- a/wgpu-types/src/assertions.rs +++ b/wgpu-types/src/assertions.rs @@ -0,0 +1,66 @@ +//! Macros for validation internal to the wgpu. +//! +//! This module defines assertion macros that respect `wgpu-type`'s +//! `"strict_asserts"` feature. +//! +//! Because `wgpu-core`'s public APIs validate their arguments in all +//! types of builds, for performance, the `track` module skips some of +//! Rust's usual run-time checks on its internal operations in release +//! builds. However, some `wgpu-core` applications have a strong +//! preference for robustness over performance. To accommodate them, +//! `wgpu-core`'s `"strict_asserts"` feature enables that validation +//! in both debug and release builds. + +/// This is equivalent to [`std::assert`] if the `strict_asserts` feature is activated. +#[cfg(feature = "strict_asserts")] +#[macro_export] +macro_rules! strict_assert { + ( $( $arg:tt )* ) => { + assert!( $( $arg )* ) + } +} + +/// This is equivalent to [`std::assert_eq`] if the `strict_asserts` feature is activated. +#[cfg(feature = "strict_asserts")] +#[macro_export] +macro_rules! strict_assert_eq { + ( $( $arg:tt )* ) => { + assert_eq!( $( $arg )* ) + } +} + +/// This is equivalent to [`std::assert_ne`] if the `strict_asserts` feature is activated. +#[cfg(feature = "strict_asserts")] +#[macro_export] +macro_rules! strict_assert_ne { + ( $( $arg:tt )* ) => { + assert_ne!( $( $arg )* ) + } +} + +/// This is equivalent to [`std::assert`] if the `strict_asserts` feature is activated. +#[cfg(not(feature = "strict_asserts"))] +#[macro_export] +macro_rules! strict_assert { + ( $( $arg:tt )* ) => { + debug_assert!( $( $arg )* ) + }; +} + +/// This is equivalent to [`std::assert_eq`] if the `strict_asserts` feature is activated. +#[cfg(not(feature = "strict_asserts"))] +#[macro_export] +macro_rules! strict_assert_eq { + ( $( $arg:tt )* ) => { + debug_assert_eq!( $( $arg )* ) + }; +} + +/// This is equivalent to [`std::assert_ne`] if the `strict_asserts` feature is activated. +#[cfg(not(feature = "strict_asserts"))] +#[macro_export] +macro_rules! strict_assert_ne { + ( $( $arg:tt )* ) => { + debug_assert_ne!( $( $arg )* ) + }; +} diff --git a/wgpu-types/src/lib.rs b/wgpu-types/src/lib.rs index 82ffaf31f3..4d648f45e9 100644 --- a/wgpu-types/src/lib.rs +++ b/wgpu-types/src/lib.rs @@ -14,6 +14,8 @@ use serde::{Deserialize, Serialize}; use std::hash::{Hash, Hasher}; use std::{num::NonZeroU32, ops::Range}; +mod assertions; + // Use this macro instead of the one provided by the bitflags_serde_shim crate // because the latter produces an error when deserializing bits that are not // specified in the bitflags, while we want deserialization to succeed and diff --git a/wgpu/Cargo.toml b/wgpu/Cargo.toml index 7da719dd3d..0e1c259518 100644 --- a/wgpu/Cargo.toml +++ b/wgpu/Cargo.toml @@ -79,7 +79,7 @@ test = true default = ["wgsl", "expose-ids", "strict_asserts"] # Apply run-time checks, even in release builds. These are in addition # to the validation carried out at public APIs in all builds. -strict_asserts = ["wgc/strict_asserts"] +strict_asserts = ["wgc/strict_asserts", "wgt/strict_asserts"] spirv = ["naga/spv-in"] glsl = ["naga/glsl-in"] wgsl = ["wgc?/wgsl"] diff --git a/wgpu/src/assertions.rs b/wgpu/src/assertions.rs deleted file mode 100644 index e34cb728c3..0000000000 --- a/wgpu/src/assertions.rs +++ /dev/null @@ -1,50 +0,0 @@ -// TODO: Do not merge without docs -#![allow(missing_docs)] - -#[cfg(feature = "strict_asserts")] -#[macro_export] -macro_rules! strict_assert { - ( $( $arg:tt )* ) => { - assert!( $( $arg )* ) - } -} - -#[cfg(feature = "strict_asserts")] -#[macro_export] -macro_rules! strict_assert_eq { - ( $( $arg:tt )* ) => { - assert_eq!( $( $arg )* ) - } -} - -#[cfg(feature = "strict_asserts")] -#[macro_export] -macro_rules! strict_assert_ne { - ( $( $arg:tt )* ) => { - assert_ne!( $( $arg )* ) - } -} - -#[cfg(not(feature = "strict_asserts"))] -#[macro_export] -macro_rules! strict_assert { - ( $( $arg:tt )* ) => { - debug_assert!( $( $arg )* ) - }; -} - -#[cfg(not(feature = "strict_asserts"))] -#[macro_export] -macro_rules! strict_assert_eq { - ( $( $arg:tt )* ) => { - debug_assert_eq!( $( $arg )* ) - }; -} - -#[cfg(not(feature = "strict_asserts"))] -#[macro_export] -macro_rules! strict_assert_ne { - ( $( $arg:tt )* ) => { - debug_assert_ne!( $( $arg )* ) - }; -} diff --git a/wgpu/src/context.rs b/wgpu/src/context.rs index e40897d27d..94e247ffc6 100644 --- a/wgpu/src/context.rs +++ b/wgpu/src/context.rs @@ -3,9 +3,9 @@ use std::{ }; use wgt::{ - AdapterInfo, BufferAddress, BufferSize, Color, DownlevelCapabilities, DynamicOffset, Extent3d, - Features, ImageDataLayout, ImageSubresourceRange, IndexFormat, Limits, ShaderStages, - SurfaceConfiguration, SurfaceStatus, TextureFormat, TextureFormatFeatures, + strict_assert, AdapterInfo, BufferAddress, BufferSize, Color, DownlevelCapabilities, + DynamicOffset, Extent3d, Features, ImageDataLayout, ImageSubresourceRange, IndexFormat, Limits, + ShaderStages, SurfaceConfiguration, SurfaceStatus, TextureFormat, TextureFormatFeatures, }; use crate::{ diff --git a/wgpu/src/lib.rs b/wgpu/src/lib.rs index 57a3227aef..38f32e2668 100644 --- a/wgpu/src/lib.rs +++ b/wgpu/src/lib.rs @@ -6,8 +6,6 @@ #![doc(html_logo_url = "https://raw.githubusercontent.com/gfx-rs/wgpu/master/logo.png")] #![warn(missing_docs, unsafe_op_in_unsafe_fn)] -#[macro_use] -mod assertions; mod backend; mod context; pub mod util;