const Builder = @import("std").build.Builder; const builtin = @import("builtin"); pub fn build(b: *Builder) void { const buildMode = b.standardReleaseOptions(); const examples = [_][2][]const u8{ [_][]const u8{ "simple", "examples/simple.zig" }, // [_][]const u8{ "mesh", "examples/mesh.zig" }, }; for (examples) |example, i| { const name = example[0]; const source = example[1]; var exe = b.addExecutable(name, source); exe.setBuildMode(b.standardReleaseOptions()); exe.addPackagePath("ecs", "src/ecs.zig"); const run_cmd = exe.run(); const exe_step = b.step(name, b.fmt("run {}.zig", .{name})); exe_step.dependOn(&run_cmd.step); // first element in the list is added as "run" so "zig build run" works if (i == 0) { const run_exe_step = b.step("run", b.fmt("run {}.zig", .{name})); run_exe_step.dependOn(&run_cmd.step); } } // internal tests const internal_test_step = b.addTest("src/tests.zig"); internal_test_step.setBuildMode(buildMode); // public api tests const test_step = b.addTest("tests/tests.zig"); test_step.addPackagePath("ecs", "src/ecs.zig"); test_step.setBuildMode(buildMode); const test_cmd = b.step("test", "Run the tests"); test_cmd.dependOn(&internal_test_step.step); test_cmd.dependOn(&test_step.step); } pub const LibType = enum(i32) { static, dynamic, // requires DYLD_LIBRARY_PATH to point to the dylib path exe_compiled, }; /// rel_path is used to add package paths. It should be the the same path used to include this build file pub fn linkArtifact(b: *Builder, artifact: *std.build.LibExeObjStep, target: std.build.Target, lib_type: LibType, rel_path: []const u8) void { switch (lib_type) { .static => { const lib = b.addStaticLibrary("ecs", "ecs.zig"); lib.setBuildMode(buildMode); lib.install(); artifact.linkLibrary(lib); }, .dynamic => { const lib = b.addSharedLibrary("ecs", "ecs.zig", null); lib.setBuildMode(buildMode); lib.install(); artifact.linkLibrary(lib); }, else => {}, } artifact.addPackagePath("ecs", std.fs.path.join(b.allocator, &[_][]const u8{ rel_path, "ecs.zig" }) catch unreachable); }