darwin.make-bootstrap-tools: Fix test target
I'll probably get rid of this eventually since the test-pkgs stuff is more realistic, but this gives quick feedback for now.
This commit is contained in:
parent
31b286467c
commit
6a380c20e0
@ -197,14 +197,49 @@ in rec {
|
|||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
|
|
||||||
|
install_name_tool \
|
||||||
|
-id $out/lib/system/libsystem_c.dylib \
|
||||||
|
$out/lib/system/libsystem_c.dylib
|
||||||
|
|
||||||
|
install_name_tool \
|
||||||
|
-id $out/lib/system/libsystem_kernel.dylib \
|
||||||
|
$out/lib/system/libsystem_kernel.dylib
|
||||||
|
|
||||||
|
# TODO: this logic basically duplicates similar logic in the Libsystem expression. Deduplicate them!
|
||||||
|
libs=$(otool -arch x86_64 -L /usr/lib/libSystem.dylib | tail -n +3 | awk '{ print $1 }')
|
||||||
|
|
||||||
|
for i in $libs; do
|
||||||
|
if [ "$i" != "/usr/lib/system/libsystem_kernel.dylib" ] && [ "$i" != "/usr/lib/system/libsystem_c.dylib" ]; then
|
||||||
|
args="$args -reexport_library $i"
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
|
||||||
|
ld -macosx_version_min 10.7 \
|
||||||
|
-arch x86_64 \
|
||||||
|
-dylib \
|
||||||
|
-o $out/lib/libSystem.B.dylib \
|
||||||
|
-compatibility_version 1.0 \
|
||||||
|
-current_version 1226.10.1 \
|
||||||
|
-reexport_library $out/lib/system/libsystem_c.dylib \
|
||||||
|
-reexport_library $out/lib/system/libsystem_kernel.dylib \
|
||||||
|
$args
|
||||||
|
|
||||||
|
ln -s libSystem.B.dylib $out/lib/libSystem.dylib
|
||||||
|
|
||||||
|
for name in c dbm dl info m mx poll proc pthread rpcsvc util gcc_s.10.4 gcc_s.10.5; do
|
||||||
|
ln -s libSystem.dylib $out/lib/lib$name.dylib
|
||||||
|
done
|
||||||
|
|
||||||
|
ln -s libresolv.9.dylib $out/lib/libresolv.dylib
|
||||||
|
|
||||||
for i in $out/lib/*.dylib $out/Library/Frameworks/CoreFoundation.framework/Versions/A/CoreFoundation; do
|
for i in $out/lib/*.dylib $out/Library/Frameworks/CoreFoundation.framework/Versions/A/CoreFoundation; do
|
||||||
if ! test -L $i; then
|
if test ! -L "$i" -a "$i" != "$out/lib/libSystem*.dylib"; then
|
||||||
echo patching $i
|
echo "Patching $i"
|
||||||
|
|
||||||
id=$(otool -D "$i" | tail -n 1)
|
id=$(otool -D "$i" | tail -n 1)
|
||||||
install_name_tool -id "$(dirname $i)/$(basename $id)" $i
|
install_name_tool -id "$(dirname $i)/$(basename $id)" $i
|
||||||
|
|
||||||
libs=$(otool -L "$i" | tail -n +2 | grep -v Libsystem | cat)
|
libs=$(otool -L "$i" | tail -n +2 | grep -v libSystem | cat)
|
||||||
if [ -n "$libs" ]; then
|
if [ -n "$libs" ]; then
|
||||||
install_name_tool -add_rpath $out/lib $i
|
install_name_tool -add_rpath $out/lib $i
|
||||||
fi
|
fi
|
||||||
@ -214,9 +249,24 @@ in rec {
|
|||||||
ln -s bash $out/bin/sh
|
ln -s bash $out/bin/sh
|
||||||
ln -s bzip2 $out/bin/bunzip2
|
ln -s bzip2 $out/bin/bunzip2
|
||||||
|
|
||||||
|
# Provide a gunzip script.
|
||||||
|
cat > $out/bin/gunzip <<EOF
|
||||||
|
#!$out/bin/sh
|
||||||
|
exec $out/bin/gzip -d "\$@"
|
||||||
|
EOF
|
||||||
|
chmod +x $out/bin/gunzip
|
||||||
|
|
||||||
|
# Provide fgrep/egrep.
|
||||||
|
echo "#! $out/bin/sh" > $out/bin/egrep
|
||||||
|
echo "exec $out/bin/grep -E \"\$@\"" >> $out/bin/egrep
|
||||||
|
echo "#! $out/bin/sh" > $out/bin/fgrep
|
||||||
|
echo "exec $out/bin/grep -F \"\$@\"" >> $out/bin/fgrep
|
||||||
|
|
||||||
cat >$out/bin/dsymutil << EOF
|
cat >$out/bin/dsymutil << EOF
|
||||||
#!$out/bin/sh
|
#!$out/bin/sh
|
||||||
EOF
|
EOF
|
||||||
|
|
||||||
|
chmod +x $out/bin/egrep $out/bin/fgrep $out/bin/dsymutil
|
||||||
'';
|
'';
|
||||||
|
|
||||||
allowedReferences = [ "out" ];
|
allowedReferences = [ "out" ];
|
||||||
|
Loading…
x
Reference in New Issue
Block a user