commit 7e751e8040ad6afb9ae0a040ae4080c2f4b2f443 (tree)
parent 5ffd8bf5f6669469d3cdbad06f09cf3844723e3b
Author: Mathias Lafeldt <mathias.lafeldt@gmail.com>
Date: Tue, 11 Mar 2025 07:12:13 +0100
Merge pull request #23193 from mlafeldt/fix-macho-detection
Fetch: enhance Mach-O executable detection for modern Macs
closes #21044
Diffstat:
1 file changed, 10 insertions(+), 1 deletion(-)
diff --git a/src/Package/Fetch.zig b/src/Package/Fetch.zig
@@ -1850,7 +1850,11 @@ const FileHeader = struct {
return magic_number == std.macho.MH_MAGIC or
magic_number == std.macho.MH_MAGIC_64 or
magic_number == std.macho.FAT_MAGIC or
- magic_number == std.macho.FAT_MAGIC_64;
+ magic_number == std.macho.FAT_MAGIC_64 or
+ magic_number == std.macho.MH_CIGAM or
+ magic_number == std.macho.MH_CIGAM_64 or
+ magic_number == std.macho.FAT_CIGAM or
+ magic_number == std.macho.FAT_CIGAM_64;
}
pub fn isExecutable(self: *FileHeader) bool {
@@ -1875,6 +1879,11 @@ test FileHeader {
h.bytes_read = 0;
h.update(&macho64_magic_bytes);
try std.testing.expect(h.isExecutable());
+
+ const macho64_cigam_bytes = [_]u8{ 0xFE, 0xED, 0xFA, 0xCF };
+ h.bytes_read = 0;
+ h.update(&macho64_cigam_bytes);
+ try std.testing.expect(h.isExecutable());
}
// Result of the `unpackResource` operation. Enables collecting errors from