fediglam/build.zig

50 lines
1.5 KiB
Zig
Raw Normal View History

2022-04-02 20:23:18 +00:00
const std = @import("std");
2022-06-09 05:54:41 +00:00
const static_libs = [_][]const u8{
"util",
2022-06-09 06:54:15 +00:00
"http",
2022-06-09 05:54:41 +00:00
};
2022-06-09 06:54:15 +00:00
fn createLibs(b: *std.build.Builder) [static_libs.len]*std.build.LibExeObjStep {
var libs: [static_libs.len]*std.build.LibExeObjStep = undefined;
inline for (static_libs) |name, i| {
libs[i] = b.addStaticLibrary(name, "src/" ++ name ++ "/lib.zig");
}
return libs;
}
fn addRunStep(b: *std.build.Builder, exe: *std.build.LibExeObjStep) void {
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);
}
2022-04-02 20:23:18 +00:00
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.
const target = b.standardTargetOptions(.{});
// Standard release options allow the person running `zig build` to select
// between Debug, ReleaseSafe, ReleaseFast, and ReleaseSmall.
const mode = b.standardReleaseOptions();
2022-06-09 05:54:41 +00:00
const exe = b.addExecutable("apub", "src/main/main.zig");
2022-04-02 20:23:18 +00:00
exe.setTarget(target);
exe.setBuildMode(mode);
2022-06-09 05:54:41 +00:00
2022-06-09 06:54:15 +00:00
var libs = createLibs(b);
for (libs) |lib| {
2022-06-09 05:54:41 +00:00
exe.linkLibrary(lib);
}
2022-04-02 20:23:18 +00:00
exe.install();
2022-06-09 06:54:15 +00:00
addRunStep(b, exe);
2022-04-02 20:23:18 +00:00
}