aboutsummaryrefslogtreecommitdiff
path: root/lib/std/Build/Step/ConfigHeader.zig
diff options
context:
space:
mode:
authorTechatrix <techatrix@mailbox.org>2025-02-19 09:03:56 +0100
committerTechatrix <techatrix@mailbox.org>2025-02-19 09:34:26 +0100
commit7e548af8b1527d2d04de1c12df9bf8afd1ad23ea (patch)
tree4d0076eadb4163d6495d2e9dd7053378350f5da0 /lib/std/Build/Step/ConfigHeader.zig
parentc390f55e727c8f4ace2eb7992403bf8332a22126 (diff)
downloadzig-7e548af8b1527d2d04de1c12df9bf8afd1ad23ea.tar.gz
zig-7e548af8b1527d2d04de1c12df9bf8afd1ad23ea.zip
std.Build.Step.ConfigHeader: allow using autoconf values multiple times
Diffstat (limited to 'lib/std/Build/Step/ConfigHeader.zig')
-rw-r--r--lib/std/Build/Step/ConfigHeader.zig17
1 files changed, 11 insertions, 6 deletions
diff --git a/lib/std/Build/Step/ConfigHeader.zig b/lib/std/Build/Step/ConfigHeader.zig
index f474c38ff0..e1a7e9f63f 100644
--- a/lib/std/Build/Step/ConfigHeader.zig
+++ b/lib/std/Build/Step/ConfigHeader.zig
@@ -264,8 +264,11 @@ fn render_autoconf(
values: std.StringArrayHashMap(Value),
src_path: []const u8,
) !void {
- var values_copy = try values.clone();
- defer values_copy.deinit();
+ const build = step.owner;
+ const allocator = build.allocator;
+
+ var is_used: std.DynamicBitSetUnmanaged = try .initEmpty(allocator, values.count());
+ defer is_used.deinit(allocator);
var any_errors = false;
var line_index: u32 = 0;
@@ -284,18 +287,20 @@ fn render_autoconf(
continue;
}
const name = it.rest();
- const kv = values_copy.fetchSwapRemove(name) orelse {
+ const index = values.getIndex(name) orelse {
try step.addError("{s}:{d}: error: unspecified config header value: '{s}'", .{
src_path, line_index + 1, name,
});
any_errors = true;
continue;
};
- try renderValueC(output, name, kv.value);
+ is_used.set(index);
+ try renderValueC(output, name, values.values()[index]);
}
- for (values_copy.keys()) |name| {
- try step.addError("{s}: error: config header value unused: '{s}'", .{ src_path, name });
+ var unused_value_it = is_used.iterator(.{ .kind = .unset });
+ while (unused_value_it.next()) |index| {
+ try step.addError("{s}: error: config header value unused: '{s}'", .{ src_path, values.keys()[index] });
any_errors = true;
}