gpu: implement BindGroup

Signed-off-by: Stephen Gutekanst <stephen@hexops.com>
This commit is contained in:
Stephen Gutekanst 2022-03-10 00:15:23 -07:00 committed by Stephen Gutekanst
parent 9162a8136f
commit 3d3fdcde0d
3 changed files with 25 additions and 1 deletions

View file

@ -31,6 +31,7 @@ const QuerySet = @import("QuerySet.zig");
const PipelineLayout = @import("PipelineLayout.zig"); const PipelineLayout = @import("PipelineLayout.zig");
const ExternalTexture = @import("ExternalTexture.zig"); const ExternalTexture = @import("ExternalTexture.zig");
const BindGroup = @import("BindGroup.zig"); const BindGroup = @import("BindGroup.zig");
const BindGroupLayout = @import("BindGroupLayout.zig");
const TextureUsage = @import("enums.zig").TextureUsage; const TextureUsage = @import("enums.zig").TextureUsage;
const TextureFormat = @import("enums.zig").TextureFormat; const TextureFormat = @import("enums.zig").TextureFormat;
@ -728,6 +729,26 @@ const bind_group_vtable = BindGroup.VTable{
}).release, }).release,
}; };
fn wrapBindGroupLayout(layout: c.WGPUBindGroupLayout) BindGroupLayout {
return .{
.ptr = layout.?,
.vtable = &bind_group_layout_vtable,
};
}
const bind_group_layout_vtable = BindGroupLayout.VTable{
.reference = (struct {
pub fn reference(ptr: *anyopaque) void {
c.wgpuBindGroupLayoutReference(@ptrCast(c.WGPUBindGroupLayout, ptr));
}
}).reference,
.release = (struct {
pub fn release(ptr: *anyopaque) void {
c.wgpuBindGroupLayoutRelease(@ptrCast(c.WGPUBindGroupLayout, ptr));
}
}).release,
};
test "syntax" { test "syntax" {
_ = wrap; _ = wrap;
_ = interface_vtable; _ = interface_vtable;
@ -752,4 +773,5 @@ test "syntax" {
_ = wrapPipelineLayout; _ = wrapPipelineLayout;
_ = wrapExternalTexture; _ = wrapExternalTexture;
_ = wrapBindGroup; _ = wrapBindGroup;
_ = wrapBindGroupLayout;
} }

View file

@ -46,6 +46,7 @@ pub const QuerySet = @import("QuerySet.zig");
pub const PipelineLayout = @import("PipelineLayout.zig"); pub const PipelineLayout = @import("PipelineLayout.zig");
pub const ExternalTexture = @import("ExternalTexture.zig"); pub const ExternalTexture = @import("ExternalTexture.zig");
pub const BindGroup = @import("BindGroup.zig"); pub const BindGroup = @import("BindGroup.zig");
pub const BindGroupLayout = @import("BindGroupLayout.zig");
pub const Feature = @import("enums.zig").Feature; pub const Feature = @import("enums.zig").Feature;
pub const TextureUsage = @import("enums.zig").TextureUsage; pub const TextureUsage = @import("enums.zig").TextureUsage;
@ -116,6 +117,7 @@ test "syntax" {
_ = PipelineLayout; _ = PipelineLayout;
_ = ExternalTexture; _ = ExternalTexture;
_ = BindGroup; _ = BindGroup;
_ = BindGroupLayout;
_ = Feature; _ = Feature;
} }