improve build.zig; run nu tests

This commit is contained in:
2024-11-21 11:27:41 -05:00
parent b5eb8fb5da
commit 03662d8063
4 changed files with 48 additions and 16 deletions

2
.gitignore vendored
View File

@@ -45,5 +45,7 @@ build-*/
docgen_tmp/
.idea/
.direnv/
.envrc
imgui.ini

View File

@@ -14,12 +14,28 @@ pub fn build(b: *std.Build) void {
const cimgui = b.dependency("cimgui", .{});
const nu = b.addModule("nu", .{
.root_source_file = b.path("src/nu.zig"),
.target = target,
.optimize = optimize,
.link_libc = true,
});
nu.addImport("cimgui", cimgui.module("cimgui"));
nu.addImport("vk", vkmod);
nu.linkSystemLibrary("glfw3", .{
.needed = true,
.preferred_link_mode = .static,
.use_pkg_config = .force,
});
const exe = b.addExecutable(.{
.name = "scratchzig",
.root_source_file = b.path("src/main.zig"),
.target = target,
.optimize = optimize,
});
exe.root_module.addImport("nu", nu);
exe.root_module.addImport("vk", vkmod);
exe.root_module.addImport("cimgui", cimgui.module("cimgui"));
const shaders = vkgen.ShaderCompileStep.create(
@@ -31,14 +47,6 @@ pub fn build(b: *std.Build) void {
shaders.add("triangle_frag", "src/shaders/triangle.frag", .{});
exe.root_module.addImport("shaders", shaders.getModule());
exe.linkSystemLibrary2("glfw3", .{
.needed = true,
.preferred_link_mode = .static,
.use_pkg_config = .force,
});
exe.linkLibC();
exe.root_module.addImport("vk", vkmod);
b.installArtifact(exe);
const run_cmd = b.addRunArtifact(exe);
@@ -51,19 +59,36 @@ pub fn build(b: *std.Build) void {
const run_step = b.step("run", "Run the app");
run_step.dependOn(&run_cmd.step);
const exe_unit_tests = b.addTest(.{
.root_source_file = b.path("src/main.zig"),
const nu_unit_tests = b.addTest(.{
.root_source_file = b.path("src/nu.zig"),
.target = target,
.optimize = optimize,
});
exe_unit_tests.linkSystemLibrary2("glfw3", .{
nu_unit_tests.root_module.addImport("cimgui", cimgui.module("cimgui"));
nu_unit_tests.root_module.addImport("vk", vkmod);
nu_unit_tests.root_module.linkSystemLibrary("glfw3", .{
.needed = true,
.preferred_link_mode = .static,
.use_pkg_config = .force,
});
exe_unit_tests.linkLibC();
const run_exe_unit_tests = b.addRunArtifact(exe_unit_tests);
nu_unit_tests.linkLibC();
const run_nu_unit_tests = b.addRunArtifact(nu_unit_tests);
// const exe_unit_tests = b.addTest(.{
// .root_source_file = b.path("src/main.zig"),
// .target = target,
// .optimize = optimize,
// });
// exe_unit_tests.linkSystemLibrary2("glfw3", .{
// .needed = true,
// .preferred_link_mode = .static,
// .use_pkg_config = .force,
// });
// exe_unit_tests.linkLibC();
// const run_exe_unit_tests = b.addRunArtifact(exe_unit_tests);
const test_step = b.step("test", "Run unit tests");
test_step.dependOn(&run_exe_unit_tests.step);
// test_step.dependOn(&run_exe_unit_tests.step);
test_step.dependOn(&run_nu_unit_tests.step);
}

View File

@@ -3,7 +3,7 @@ const nu = @import("nu.zig");
pub const nu_modules = .{
App,
// UI,
UI,
};
pub const main = nu.main;

View File

@@ -1,12 +1,13 @@
const std = @import("std");
const root = @import("root");
const hooks = @import("nu/hooks.zig");
pub const Window = @import("nu/Window.zig");
pub const Render = @import("nu/Render.zig");
pub const ImGui = @import("nu/ImGui.zig");
pub const Bus = @import("nu/Bus.zig");
pub const Hook = @import("nu/hooks.zig").Hook;
pub const Hook = hooks.Hook;
const Config = struct {
window: Window.Config = .{},
@@ -109,3 +110,7 @@ const Graph = struct {
return result;
}
};
test {
std.testing.refAllDecls(hooks);
}