aboutsummaryrefslogtreecommitdiff
path: root/tools
diff options
context:
space:
mode:
authorAndrew Kelley <andrew@ziglang.org>2021-12-15 17:57:33 -0700
committerAndrew Kelley <andrew@ziglang.org>2021-12-15 18:34:27 -0700
commit21cffe22d4373c203d5d2b14cdd09febbe3d0e7e (patch)
treebfc4d938c0afd4470efe39c254d096ab844bf0aa /tools
parent4d48948b526337947ef59a83f7dbc81b70aa5723 (diff)
downloadzig-21cffe22d4373c203d5d2b14cdd09febbe3d0e7e.tar.gz
zig-21cffe22d4373c203d5d2b14cdd09febbe3d0e7e.zip
glibc: remove duplicate files between generic-glibc/ and glibc/include/
Diffstat (limited to 'tools')
-rw-r--r--tools/update_glibc.zig82
1 files changed, 73 insertions, 9 deletions
diff --git a/tools/update_glibc.zig b/tools/update_glibc.zig
index 14d318ea7b..c15123a6de 100644
--- a/tools/update_glibc.zig
+++ b/tools/update_glibc.zig
@@ -51,7 +51,50 @@ pub fn main() !void {
var glibc_src_dir = try fs.cwd().openDir(glibc_src_path, .{});
defer glibc_src_dir.close();
- var walker = try dest_dir.walk(arena);
+ // Copy updated files from upstream.
+ {
+ var walker = try dest_dir.walk(arena);
+ defer walker.deinit();
+
+ walk: while (try walker.next()) |entry| {
+ if (entry.kind != .File) continue;
+ if (mem.startsWith(u8, entry.basename, ".")) continue;
+ for (exempt_files) |p| {
+ if (mem.eql(u8, entry.path, p)) continue :walk;
+ }
+
+ glibc_src_dir.copyFile(entry.path, dest_dir, entry.path, .{}) catch |err| {
+ log.warn("unable to copy '{s}/{s}' to '{s}/{s}': {s}", .{
+ glibc_src_path, entry.path,
+ dest_dir_path, entry.path,
+ @errorName(err),
+ });
+ if (err == error.FileNotFound) {
+ try dest_dir.deleteFile(entry.path);
+ }
+ };
+ }
+ }
+
+ // Warn about duplicated files inside glibc/include/* that can be omitted
+ // because they are already in generic-glibc/*.
+
+ var include_dir = dest_dir.openDir("include", .{ .iterate = true }) catch |err| {
+ fatal("unable to open directory '{s}/include': {s}", .{
+ dest_dir_path, @errorName(err),
+ });
+ };
+ defer include_dir.close();
+
+ const generic_glibc_path = try std.fmt.allocPrint(
+ arena,
+ "{s}/lib/libc/include/generic-glibc",
+ .{zig_src_path},
+ );
+ var generic_glibc_dir = try fs.cwd().openDir(generic_glibc_path, .{});
+ defer generic_glibc_dir.close();
+
+ var walker = try include_dir.walk(arena);
defer walker.deinit();
walk: while (try walker.next()) |entry| {
@@ -61,16 +104,37 @@ pub fn main() !void {
if (mem.eql(u8, entry.path, p)) continue :walk;
}
- glibc_src_dir.copyFile(entry.path, dest_dir, entry.path, .{}) catch |err| {
- log.warn("unable to copy '{s}/{s}' to '{s}/{s}': {s}", .{
- glibc_src_path, entry.path,
- dest_dir_path, entry.path,
- @errorName(err),
+ const max_file_size = 10 * 1024 * 1024;
+
+ const generic_glibc_contents = generic_glibc_dir.readFileAlloc(
+ arena,
+ entry.path,
+ max_file_size,
+ ) catch |err| switch (err) {
+ error.FileNotFound => continue,
+ else => |e| fatal("unable to load '{s}/include/{s}': {s}", .{
+ generic_glibc_path, entry.path, @errorName(e),
+ }),
+ };
+ const glibc_include_contents = include_dir.readFileAlloc(
+ arena,
+ entry.path,
+ max_file_size,
+ ) catch |err| {
+ fatal("unable to load '{s}/include/{s}': {s}", .{
+ dest_dir_path, entry.path, @errorName(err),
});
- if (err == error.FileNotFound) {
- try dest_dir.deleteFile(entry.path);
- }
};
+
+ const whitespace = " \r\n\t";
+ const generic_glibc_trimmed = mem.trim(u8, generic_glibc_contents, whitespace);
+ const glibc_include_trimmed = mem.trim(u8, glibc_include_contents, whitespace);
+ if (mem.eql(u8, generic_glibc_trimmed, glibc_include_trimmed)) {
+ log.warn("same contents: '{s}/include/{s}' and '{s}/include/{s}'", .{
+ generic_glibc_path, entry.path,
+ dest_dir_path, entry.path,
+ });
+ }
}
}