Simplify shader compilation step

This commit is contained in:
duck
2025-04-23 21:49:32 +05:00
parent 5513044d61
commit 5f50968746
4 changed files with 26 additions and 10 deletions

View File

@@ -1,8 +1,9 @@
const std = @import("std"); const std = @import("std");
const SHADERS: []const struct { file: []const u8, stage: []const u8 } = &.{ /// Paths specified here are compiled to SPIR-V instead of being copied over
.{ .file = "basic", .stage = "vert" }, const SHADERS: []const []const u8 = &.{
.{ .file = "basic", .stage = "frag" }, "data/shaders/basic.vert",
"data/shaders/basic.frag",
}; };
pub fn build(b: *std.Build) void { pub fn build(b: *std.Build) void {
@@ -19,14 +20,29 @@ pub fn build(b: *std.Build) void {
exe.linkLibC(); exe.linkLibC();
exe.linkSystemLibrary("SDL3"); exe.linkSystemLibrary("SDL3");
inline for (SHADERS) |shader| { const copy_data_cmd = b.addInstallDirectory(.{
.source_dir = b.path("data"),
.install_dir = .bin,
.install_subdir = "data",
.exclude_extensions = &.{ "vert", "frag" },
});
b.getInstallStep().dependOn(&copy_data_cmd.step);
for (SHADERS) |shader_path| {
const glslc = b.addSystemCommand(&.{"glslc"}); const glslc = b.addSystemCommand(&.{"glslc"});
glslc.addArg("-fshader-stage=" ++ shader.stage);
glslc.addFileArg(b.path("assets/shaders/" ++ shader.file ++ "." ++ shader.stage)); const ext = std.fs.path.extension(shader_path);
if (std.mem.eql(u8, ext, "vert")) {
glslc.addArg("-fshader-stage=vert");
}
if (std.mem.eql(u8, ext, "frag")) {
glslc.addArg("-fshader-stage=frag");
}
glslc.addFileArg(b.path(shader_path));
glslc.addArg("-o"); glslc.addArg("-o");
const filename = shader.file ++ "_" ++ shader.stage ++ ".spv"; const shader_artifact = glslc.addOutputFileArg(std.fs.path.basename(shader_path));
const shader_artifact = glslc.addOutputFileArg(filename); b.getInstallStep().dependOn(&b.addInstallFileWithDir(shader_artifact, .bin, shader_path).step);
b.getInstallStep().dependOn(&b.addInstallFileWithDir(shader_artifact, .prefix, filename).step);
} }
const run_cmd = b.addRunArtifact(exe); const run_cmd = b.addRunArtifact(exe);

View File

@@ -6,6 +6,6 @@
"build.zig", "build.zig",
"build.zig.zon", "build.zig.zon",
"src", "src",
"assets", "data",
}, },
} }