aboutsummaryrefslogtreecommitdiff
path: root/lib/std
diff options
context:
space:
mode:
authorAsa Zeren <asaizeren@gmail.com>2021-03-23 18:58:24 -0400
committerVeikka Tuominen <git@vexu.eu>2021-06-11 20:18:19 +0300
commit6cc88458029759bbedcb4d949deb887d464cdd60 (patch)
tree1e31fcbe7cd4a2cbb2d1d652d6358825554ad1f0 /lib/std
parent0bde5ce369ba59f7bc33e97cd5b03d69913108c5 (diff)
downloadzig-6cc88458029759bbedcb4d949deb887d464cdd60.tar.gz
zig-6cc88458029759bbedcb4d949deb887d464cdd60.zip
Change defineCMacro to take separate name and value arugments
Before this change, when one or more of name or value are not known at comptime, build.zig files must allocate and do the concatanation, which can be cumbersome, and also adds a redundant allocation when name and value are slices. The new version only does a single allocation directly in the builder's allocator to concatonate name and value. The origional behavior is available in defineCMacroRaw, for use in situations such as parseing c compiler arguments. Additionally, several places have been updated to use the new funtions.
Diffstat (limited to 'lib/std')
-rw-r--r--lib/std/build.zig21
1 files changed, 18 insertions, 3 deletions
diff --git a/lib/std/build.zig b/lib/std/build.zig
index 19306fa916..5c9d8c3c44 100644
--- a/lib/std/build.zig
+++ b/lib/std/build.zig
@@ -1700,8 +1700,23 @@ pub const LibExeObjStep = struct {
}
}
+ /// If the value is omitted, it is set to 1.
+ /// `name` and `value` need not live longer than the function call.
+ pub fn defineCMacro(self: *LibExeObjStep, name: []const u8, value: ?[]const u8) void {
+ var macro = self.builder.allocator.alloc(
+ u8,
+ name.len + if (value) |value_slice| value_slice.len + 1 else 0,
+ ) catch |err| if (err == error.OutOfMemory) @panic("Out of memory") else unreachable;
+ mem.copy(u8, macro, name);
+ if (value) |value_slice| {
+ macro[name.len] = '=';
+ mem.copy(u8, macro[name.len + 1 ..], value_slice);
+ }
+ self.c_macros.append(macro) catch unreachable;
+ }
+
/// name_and_value looks like [name]=[value]. If the value is omitted, it is set to 1.
- pub fn defineCMacro(self: *LibExeObjStep, name_and_value: []const u8) void {
+ pub fn defineCMacroRaw(self: *LibExeObjStep, name_and_value: []const u8) void {
self.c_macros.append(self.builder.dupe(name_and_value)) catch unreachable;
}
@@ -1790,9 +1805,9 @@ pub const LibExeObjStep = struct {
self.linkSystemLibraryName(tok["-l".len..]);
} else if (mem.eql(u8, tok, "-D")) {
const macro = it.next() orelse return error.PkgConfigInvalidOutput;
- self.defineCMacro(macro);
+ self.defineCMacroRaw(macro);
} else if (mem.startsWith(u8, tok, "-D")) {
- self.defineCMacro(tok["-D".len..]);
+ self.defineCMacroRaw(tok["-D".len..]);
} else if (mem.eql(u8, tok, "-pthread")) {
self.linkLibC();
} else if (self.builder.verbose) {