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);
}