aboutsummaryrefslogtreecommitdiff
path: root/backend/build.zig
diff options
context:
space:
mode:
Diffstat (limited to 'backend/build.zig')
-rw-r--r--backend/build.zig49
1 files changed, 49 insertions, 0 deletions
diff --git a/backend/build.zig b/backend/build.zig
new file mode 100644
index 0000000..3fd7c48
--- /dev/null
+++ b/backend/build.zig
@@ -0,0 +1,49 @@
+const std = @import("std");
+
+pub fn build(b: *std.Build) void {
+ const target = b.standardTargetOptions(.{});
+
+ const optimize = b.standardOptimizeOption(.{});
+
+ const exe = b.addExecutable(.{
+ .name = "backend",
+ .root_source_file = b.path("src/main.zig"),
+ .target = target,
+ .optimize = optimize,
+ });
+
+ const httpz = b.dependency("httpz", .{
+ .target = target,
+ .optimize = optimize,
+ });
+ exe.root_module.addImport("httpz", httpz.module("httpz"));
+
+ const zqlite = b.dependency("zqlite", .{
+ .target = target,
+ .optimize = optimize,
+ });
+ exe.linkLibC();
+ exe.linkSystemLibrary("sqlite3");
+ exe.root_module.addImport("zqlite", zqlite.module("zqlite"));
+
+ b.installArtifact(exe);
+
+ const run_cmd = b.addRunArtifact(exe);
+ 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_unit_tests = b.addTest(.{
+ .root_source_file = b.path("src/main.zig"),
+ .target = target,
+ .optimize = optimize,
+ });
+ 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);
+}