forked from nodecum/c-toxcore-zig
-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathbuild.zig
70 lines (62 loc) · 2.15 KB
/
build.zig
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
const std = @import("std");
const Build = std.Build;
const APPS = .{
"key", "show-keys", "local-test", "echo-bot",
};
pub fn build(b: *Build) void {
const target = b.standardTargetOptions(.{});
const optimize = b.standardOptimizeOption(.{});
const c_toxcore_dep = b.dependency(
"c-toxcore",
.{
.target = target,
.optimize = optimize,
.static = true,
.shared = false,
},
);
const libsodium_dep = b.dependency("libsodium", .{});
const c_toxcore_lib = c_toxcore_dep.artifact("toxcore");
const tox = b.addModule("tox", .{
.root_source_file = .{ .path = "src/tox.zig" },
});
tox.addIncludePath(c_toxcore_dep.path("."));
const sodium = b.addModule("sodium", .{
.root_source_file = .{ .path = "src/sodium.zig" },
});
sodium.addIncludePath(libsodium_dep.path("src/libsodium/include"));
const test_exe = b.addTest(.{
.root_source_file = .{ .path = "src/tox.zig" },
.target = target,
.optimize = optimize,
});
test_exe.linkLibrary(c_toxcore_lib);
//test_exe.installLibraryHeaders(c_toxcore_lib);
b.installArtifact(test_exe);
const run_test = b.addRunArtifact(test_exe);
const test_step = b.step("test", "Run all tests");
test_step.dependOn(&run_test.step);
const all_apps_step = b.step("apps", "Build apps");
inline for (APPS) |app_name| {
const app = b.addExecutable(.{
.name = app_name,
.root_source_file = .{
.path = "apps" ++ std.fs.path.sep_str ++ app_name ++ ".zig",
},
.target = target,
.optimize = optimize,
});
app.root_module.addImport("sodium", sodium);
app.root_module.addImport("tox", tox);
app.linkLibrary(c_toxcore_lib);
//app.installLibraryHeaders(c_toxcore_lib);
var run = b.addRunArtifact(app);
b.installArtifact(app);
if (b.args) |args| run.addArgs(args);
b.step(
"run-" ++ app_name,
"Run the " ++ app_name ++ " app",
).dependOn(&run.step);
all_apps_step.dependOn(&app.step);
}
}