Merge pull request #32 from msiglreith/clear_attachments
Clear attachments command and Copy derives
This commit is contained in:
commit
37dfc190a5
2 changed files with 42 additions and 27 deletions
|
@ -563,6 +563,21 @@ pub trait DeviceV1_0 {
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
unsafe fn cmd_clear_attachments(
|
||||||
|
&self,
|
||||||
|
command_buffer: vk::CommandBuffer,
|
||||||
|
attachments: &[vk::ClearAttachment],
|
||||||
|
rects: &[vk::ClearRect],
|
||||||
|
) {
|
||||||
|
self.fp_v1_0().cmd_clear_attachments(
|
||||||
|
command_buffer,
|
||||||
|
attachments.len() as vk::uint32_t,
|
||||||
|
attachments.as_ptr(),
|
||||||
|
rects.len() as vk::uint32_t,
|
||||||
|
rects.as_ptr(),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
unsafe fn cmd_draw_indexed(
|
unsafe fn cmd_draw_indexed(
|
||||||
&self,
|
&self,
|
||||||
command_buffer: vk::CommandBuffer,
|
command_buffer: vk::CommandBuffer,
|
||||||
|
|
|
@ -433,7 +433,7 @@ pub mod types {
|
||||||
pub inherited_queries: Bool32,
|
pub inherited_queries: Bool32,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Debug, Clone, Hash)]
|
#[derive(Debug, Clone, Copy, Hash)]
|
||||||
#[repr(C)]
|
#[repr(C)]
|
||||||
pub struct FormatProperties {
|
pub struct FormatProperties {
|
||||||
pub linear_tiling_features: FormatFeatureFlags,
|
pub linear_tiling_features: FormatFeatureFlags,
|
||||||
|
@ -441,7 +441,7 @@ pub mod types {
|
||||||
pub buffer_features: FormatFeatureFlags,
|
pub buffer_features: FormatFeatureFlags,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Debug, Clone, Hash)]
|
#[derive(Debug, Clone, Copy, Hash)]
|
||||||
#[repr(C)]
|
#[repr(C)]
|
||||||
pub struct ImageFormatProperties {
|
pub struct ImageFormatProperties {
|
||||||
pub max_extent: Extent3D,
|
pub max_extent: Extent3D,
|
||||||
|
@ -451,7 +451,7 @@ pub mod types {
|
||||||
pub max_resource_size: DeviceSize,
|
pub max_resource_size: DeviceSize,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Debug, Clone, PartialEq, Eq, Hash)]
|
#[derive(Debug, Clone, Copy, PartialEq, Eq, Hash)]
|
||||||
#[repr(C)]
|
#[repr(C)]
|
||||||
pub struct Extent3D {
|
pub struct Extent3D {
|
||||||
pub width: uint32_t,
|
pub width: uint32_t,
|
||||||
|
@ -1341,7 +1341,7 @@ pub mod types {
|
||||||
pub size: DeviceSize,
|
pub size: DeviceSize,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Debug, Clone, Hash)]
|
#[derive(Debug, Clone, Copy, Hash)]
|
||||||
#[repr(C)]
|
#[repr(C)]
|
||||||
pub struct MemoryRequirements {
|
pub struct MemoryRequirements {
|
||||||
pub size: DeviceSize,
|
pub size: DeviceSize,
|
||||||
|
@ -1429,7 +1429,7 @@ pub mod types {
|
||||||
pub flags: SparseMemoryBindFlags,
|
pub flags: SparseMemoryBindFlags,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Debug, Clone, Hash)]
|
#[derive(Debug, Clone, Copy, Hash)]
|
||||||
#[repr(C)]
|
#[repr(C)]
|
||||||
pub struct ImageSubresource {
|
pub struct ImageSubresource {
|
||||||
pub aspect_mask: ImageAspectFlags,
|
pub aspect_mask: ImageAspectFlags,
|
||||||
|
@ -1437,7 +1437,7 @@ pub mod types {
|
||||||
pub array_layer: uint32_t,
|
pub array_layer: uint32_t,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Debug, Clone, Hash)]
|
#[derive(Debug, Clone, Copy, Hash)]
|
||||||
#[repr(C)]
|
#[repr(C)]
|
||||||
pub struct Offset3D {
|
pub struct Offset3D {
|
||||||
pub x: int32_t,
|
pub x: int32_t,
|
||||||
|
@ -1525,7 +1525,7 @@ pub mod types {
|
||||||
pub initial_layout: ImageLayout,
|
pub initial_layout: ImageLayout,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Debug, Clone, Hash)]
|
#[derive(Debug, Clone, Copy, Hash)]
|
||||||
#[repr(C)]
|
#[repr(C)]
|
||||||
pub struct SubresourceLayout {
|
pub struct SubresourceLayout {
|
||||||
pub offset: DeviceSize,
|
pub offset: DeviceSize,
|
||||||
|
@ -1548,7 +1548,7 @@ pub mod types {
|
||||||
pub subresource_range: ImageSubresourceRange,
|
pub subresource_range: ImageSubresourceRange,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Debug, Clone, Hash)]
|
#[derive(Debug, Clone, Copy, Hash)]
|
||||||
#[repr(C)]
|
#[repr(C)]
|
||||||
pub struct ComponentMapping {
|
pub struct ComponentMapping {
|
||||||
pub r: ComponentSwizzle,
|
pub r: ComponentSwizzle,
|
||||||
|
@ -1700,7 +1700,7 @@ pub mod types {
|
||||||
pub p_scissors: *const Rect2D,
|
pub p_scissors: *const Rect2D,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Debug, Clone)]
|
#[derive(Debug, Clone, Copy)]
|
||||||
#[repr(C)]
|
#[repr(C)]
|
||||||
pub struct Viewport {
|
pub struct Viewport {
|
||||||
pub x: c_float,
|
pub x: c_float,
|
||||||
|
@ -1711,21 +1711,21 @@ pub mod types {
|
||||||
pub max_depth: c_float,
|
pub max_depth: c_float,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Debug, Clone, Hash)]
|
#[derive(Debug, Clone, Copy, Hash)]
|
||||||
#[repr(C)]
|
#[repr(C)]
|
||||||
pub struct Rect2D {
|
pub struct Rect2D {
|
||||||
pub offset: Offset2D,
|
pub offset: Offset2D,
|
||||||
pub extent: Extent2D,
|
pub extent: Extent2D,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Debug, Clone, Hash)]
|
#[derive(Debug, Clone, Copy, Hash)]
|
||||||
#[repr(C)]
|
#[repr(C)]
|
||||||
pub struct Offset2D {
|
pub struct Offset2D {
|
||||||
pub x: int32_t,
|
pub x: int32_t,
|
||||||
pub y: int32_t,
|
pub y: int32_t,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Debug, Clone, Hash)]
|
#[derive(Debug, Clone, Copy, Hash)]
|
||||||
#[repr(C)]
|
#[repr(C)]
|
||||||
pub struct Extent2D {
|
pub struct Extent2D {
|
||||||
pub width: uint32_t,
|
pub width: uint32_t,
|
||||||
|
@ -1781,7 +1781,7 @@ pub mod types {
|
||||||
pub max_depth_bounds: c_float,
|
pub max_depth_bounds: c_float,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Debug, Clone)]
|
#[derive(Debug, Clone, Copy)]
|
||||||
#[repr(C)]
|
#[repr(C)]
|
||||||
pub struct StencilOpState {
|
pub struct StencilOpState {
|
||||||
pub fail_op: StencilOp,
|
pub fail_op: StencilOp,
|
||||||
|
@ -1890,7 +1890,7 @@ pub mod types {
|
||||||
pub p_push_constant_ranges: *const PushConstantRange,
|
pub p_push_constant_ranges: *const PushConstantRange,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Debug, Clone, Hash)]
|
#[derive(Debug, Clone, Copy, Hash)]
|
||||||
#[repr(C)]
|
#[repr(C)]
|
||||||
pub struct PushConstantRange {
|
pub struct PushConstantRange {
|
||||||
pub stage_flags: ShaderStageFlags,
|
pub stage_flags: ShaderStageFlags,
|
||||||
|
@ -1952,7 +1952,7 @@ pub mod types {
|
||||||
pub p_pool_sizes: *const DescriptorPoolSize,
|
pub p_pool_sizes: *const DescriptorPoolSize,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Debug, Clone, Hash)]
|
#[derive(Debug, Clone, Copy, Hash)]
|
||||||
#[repr(C)]
|
#[repr(C)]
|
||||||
pub struct DescriptorPoolSize {
|
pub struct DescriptorPoolSize {
|
||||||
pub typ: DescriptorType,
|
pub typ: DescriptorType,
|
||||||
|
@ -2131,7 +2131,7 @@ pub mod types {
|
||||||
pub pipeline_statistics: QueryPipelineStatisticFlags,
|
pub pipeline_statistics: QueryPipelineStatisticFlags,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Debug, Clone, Hash)]
|
#[derive(Debug, Clone, Copy, Hash)]
|
||||||
#[repr(C)]
|
#[repr(C)]
|
||||||
pub struct BufferCopy {
|
pub struct BufferCopy {
|
||||||
pub src_offset: DeviceSize,
|
pub src_offset: DeviceSize,
|
||||||
|
@ -2139,7 +2139,7 @@ pub mod types {
|
||||||
pub size: DeviceSize,
|
pub size: DeviceSize,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Debug, Clone, Hash)]
|
#[derive(Debug, Clone, Copy, Hash)]
|
||||||
#[repr(C)]
|
#[repr(C)]
|
||||||
pub struct ImageCopy {
|
pub struct ImageCopy {
|
||||||
pub src_subresource: ImageSubresourceLayers,
|
pub src_subresource: ImageSubresourceLayers,
|
||||||
|
@ -2149,7 +2149,7 @@ pub mod types {
|
||||||
pub extent: Extent3D,
|
pub extent: Extent3D,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Debug, Clone, Hash)]
|
#[derive(Debug, Clone, Copy, Hash)]
|
||||||
#[repr(C)]
|
#[repr(C)]
|
||||||
pub struct ImageSubresourceLayers {
|
pub struct ImageSubresourceLayers {
|
||||||
pub aspect_mask: ImageAspectFlags,
|
pub aspect_mask: ImageAspectFlags,
|
||||||
|
@ -2204,7 +2204,7 @@ pub mod types {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Debug, Clone, Hash)]
|
#[derive(Debug, Clone, Copy, Hash)]
|
||||||
#[repr(C)]
|
#[repr(C)]
|
||||||
pub struct BufferImageCopy {
|
pub struct BufferImageCopy {
|
||||||
pub buffer_offset: DeviceSize,
|
pub buffer_offset: DeviceSize,
|
||||||
|
@ -2215,14 +2215,14 @@ pub mod types {
|
||||||
pub image_extent: Extent3D,
|
pub image_extent: Extent3D,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Debug, Clone)]
|
#[derive(Debug, Clone, Copy)]
|
||||||
#[repr(C)]
|
#[repr(C)]
|
||||||
pub struct ClearDepthStencilValue {
|
pub struct ClearDepthStencilValue {
|
||||||
pub depth: c_float,
|
pub depth: c_float,
|
||||||
pub stencil: uint32_t,
|
pub stencil: uint32_t,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Debug, Clone, Hash)]
|
#[derive(Debug, Clone, Copy, Hash)]
|
||||||
#[repr(C)]
|
#[repr(C)]
|
||||||
pub struct ClearAttachment {
|
pub struct ClearAttachment {
|
||||||
pub aspect_mask: ImageAspectFlags,
|
pub aspect_mask: ImageAspectFlags,
|
||||||
|
@ -2230,7 +2230,7 @@ pub mod types {
|
||||||
pub clear_value: ClearValue,
|
pub clear_value: ClearValue,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Debug, Clone, Hash)]
|
#[derive(Debug, Clone, Copy, Hash)]
|
||||||
#[repr(C)]
|
#[repr(C)]
|
||||||
pub struct ClearRect {
|
pub struct ClearRect {
|
||||||
pub rect: Rect2D,
|
pub rect: Rect2D,
|
||||||
|
@ -2238,7 +2238,7 @@ pub mod types {
|
||||||
pub layer_count: uint32_t,
|
pub layer_count: uint32_t,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Debug, Clone, Hash)]
|
#[derive(Debug, Clone, Copy, Hash)]
|
||||||
#[repr(C)]
|
#[repr(C)]
|
||||||
pub struct ImageResolve {
|
pub struct ImageResolve {
|
||||||
pub src_subresource: ImageSubresourceLayers,
|
pub src_subresource: ImageSubresourceLayers,
|
||||||
|
@ -2298,7 +2298,7 @@ pub mod types {
|
||||||
pub p_clear_values: *const ClearValue,
|
pub p_clear_values: *const ClearValue,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Debug, Clone)]
|
#[derive(Debug, Clone, Copy)]
|
||||||
#[repr(C)]
|
#[repr(C)]
|
||||||
pub struct DispatchIndirectCommand {
|
pub struct DispatchIndirectCommand {
|
||||||
pub x: uint32_t,
|
pub x: uint32_t,
|
||||||
|
@ -2306,7 +2306,7 @@ pub mod types {
|
||||||
pub z: uint32_t,
|
pub z: uint32_t,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Debug, Clone)]
|
#[derive(Debug, Clone, Copy)]
|
||||||
#[repr(C)]
|
#[repr(C)]
|
||||||
pub struct DrawIndexedIndirectCommand {
|
pub struct DrawIndexedIndirectCommand {
|
||||||
pub index_count: uint32_t,
|
pub index_count: uint32_t,
|
||||||
|
@ -2316,7 +2316,7 @@ pub mod types {
|
||||||
pub first_instance: uint32_t,
|
pub first_instance: uint32_t,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Debug, Clone)]
|
#[derive(Debug, Clone, Copy)]
|
||||||
#[repr(C)]
|
#[repr(C)]
|
||||||
pub struct DrawIndirectCommand {
|
pub struct DrawIndirectCommand {
|
||||||
pub vertex_count: uint32_t,
|
pub vertex_count: uint32_t,
|
||||||
|
@ -2625,7 +2625,7 @@ pub mod types {
|
||||||
|
|
||||||
/// Temporary Hard-Coded union hack; will be automatically generated when actual unions become stable
|
/// Temporary Hard-Coded union hack; will be automatically generated when actual unions become stable
|
||||||
#[repr(C)]
|
#[repr(C)]
|
||||||
#[derive(Debug, Clone, Hash)]
|
#[derive(Debug, Clone, Copy, Hash)]
|
||||||
pub struct ClearValue {
|
pub struct ClearValue {
|
||||||
data: [u8; 16],
|
data: [u8; 16],
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue