gpu: implement RenderBundleEncoder.finish
Signed-off-by: Stephen Gutekanst <stephen@hexops.com>
This commit is contained in:
parent
9e7f0796f6
commit
d7476bc24e
2 changed files with 16 additions and 11 deletions
|
|
@ -1164,6 +1164,15 @@ const render_bundle_encoder_vtable = RenderBundleEncoder.VTable{
|
|||
);
|
||||
}
|
||||
}).drawIndirect,
|
||||
.finish = (struct {
|
||||
pub fn finish(ptr: *anyopaque, descriptor: *const RenderBundle.Descriptor) RenderBundle {
|
||||
const desc = c.WGPURenderBundleDescriptor{
|
||||
.nextInChain = null,
|
||||
.label = if (descriptor.label) |l| l else null,
|
||||
};
|
||||
return wrapRenderBundle(c.wgpuRenderBundleEncoderFinish(@ptrCast(c.WGPURenderBundleEncoder, ptr), &desc));
|
||||
}
|
||||
}).finish,
|
||||
// .beginOcclusionQuery = (struct {
|
||||
// pub fn beginOcclusionQuery(ptr: *anyopaque, query_index: u32) void {
|
||||
// c.wgpuRenderBundleEncoderBeginOcclusionQuery(@ptrCast(c.WGPURenderBundleEncoder, ptr), query_index);
|
||||
|
|
@ -1174,11 +1183,6 @@ const render_bundle_encoder_vtable = RenderBundleEncoder.VTable{
|
|||
// c.wgpuRenderBundleEncoderEndOcclusionQuery(@ptrCast(c.WGPURenderBundleEncoder, ptr));
|
||||
// }
|
||||
// }).endOcclusionQuery,
|
||||
// .end = (struct {
|
||||
// pub fn end(ptr: *anyopaque) void {
|
||||
// c.wgpuRenderBundleEncoderEnd(@ptrCast(c.WGPURenderBundleEncoder, ptr));
|
||||
// }
|
||||
// }).end,
|
||||
// .executeBundles = (struct {
|
||||
// pub fn executeBundles(ptr: *anyopaque, bundles: []RenderBundle) void {
|
||||
// var few_bundles: [16]c.WGPURenderBundle = undefined;
|
||||
|
|
|
|||
|
|
@ -1,5 +1,6 @@
|
|||
const Texture = @import("Texture.zig");
|
||||
const Buffer = @import("Buffer.zig");
|
||||
const RenderBundle = @import("RenderBundle.zig");
|
||||
|
||||
const RenderBundleEncoder = @This();
|
||||
|
||||
|
|
@ -28,8 +29,7 @@ pub const VTable = struct {
|
|||
) void,
|
||||
drawIndexedIndirect: fn (ptr: *anyopaque, indirect_buffer: Buffer, indirect_offset: u64) void,
|
||||
drawIndirect: fn (ptr: *anyopaque, indirect_buffer: Buffer, indirect_offset: u64) void,
|
||||
// finish: fn (ptr: *anyopaque, descriptor: *const RenderBundle.Descriptor) void,
|
||||
// WGPU_EXPORT WGPURenderBundle wgpuRenderBundleEncoderFinish(WGPURenderBundleEncoder renderBundleEncoder, WGPURenderBundleDescriptor const * descriptor);
|
||||
finish: fn (ptr: *anyopaque, descriptor: *const RenderBundle.Descriptor) RenderBundle,
|
||||
// insertDebugMarker: fn (ptr: *anyopaque, marker_label: [*:0]const u8) void,
|
||||
// WGPU_EXPORT void wgpuRenderBundleEncoderInsertDebugMarker(WGPURenderBundleEncoder renderBundleEncoder, char const * markerLabel);
|
||||
// popDebugGroup: fn (ptr: *anyopaque) void,
|
||||
|
|
@ -84,6 +84,10 @@ pub inline fn drawIndirect(enc: RenderBundleEncoder, indirect_buffer: Buffer, in
|
|||
enc.vtable.drawIndirect(enc.ptr, indirect_buffer, indirect_offset);
|
||||
}
|
||||
|
||||
pub inline fn finish(enc: RenderBundleEncoder, descriptor: *const RenderBundle.Descriptor) RenderBundle {
|
||||
return enc.vtable.finish(enc.ptr, descriptor);
|
||||
}
|
||||
|
||||
// pub inline fn beginOcclusionQuery(enc: RenderBundleEncoder, query_index: u32) void {
|
||||
// enc.vtable.beginOcclusionQuery(enc.ptr, query_index);
|
||||
// }
|
||||
|
|
@ -92,10 +96,6 @@ pub inline fn drawIndirect(enc: RenderBundleEncoder, indirect_buffer: Buffer, in
|
|||
// enc.vtable.endOcclusionQuery(enc.ptr);
|
||||
// }
|
||||
|
||||
// pub inline fn end(enc: RenderBundleEncoder) void {
|
||||
// enc.vtable.end(enc.ptr);
|
||||
// }
|
||||
|
||||
// pub inline fn executeBundles(enc: RenderBundleEncoder, bundles: []RenderBundle) void {
|
||||
// enc.vtable.executeBundles(enc.ptr, bundles);
|
||||
// }
|
||||
|
|
@ -194,5 +194,6 @@ test {
|
|||
_ = drawIndexed;
|
||||
_ = drawIndexedIndirect;
|
||||
_ = drawIndirect;
|
||||
_ = finish;
|
||||
_ = Descriptor;
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue