-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathbuild.zig
125 lines (114 loc) · 3.97 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
const std = @import("std");
pub fn build(b: *std.Build) void {
const target = b.standardTargetOptions(.{});
const optimize = b.standardOptimizeOption(.{});
buildExe(b, .{
.filepath = "src/hello-c.c",
.filetype = .c,
.target = target,
.optimize = optimize,
});
buildExe(b, .{
.filepath = "src/hello-cpp.cpp",
.filetype = .cpp,
.target = target,
.optimize = optimize,
});
// no need libc
buildExe(b, .{
.filepath = "src/hello-zig.zig",
.filetype = .zig,
.target = target,
.optimize = optimize,
});
}
fn buildExe(b: *std.Build, info: BuildInfo) void {
const exe = b.addExecutable(.{
.name = info.filename(),
.target = info.target,
.optimize = info.optimize,
});
switch (info.filetype) {
// zig w/ msvc no has libcxx support
// https://github.com/ziglang/zig/issues/5312
.cpp => {
exe.addCSourceFile(.{
.file = b.path(info.filepath),
.flags = &.{
"-Wall",
"-Wextra",
},
});
exe.want_lto = false;
if (exe.rootModuleTarget().abi == .msvc) {
xWin(b, exe);
exe.linkLibC();
} else {
exe.linkLibCpp();
}
},
.c => {
exe.addCSourceFile(.{
.file = b.path(info.filepath),
.flags = &.{
"-Wall",
"-Wextra",
},
});
if (exe.rootModuleTarget().abi == .msvc) {
xWin(b, exe);
}
exe.linkLibC();
},
.zig => exe.root_module.root_source_file = b.path(info.filepath),
}
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(info.filename(), b.fmt("Run the {s} app", .{info.filename()}));
run_step.dependOn(&run_cmd.step);
}
const BuildInfo = struct {
filepath: []const u8,
filetype: enum {
c,
cpp,
zig,
},
target: std.Build.ResolvedTarget,
optimize: std.builtin.OptimizeMode,
fn filename(self: BuildInfo) []const u8 {
var split = std.mem.splitSequence(u8, std.fs.path.basename(self.filepath), ".");
return split.first();
}
};
fn xWin(b: *std.Build, exe: *std.Build.Step.Compile) void {
const arch: []const u8 = switch (exe.rootModuleTarget().cpu.arch) {
.x86_64 => "x64",
.x86 => "x86",
.arm, .armeb => "arm",
.aarch64 => "arm64",
else => @panic("Unsupported Architecture"),
};
exe.setLibCFile(.{ .cwd_relative = sdkPath("/libc.txt") });
exe.addSystemIncludePath(.{ .cwd_relative = sdkPath("/.xwin/crt/include") });
exe.addSystemIncludePath(.{ .cwd_relative = sdkPath("/.xwin/sdk/include") });
exe.addSystemIncludePath(.{ .cwd_relative = sdkPath("/.xwin/sdk/include/10.0.26100/cppwinrt") });
exe.addSystemIncludePath(.{ .cwd_relative = sdkPath("/.xwin/sdk/include/10.0.26100/ucrt") });
exe.addSystemIncludePath(.{ .cwd_relative = sdkPath("/.xwin/sdk/include/10.0.26100/um") });
exe.addSystemIncludePath(.{ .cwd_relative = sdkPath("/.xwin/sdk/include/10.0.26100/shared") });
exe.addLibraryPath(.{ .cwd_relative = b.fmt(sdkPath("/.xwin/crt/lib/{s}"), .{arch}) });
exe.addLibraryPath(.{ .cwd_relative = b.fmt(sdkPath("/.xwin/sdk/lib/ucrt/{s}"), .{arch}) });
exe.addLibraryPath(.{ .cwd_relative = b.fmt(sdkPath("/.xwin/sdk/lib/um/{s}"), .{arch}) });
}
fn sdkPath(comptime suffix: []const u8) []const u8 {
if (suffix[0] != '/') @compileError("relToPath requires an absolute path!");
return comptime blk: {
@setEvalBranchQuota(2000);
const root_dir = std.fs.path.dirname(@src().file) orelse ".";
break :blk root_dir ++ suffix;
};
}