ar-wrapper
758 Bytes
#!/bin/sh
# This wrapper takes the arguments: <ar> <operation> <archive> <files...>
# <ar> can be any ar implementation.
# <operations>, <archive> and <files...> are the normal arguments to <ar>.
#
# OS X's ar implementation has the problem, that it refuses to create empty archives.
# This wrapper will copy a provided empty .a file to <archive> if it was told to.
# If <operations> contains "r", and there are no <files...> given.
if [ "${2#*r}" != "$2" ] && [ "$#" -eq 3 ]; then
# If <archive> exists, do nothing, otherwise copy an empty archive.
[ -e "$3" ] || cp "${0%ar-wrapper}/empty.a" "$3"
else
# Otherwise act like this wrapper was not present.
"$@"
fi
# Return the exit code of the last invocation ("[", "cp", or <ar>).
exit $?