#[allow(unused_imports)]
use rafx_api::RafxResult;
#[allow(unused_imports)]
use crate::{
DescriptorSetAllocator, DescriptorSetArc, DescriptorSetBindings, DescriptorSetInitializer,
DescriptorSetWriter, DescriptorSetWriterContext, DynDescriptorSet, ImageViewResource,
ResourceArc,
};
#[derive(Copy, Clone, Debug)]
#[repr(C)]
pub struct ClearBufferConfigStd140 {
pub buffer_bytes_div_by_four: u32, pub fill_value: u32, pub num_workgroups_x: u32, pub _padding0: [u8; 4], }
impl Default for ClearBufferConfigStd140 {
fn default() -> Self {
ClearBufferConfigStd140 {
buffer_bytes_div_by_four: <u32>::default(),
fill_value: <u32>::default(),
num_workgroups_x: <u32>::default(),
_padding0: [u8::default(); 4],
}
}
}
pub type ClearBufferConfigUniform = ClearBufferConfigStd140;
pub const CONFIG_DESCRIPTOR_SET_INDEX: usize = 0;
pub const CONFIG_DESCRIPTOR_BINDING_INDEX: usize = 0;
pub const DATA_DESCRIPTOR_SET_INDEX: usize = 0;
pub const DATA_DESCRIPTOR_BINDING_INDEX: usize = 1;
pub struct DescriptorSet0Args<'a> {
pub config: &'a ClearBufferConfigUniform,
}
impl<'a> DescriptorSetInitializer<'a> for DescriptorSet0Args<'a> {
type Output = DescriptorSet0;
fn create_dyn_descriptor_set(
descriptor_set: DynDescriptorSet,
args: Self,
) -> Self::Output {
let mut descriptor = DescriptorSet0(descriptor_set);
descriptor.set_args(args);
descriptor
}
fn create_descriptor_set(
descriptor_set_allocator: &mut DescriptorSetAllocator,
descriptor_set: DynDescriptorSet,
args: Self,
) -> RafxResult<DescriptorSetArc> {
let mut descriptor = Self::create_dyn_descriptor_set(descriptor_set, args);
descriptor.0.flush(descriptor_set_allocator)?;
Ok(descriptor.0.descriptor_set().clone())
}
}
impl<'a> DescriptorSetWriter<'a> for DescriptorSet0Args<'a> {
fn write_to(
descriptor_set: &mut DescriptorSetWriterContext,
args: Self,
) {
descriptor_set.set_buffer_data(CONFIG_DESCRIPTOR_BINDING_INDEX as u32, args.config);
}
}
pub struct DescriptorSet0(pub DynDescriptorSet);
impl DescriptorSet0 {
pub fn set_args_static(
descriptor_set: &mut DynDescriptorSet,
args: DescriptorSet0Args,
) {
descriptor_set.set_buffer_data(CONFIG_DESCRIPTOR_BINDING_INDEX as u32, args.config);
}
pub fn set_args(
&mut self,
args: DescriptorSet0Args,
) {
self.set_config(args.config);
}
pub fn set_config(
&mut self,
config: &ClearBufferConfigUniform,
) {
self.0
.set_buffer_data(CONFIG_DESCRIPTOR_BINDING_INDEX as u32, config);
}
pub fn flush(
&mut self,
descriptor_set_allocator: &mut DescriptorSetAllocator,
) -> RafxResult<()> {
self.0.flush(descriptor_set_allocator)
}
}
#[cfg(test)]
mod test {
use super::*;
#[test]
fn test_struct_clear_buffer_config_std140() {
assert_eq!(std::mem::size_of::<ClearBufferConfigStd140>(), 16);
assert_eq!(std::mem::size_of::<u32>(), 4);
assert_eq!(std::mem::align_of::<u32>(), 4);
assert_eq!(
memoffset::offset_of!(ClearBufferConfigStd140, buffer_bytes_div_by_four),
0
);
assert_eq!(std::mem::size_of::<u32>(), 4);
assert_eq!(std::mem::align_of::<u32>(), 4);
assert_eq!(
memoffset::offset_of!(ClearBufferConfigStd140, fill_value),
4
);
assert_eq!(std::mem::size_of::<u32>(), 4);
assert_eq!(std::mem::align_of::<u32>(), 4);
assert_eq!(
memoffset::offset_of!(ClearBufferConfigStd140, num_workgroups_x),
8
);
assert_eq!(std::mem::size_of::<[u8; 4]>(), 4);
assert_eq!(std::mem::align_of::<[u8; 4]>(), 1);
assert_eq!(
memoffset::offset_of!(ClearBufferConfigStd140, _padding0),
12
);
}
}