From 6f34061be705e07d6dbe5d314e35989ed5cc7faa Mon Sep 17 00:00:00 2001 From: Marcel Taeumel Date: Wed, 17 Jan 2024 19:43:32 +0100 Subject: [PATCH] Unified macOS bundle: use binary plist from x64 build (macos 10.9+). Ignore the newer (binary) NIBArchive introduced with macOS 10.13. --- helpers_bundles.sh | 26 +++++++++++++++++++------- 1 file changed, 19 insertions(+), 7 deletions(-) diff --git a/helpers_bundles.sh b/helpers_bundles.sh index 8a7f5f4..32ef464 100644 --- a/helpers_bundles.sh +++ b/helpers_bundles.sh @@ -185,15 +185,16 @@ copy_resources() { } # Make a fat binary from a pair of VMs in -# build.macos64{x64,ARMv8}/virtend.cog.spur/Virtend*.app -# To choose the oldest nib the oldest deployment target (x86_64) should be last +# building/macos64{x64,ARMv8}/squeak.cog.spur/Squeak*.app +# To choose the oldest *.nib, meaning the oldest deployment +# target (x86_64) should be the second argument create_unified_vm_macOS() { local MISMATCHINGNIBS= local MISMATCHINGPLISTS= readonly O="$1" - readonly A="$2" - readonly B="$3" + readonly A="$2" # ARMv8 + readonly B="$3" # x64 if [ ! -d "$A" ]; then echo "$A does not exist; aborting" @@ -215,22 +216,33 @@ create_unified_vm_macOS() { # echo ln -s `readlink "$A/$f"` "$O/$f" elif [ ! -f "$A/$f" ]; then echo "$A/$f does not exist; how come?" - elif [ ! -f "$B/$f" ]; then + elif [[ ! "$f" =~ ^.*MainMenu\.nib$ ]] && [ ! -f "$B/$f" ]; then echo "$B/$f does not exist; how come?" else case `file -b "$A/$f"` in Mach-O*) lipo -create -output "$O/$f" "$A/$f" "$B/$f";; *) - if cmp -s "$A/$f" "$B/$f"; then + if [ -f "$B/$f" ] && (cmp -s "$A/$f" "$B/$f"); then cp "$A/$f" "$O/$f" else - echo "EXCLUDING $f because it differs" case "$f" in *.plist) + echo "EXCLUDING $f because it differs" MISMATCHINGPLISTS="$MISMATCHINGPLISTS $f" ;; + *MainMenu.nib) + # Use old binary plist from x64 bundle. + # Ignore NIBArchive keyedobjects-101300.nib. + # Ignore NIBArchive MainMenu.nib from ARM bundle. + if [ -d "$B/$f" ]; then + cp "$B/$f/keyedobjects.nib" "$O/$f" + else + echo "$B/$f should be a directory; how come?" + fi + ;; *.nib) + echo "REPLACING $f because it differs" MISMATCHINGNIBS="$MISMATCHINGNIBS $f" echo "using $B version" cp "$B/$f" "$O/$f"