#[cfg(doc)]
use crate::{VertexAttribute, VertexBufferLayout, VertexFormat};
#[macro_export]
macro_rules! vertex_attr_array {
($($location:expr => $format:ident),* $(,)?) => {
$crate::_vertex_attr_array_helper!([] ; 0; $($location => $format ,)*)
};
}
#[doc(hidden)]
#[macro_export]
macro_rules! _vertex_attr_array_helper {
([$($t:expr,)*] ; $off:expr ;) => { [$($t,)*] };
([$($t:expr,)*] ; $off:expr ; $location:expr => $format:ident, $($ll:expr => $ii:ident ,)*) => {
$crate::_vertex_attr_array_helper!(
[$($t,)*
$crate::VertexAttribute {
format: $crate::VertexFormat :: $format,
offset: $off,
shader_location: $location,
},];
$off + $crate::VertexFormat :: $format.size();
$($ll => $ii ,)*
)
};
}
#[test]
fn test_vertex_attr_array() {
let attrs = vertex_attr_array![0 => Float32x2, 3 => Uint16x4];
assert_eq!(attrs.len(), 2);
assert_eq!(attrs[0].offset, 0);
assert_eq!(attrs[0].shader_location, 0);
assert_eq!(attrs[1].offset, size_of::<(f32, f32)>() as u64);
assert_eq!(attrs[1].shader_location, 3);
}
#[macro_export]
#[doc(hidden)]
macro_rules! include_spirv_source {
($($token:tt)*) => {
{
const SPIRV_SOURCE: [
u8;
$crate::__macro_helpers::include_bytes!($($token)*).len()
] = *$crate::__macro_helpers::include_bytes!($($token)*);
const SPIRV_LEN: usize = SPIRV_SOURCE.len() / 4;
const SPIRV_WORDS: [u32; SPIRV_LEN] = $crate::util::make_spirv_const(SPIRV_SOURCE);
&SPIRV_WORDS
}
}
}
#[test]
fn make_spirv_le_pass() {
static SPIRV: &[u32] = include_spirv_source!("le-aligned.spv");
assert_eq!(SPIRV, &[0x07230203, 0x11223344]);
}
#[test]
fn make_spirv_be_pass() {
static SPIRV: &[u32] = include_spirv_source!("be-aligned.spv");
assert_eq!(SPIRV, &[0x07230203, 0x11223344]);
}
#[macro_export]
#[cfg(feature = "spirv")]
macro_rules! include_spirv {
($($token:tt)*) => {
{
$crate::ShaderModuleDescriptor {
label: Some($($token)*),
source: $crate::ShaderSource::SpirV(
$crate::__macro_helpers::Cow::Borrowed($crate::include_spirv_source!($($token)*))
),
}
}
};
}
#[cfg(all(feature = "spirv", test))]
#[expect(dead_code)]
static SPIRV: crate::ShaderModuleDescriptor<'_> = include_spirv!("le-aligned.spv");
#[macro_export]
macro_rules! include_spirv_raw {
($($token:tt)*) => {
{
$crate::ShaderModuleDescriptorPassthrough {
label: $crate::__macro_helpers::Some($($token)*),
spirv: Some($crate::__macro_helpers::Cow::Borrowed($crate::include_spirv_source!($($token)*))),
num_workgroups: (0, 0, 0),
dxil: None,
metallib: None,
msl: None,
hlsl: None,
glsl: None,
wgsl: None,
}
}
};
}
#[cfg(test)]
#[expect(dead_code)]
static SPIRV_RAW: crate::ShaderModuleDescriptorPassthrough<'_> =
include_spirv_raw!("le-aligned.spv");
#[macro_export]
macro_rules! include_wgsl {
($($token:tt)*) => {
{
$crate::ShaderModuleDescriptor {
label: $crate::__macro_helpers::Some($($token)*),
source: $crate::ShaderSource::Wgsl($crate::__macro_helpers::Cow::Borrowed($crate::__macro_helpers::include_str!($($token)*))),
}
}
};
}
#[cfg(dx12)]
macro_rules! hal_type_dx12 {
($ty: literal) => {
concat!("- [`hal::api::Dx12`] uses [`hal::dx12::", $ty, "`]")
};
}
#[cfg(not(dx12))]
macro_rules! hal_type_dx12 {
($ty: literal) => {
concat!("- `hal::api::Dx12` uses `hal::dx12::", $ty, "`")
};
}
pub(crate) use hal_type_dx12;
#[cfg(metal)]
macro_rules! hal_type_metal {
($ty: literal) => {
concat!("- [`hal::api::Metal`] uses [`hal::metal::", $ty, "`]")
};
}
#[cfg(not(metal))]
macro_rules! hal_type_metal {
($ty: literal) => {
concat!("- `hal::api::Metal` uses `hal::metal::", $ty, "`")
};
}
pub(crate) use hal_type_metal;
#[cfg(vulkan)]
macro_rules! hal_type_vulkan {
($ty: literal) => {
concat!("- [`hal::api::Vulkan`] uses [`hal::vulkan::", $ty, "`]")
};
}
#[cfg(not(vulkan))]
macro_rules! hal_type_vulkan {
($ty: literal) => {
concat!("- `hal::api::Vulkan` uses `hal::vulkan::", $ty, "`")
};
}
pub(crate) use hal_type_vulkan;
#[cfg(gles)]
macro_rules! hal_type_gles {
($ty: literal) => {
concat!("- [`hal::api::Gles`] uses [`hal::gles::", $ty, "`]")
};
}
#[cfg(not(gles))]
macro_rules! hal_type_gles {
($ty: literal) => {
concat!("- `hal::api::Gles` uses `hal::gles::", $ty, "`")
};
}
pub(crate) use hal_type_gles;
#[doc(hidden)]
pub mod helpers {
pub use alloc::{borrow::Cow, string::String};
pub use core::{include_bytes, include_str};
pub use Some;
}