diff options
| author | Techatrix <techatrix@mailbox.org> | 2025-02-19 09:03:56 +0100 |
|---|---|---|
| committer | Techatrix <techatrix@mailbox.org> | 2025-02-19 09:34:26 +0100 |
| commit | 7e548af8b1527d2d04de1c12df9bf8afd1ad23ea (patch) | |
| tree | 4d0076eadb4163d6495d2e9dd7053378350f5da0 /lib/std/Build/Step/ConfigHeader.zig | |
| parent | c390f55e727c8f4ace2eb7992403bf8332a22126 (diff) | |
| download | zig-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.zig | 17 |
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; } |
