const std = @import("std"); const deps = @import("./deps.zig"); pub fn build(b: *std.build.Builder) void { // Standard target options allows the person running `zig build` to choose // what target to build for. Here we do not override the defaults, which // means any target is allowed, and the default is native. Other options // for restricting supported target set are available. var target = b.standardTargetOptions( .{ .default_target = .{ .abi = .musl, }, }, ); // Standard release options allow the person running `zig build` to select // between Debug, ReleaseSafe, ReleaseFast, and ReleaseSmall. const mode = b.standardReleaseOptions(); const exe = b.addExecutable("b2dlkeygen", "src/main.zig"); exe.linkage = .static; exe.setTarget(target); exe.setBuildMode(mode); exe.install(); // exe.linkage = .static; deps.addAllTo(exe); exe.linkLibC(); exe.addObjectFile("/usr/lib/libcurl.a"); exe.addIncludeDir("/usr/include"); exe.addObjectFile("/usr/lib/libssl.a"); exe.addObjectFile("/usr/lib/libcrypto.a"); exe.addObjectFile("/usr/lib/libnghttp2.a"); exe.addObjectFile("/usr/lib/libbrotlicommon.a"); exe.addObjectFile("/usr/lib/libbrotlidec.a"); exe.addObjectFile("/usr/lib/libbrotlienc.a"); exe.addObjectFile("/lib/libz.a"); const run_cmd = exe.run(); run_cmd.step.dependOn(b.getInstallStep()); if (b.args) |args| { run_cmd.addArgs(args); } const run_step = b.step("run", "Run the app"); run_step.dependOn(&run_cmd.step); const exe_tests = b.addTest("src/main.zig"); exe_tests.setTarget(target); exe_tests.setBuildMode(mode); const test_step = b.step("test", "Run unit tests"); test_step.dependOn(&exe_tests.step); }