gpu: implement PipelineLayout
Signed-off-by: Stephen Gutekanst <stephen@hexops.com>
This commit is contained in:
parent
a7667972a2
commit
88e1894fbd
3 changed files with 51 additions and 0 deletions
|
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
|
||||||
27
gpu/src/PipelineLayout.zig
Normal file
27
gpu/src/PipelineLayout.zig
Normal 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;
|
||||||
|
}
|
||||||
|
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue