-
-
Notifications
You must be signed in to change notification settings - Fork 8
/
build.zig
153 lines (139 loc) · 6.09 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
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
const builtin = @import("builtin");
const std = @import("std");
pub fn build(b: *std.Build) void {
var target = b.standardTargetOptions(.{});
const optimize = b.standardOptimizeOption(.{});
switch (target.query.os_tag orelse builtin.os.tag) {
.wasi => {
target.query.cpu_features_add.addFeature(@intFromEnum(std.Target.wasm.Feature.atomics));
target.query.cpu_features_add.addFeature(@intFromEnum(std.Target.wasm.Feature.bulk_memory));
},
else => {},
}
const sanitize = b.option(bool, "sanitize", "use sanitizers when running examples or tests") orelse false;
var aio_opts = b.addOptions();
const PosixMode = enum { auto, force, disable };
const posix = b.option(PosixMode, "posix", "posix mode [auto, force, disable]") orelse .auto;
aio_opts.addOption(PosixMode, "posix", posix);
const WasiMode = enum { wasi, wasix };
const wasi = b.option(WasiMode, "wasi", "wasi mode [wasi, wasix]") orelse .wasi;
aio_opts.addOption(WasiMode, "wasi", wasi);
var minilib_opts = b.addOptions();
const force_foreign_timer_queue = b.option(bool, "force_foreign_timer_queue", "force the use of foreign timer queue backend") orelse false;
minilib_opts.addOption(bool, "force_foreign_timer_queue", force_foreign_timer_queue);
const minilib = b.addModule("minilib", .{
.root_source_file = b.path("src/minilib.zig"),
.target = target,
.optimize = optimize,
.single_threaded = switch (target.query.os_tag orelse builtin.os.tag) {
.linux => null, // io_uring backend can be used without threads
else => false,
},
});
minilib.addImport("build_options", minilib_opts.createModule());
const aio = b.addModule("aio", .{
.root_source_file = b.path("src/aio.zig"),
.target = target,
.optimize = optimize,
.link_libc = switch (target.query.os_tag orelse builtin.os.tag) {
.windows => true,
.freebsd, .openbsd, .dragonfly, .netbsd => true,
else => false,
},
.single_threaded = minilib.single_threaded,
});
aio.addImport("minilib", minilib);
aio.addImport("build_options", aio_opts.createModule());
if (target.query.os_tag orelse builtin.os.tag == .windows) {
if (b.lazyDependency("zigwin32", .{})) |zigwin32| {
aio.addImport("win32", zigwin32.module("zigwin32"));
}
}
const coro = b.addModule("coro", .{
.root_source_file = b.path("src/coro.zig"),
.target = target,
.optimize = optimize,
});
coro.addImport("minilib", minilib);
coro.addImport("aio", aio);
const run_all = b.step("run", "Run all examples");
inline for (.{
.aio_dynamic,
.aio_immediate,
.coro,
.coro_wttr,
}) |example| {
const exe = b.addExecutable(.{
.name = @tagName(example),
.root_source_file = b.path("examples/" ++ @tagName(example) ++ ".zig"),
.target = target,
.optimize = optimize,
.sanitize_thread = sanitize,
.single_threaded = minilib.single_threaded,
});
exe.root_module.addImport("aio", aio);
exe.root_module.addImport("coro", coro);
var cmd = makeRunStep(b, target, exe, 3.355e+7, @tagName(example), "Run " ++ @tagName(example) ++ " example");
run_all.dependOn(&cmd.step);
}
const test_filter = b.option([]const u8, "test-filter", "Skip tests that do not match any filter") orelse "";
const test_step = b.step("test", "Run unit tests");
inline for (.{ .minilib, .aio, .coro }) |mod| {
const tst = b.addTest(.{
.root_source_file = b.path("src/" ++ @tagName(mod) ++ ".zig"),
.target = target,
.optimize = optimize,
.filters = &.{test_filter},
.link_libc = aio.link_libc,
.single_threaded = minilib.single_threaded,
.sanitize_thread = sanitize,
});
switch (mod) {
.minilib => addImportsFrom(tst.root_module, minilib),
.aio => addImportsFrom(tst.root_module, aio),
.coro => addImportsFrom(tst.root_module, coro),
else => unreachable,
}
var cmd = makeRunStep(b, target, tst, 3.355e+7, "test-" ++ @tagName(mod), "Run " ++ @tagName(mod) ++ " tests");
test_step.dependOn(&cmd.step);
}
inline for (.{
.ping_pongs,
}) |bench| {
const exe = b.addExecutable(.{
.name = @tagName(bench),
.root_source_file = b.path("bench/" ++ @tagName(bench) ++ ".zig"),
.target = target,
.optimize = optimize,
.sanitize_thread = sanitize,
.single_threaded = minilib.single_threaded,
});
exe.root_module.addImport("aio", aio);
exe.root_module.addImport("coro", coro);
var cmd = makeRunStep(b, target, exe, 3.355e+7, @tagName(bench), "Run " ++ @tagName(bench) ++ " benchmark");
run_all.dependOn(&cmd.step);
}
}
fn addImportsFrom(dst: *std.Build.Module, src: *std.Build.Module) void {
var iter = src.import_table.iterator();
while (iter.next()) |e| dst.addImport(e.key_ptr.*, e.value_ptr.*);
}
fn makeRunStep(b: *std.Build, target: std.Build.ResolvedTarget, step: *std.Build.Step.Compile, max_memory: usize, name: []const u8, description: []const u8) *std.Build.Step.Run {
const cmd = switch (target.query.os_tag orelse builtin.os.tag) {
.wasi => blk: {
step.shared_memory = true;
step.max_memory = std.mem.alignForward(usize, max_memory, 65536);
step.import_memory = true;
step.export_memory = true;
step.root_module.export_symbol_names = &.{"wasi_thread_start"};
const wasmtime = b.addSystemCommand(&.{ "wasmtime", "-W", "trap-on-grow-failure=y", "-S", "threads=y", "--dir", "." });
wasmtime.addArtifactArg(step);
break :blk wasmtime;
},
else => b.addRunArtifact(step),
};
if (b.args) |args| cmd.addArgs(args);
const run = b.step(name, description);
run.dependOn(&cmd.step);
return cmd;
}