gpu: implement PipelineLayout

Signed-off-by: Stephen Gutekanst <stephen@hexops.com>
This commit is contained in:
Stephen Gutekanst 2022-03-09 23:42:34 -07:00 committed by Stephen Gutekanst
parent a7667972a2
commit 88e1894fbd
3 changed files with 51 additions and 0 deletions

View file

@ -28,6 +28,7 @@ const RenderPassEncoder = @import("RenderPassEncoder.zig");
const RenderBundleEncoder = @import("RenderBundleEncoder.zig"); const RenderBundleEncoder = @import("RenderBundleEncoder.zig");
const RenderBundle = @import("RenderBundle.zig"); const RenderBundle = @import("RenderBundle.zig");
const QuerySet = @import("QuerySet.zig"); const QuerySet = @import("QuerySet.zig");
const PipelineLayout = @import("PipelineLayout.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;
@ -665,6 +666,26 @@ const query_set_vtable = QuerySet.VTable{
}).release, }).release,
}; };
fn wrapPipelineLayout(layout: c.WGPUPipelineLayout) PipelineLayout {
return .{
.ptr = layout.?,
.vtable = &pipeline_layout_vtable,
};
}
const pipeline_layout_vtable = PipelineLayout.VTable{
.reference = (struct {
pub fn reference(ptr: *anyopaque) void {
c.wgpuPipelineLayoutReference(@ptrCast(c.WGPUPipelineLayout, ptr));
}
}).reference,
.release = (struct {
pub fn release(ptr: *anyopaque) void {
c.wgpuPipelineLayoutRelease(@ptrCast(c.WGPUPipelineLayout, ptr));
}
}).release,
};
test "syntax" { test "syntax" {
_ = wrap; _ = wrap;
_ = interface_vtable; _ = interface_vtable;
@ -686,4 +707,5 @@ test "syntax" {
_ = wrapRenderBundleEncoder; _ = wrapRenderBundleEncoder;
_ = wrapRenderBundle; _ = wrapRenderBundle;
_ = wrapQuerySet; _ = wrapQuerySet;
_ = wrapPipelineLayout;
} }

View file

@ -0,0 +1,27 @@
const PipelineLayout = @This();
/// The type erased pointer to the PipelineLayout implementation
/// Equal to c.WGPUPipelineLayout for NativeInstance.
ptr: *anyopaque,
vtable: *const VTable,
pub const VTable = struct {
reference: fn (ptr: *anyopaque) void,
release: fn (ptr: *anyopaque) void,
// TODO:
// WGPU_EXPORT void wgpuPipelineLayoutSetLabel(WGPUPipelineLayout pipelineLayout, char const * label);
};
pub inline fn reference(qset: PipelineLayout) void {
qset.vtable.reference(qset.ptr);
}
pub inline fn release(qset: PipelineLayout) void {
qset.vtable.release(qset.ptr);
}
test "syntax" {
_ = VTable;
_ = reference;
_ = release;
}

View file

@ -43,6 +43,7 @@ pub const RenderPassEncoder = @import("RenderPassEncoder.zig");
pub const RenderBundleEncoder = @import("RenderBundleEncoder.zig"); pub const RenderBundleEncoder = @import("RenderBundleEncoder.zig");
pub const RenderBundle = @import("RenderBundle.zig"); pub const RenderBundle = @import("RenderBundle.zig");
pub const QuerySet = @import("QuerySet.zig"); pub const QuerySet = @import("QuerySet.zig");
pub const PipelineLayout = @import("PipelineLayout.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;
@ -110,6 +111,7 @@ test "syntax" {
_ = RenderBundleEncoder; _ = RenderBundleEncoder;
_ = RenderBundle; _ = RenderBundle;
_ = QuerySet; _ = QuerySet;
_ = PipelineLayout;
_ = Feature; _ = Feature;
} }