zig

fork of https://codeberg.org/ziglang/zig
Log | Files | Refs | README | LICENSE

commit ec4514def41db988f89c2da180f7a8f87168f5d1 (tree)
parent df394faf776aa7012649dc1724ccb66d78a1439e
Author: Henry Kupty <hkupty@gmail.com>
Date:   Thu, 25 Sep 2025 22:22:08 +0200

refactor: Reimplement tool using SelectiveWalker

This skips directory trees where top-level directories do not match the
defined ones

Diffstat:
Mtools/update_mingw.zig | 28++++++++++++++++++++--------
1 file changed, 20 insertions(+), 8 deletions(-)

diff --git a/tools/update_mingw.zig b/tools/update_mingw.zig @@ -109,13 +109,31 @@ pub fn main() !void { { // Also add all new def and def.in files. - var walker = try src_crt_dir.walk(arena); + var walker = try src_crt_dir.walkSelectively(arena); defer walker.deinit(); var fail = false; while (try walker.next()) |entry| { - if (entry.kind != .file) continue; + switch (entry.kind) { + .directory => { + switch (walker.depth()) { + 1 => for (def_dirs) |p| { + if (std.mem.eql(u8, entry.basename, p)) { + try walker.enter(entry); + continue; + } + }, + else => { + // The top-level directory was already validated + try walker.enter(entry); + continue; + }, + } + }, + .file => {}, + else => continue, + } const ok_ext = for (def_exts) |ext| { if (std.mem.endsWith(u8, entry.path, ext)) break true; @@ -123,12 +141,6 @@ pub fn main() !void { if (!ok_ext) continue; - const ok_prefix = for (def_dirs) |p| { - if (std.mem.startsWith(u8, entry.path, p)) break true; - } else false; - - if (!ok_prefix) continue; - const blacklisted = for (blacklisted_defs) |item| { if (std.mem.eql(u8, entry.basename, item)) break true; } else false;