-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathbuild_roc.zig
72 lines (62 loc) · 2.58 KB
/
build_roc.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
const std = @import("std");
pub fn main() !void {
// Setup allocator
var gpa = std.heap.GeneralPurposeAllocator(.{}){};
const allocator = gpa.allocator();
defer _ = gpa.deinit();
// Grab args
const args = try std.process.argsAlloc(allocator);
defer std.process.argsFree(allocator, args);
// Setup buffered stdout and stderr
const stdout = std.io.getStdOut().writer();
const stderr = std.io.getStdErr().writer();
// Early exit on not enough args
if (args.len < 2) {
try stderr.print("not enough args for build_roc.\n", .{});
std.process.exit(1);
}
// First arg is executable name (can be ignored)
// Second is the file for roc to check and build.
// Third is the optional optimization flag.
const app_name = args[1];
const optimize_flag = if (args.len >= 3) args[2] else "";
// Run `roc check`
const roc_check_args = [_][]const u8{ "roc", "check", app_name };
const roc_check = try std.ChildProcess.exec(.{
.allocator = allocator,
.argv = &roc_check_args,
});
defer allocator.free(roc_check.stdout);
defer allocator.free(roc_check.stderr);
const roc_check_success = roc_check.term.Exited == 0;
const roc_check_warning = roc_check.term.Exited == 2;
// On the error case, print the output of `roc check` and return and err.
if (!roc_check_success and !roc_check_warning) {
try stdout.print("{s}", .{roc_check.stdout});
try stderr.print("{s}", .{roc_check.stderr});
std.process.exit(1);
}
// `roc check` succeeded or only had warnings.
// Proceed to `roc build`
var roc_build_args = try std.ArrayList([]const u8).initCapacity(allocator, 10);
defer roc_build_args.deinit();
try roc_build_args.appendSlice(&[_][]const u8{ "roc", "build", "--target", "wasm32", "--no-link", "--output", "zig-cache/app.o" });
if (optimize_flag.len != 0) {
try roc_build_args.append(optimize_flag);
}
try roc_build_args.append(app_name);
const roc_build = try std.ChildProcess.exec(.{
.allocator = allocator,
.argv = roc_build_args.items,
});
defer allocator.free(roc_build.stdout);
defer allocator.free(roc_build.stderr);
// For roc build, we always output all of stdout and stderr, but only fail on errors.
try stdout.print("{s}", .{roc_build.stdout});
try stderr.print("{s}", .{roc_build.stderr});
const roc_build_success = roc_build.term.Exited == 0;
const roc_build_warning = roc_build.term.Exited == 2;
if (!roc_build_success and !roc_build_warning) {
std.process.exit(1);
}
}