summaryrefslogtreecommitdiff
path: root/build.zig
diff options
context:
space:
mode:
authornavewindre <boneyaard@gmail.com>2025-07-04 04:28:18 +0200
committernavewindre <boneyaard@gmail.com>2025-07-04 04:28:18 +0200
commit59e212391b5ee81a000c65871e4ec81109ece3f9 (patch)
tree7ce4c9952ccf9f29a1469b7621706e321c94fac6 /build.zig
parent2eb893562eeb08b2cbd909533026f745d3665ebc (diff)
push source
Diffstat (limited to 'build.zig')
-rw-r--r--build.zig45
1 files changed, 45 insertions, 0 deletions
diff --git a/build.zig b/build.zig
new file mode 100644
index 0000000..cc723ee
--- /dev/null
+++ b/build.zig
@@ -0,0 +1,45 @@
+const std = @import("std");
+
+pub fn build(b: *std.Build) void {
+ const target = b.standardTargetOptions(.{});
+ const optimize = b.standardOptimizeOption(.{});
+
+ const exe_mod = b.createModule(.{
+ .root_source_file = b.path("src/main.zig"),
+ .target = target,
+ .optimize = optimize,
+ });
+
+ const folders = b.dependency( "known_folders", .{} ).module( "known-folders" );
+ const exe = b.addExecutable(.{
+ .name = "dmenu_runner",
+ .root_module = exe_mod,
+ });
+
+ exe.root_module.addImport( "known_folders", folders );
+
+ const check_exe = b.addExecutable(.{
+ .name = "dmenu_runner",
+ .root_source_file = b.path( "src/main.zig" ),
+ .target = target,
+ .optimize = optimize,
+ });
+
+ for( exe.root_module.import_table.keys() ) |key|
+ check_exe.root_module.addImport( key, exe.root_module.import_table.get( key ) orelse unreachable );
+
+ const check = b.step( "check", "check compile result" );
+ check.dependOn( &check_exe.step );
+
+ 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);
+}