OSX build: mighty tweak osxbuild.sh and link to LibPNG from Fink on x86_64.

The build script now has two more presets: helix and installtools
(which was previously attempted after the build; untested). Also,
 - when detecting git, run commands such that the SVN repo isn't accessed
 - package kextract, kgroup and arttool into tools/ in the zip
 - try to exit on failure in some places, though that doesn't seem to work

git-svn-id: https://svn.eduke32.com/eduke32@2852 1a8010ca-5511-0410-912e-c29ae57300e0
This commit is contained in:
helixhorned 2012-07-29 23:35:12 +00:00
parent b1f98d241e
commit 19d426ba02
2 changed files with 121 additions and 74 deletions

View file

@ -310,8 +310,8 @@ ifeq ($(PLATFORM),WINDOWS)
else else
ifeq ($(PLATFORM),DARWIN) ifeq ($(PLATFORM),DARWIN)
ifneq ($(USE_LIBPNG),0) ifneq ($(USE_LIBPNG),0)
BUILDCFLAGS+= -I/opt/local/include -I/usr/local/include BUILDCFLAGS+= -I/opt/local/include -I/sw/include -I/usr/local/include
LIBS+= -L/opt/local/lib -L/usr/local/lib -lpng -lz LIBS+= -L/opt/local/lib -L/usr/local/lib -lpng # -lz
endif endif
else else
LIBS+= -lpng -lz LIBS+= -lpng -lz

View file

@ -8,8 +8,10 @@ build86=1
build64=1 build64=1
buildmain=1 buildmain=1
buildtools=0 buildtools=0
installtools=0
builddebug=0 builddebug=0
pack=1 pack=1
iamhelix=0
# Enforce OS: # Enforce OS:
if [ `uname -s` != Darwin ]; then if [ `uname -s` != Darwin ]; then
@ -37,12 +39,22 @@ fi
# Parse arguments: # Parse arguments:
for i in $*; do for i in $*; do
case $i in case $i in
# onlyzip: For Helixhorned's convenience. # onlyzip, helix: For Helixhorned's convenience.
onlyzip) onlyzip)
buildmain=0 buildmain=0
buildtools=0 buildtools=0
pack=1 pack=1
;; ;;
helix)
iamhelix=1
buildppc=0
build86=1
build64=1
buildmain=1
buildtools=1
builddebug=0
pack=1
;;
# For the convenience of universal distributors: # For the convenience of universal distributors:
dist) dist)
@ -73,6 +85,18 @@ for i in $*; do
pack=1 pack=1
;; ;;
# misc.
installtools)
buildppc=0
build86=0
build64=0
buildmain=0
buildtools=0
builddebug=0
pack=0
installtools=1
;;
--buildppc=*) --buildppc=*)
buildppc=${i#*=} buildppc=${i#*=}
;; ;;
@ -106,7 +130,7 @@ for i in $*; do
echo " [--main=<0|1>] [--tools=<0|1>]" echo " [--main=<0|1>] [--tools=<0|1>]"
echo " [--pack=<0|1>]" echo " [--pack=<0|1>]"
echo "presets:" echo "presets:"
echo " [onlyzip] [dist] [disttools] [full]" echo " [onlyzip] [dist] [disttools] [full] [installtools]"
exit 1 exit 1
;; ;;
esac esac
@ -123,11 +147,12 @@ if [ `expr $darwinversion \> 10` == 1 ]; then
fi fi
# Detect versioning systems and pull the revision number: # Detect versioning systems and pull the revision number:
rev=`svn info | grep Revision | awk '{ print $2 }'` rev=$(svn info 2> /dev/null | grep Revision | awk '{ print $2 }')
vc=svn vc=svn
if [ -z "$rev" ]; then if [ -z "$rev" ]; then
vc=git vc=git
rev=`git svn info | grep 'Revision' | awk '{ print $2 }'` rev=$(git log | grep 'git-svn-id:' | head -n 1 | sed -E 's/.*\@([0-9]+).*/\1/')
echo "Detected git repository, revision r$rev"
fi fi
if [ -n "$rev" ]; then if [ -n "$rev" ]; then
@ -173,9 +198,12 @@ if [ $buildppc == 1 ]; then
fi fi
# Building the buildtools: # Building the buildtools:
if [ $buildtools == 1 ] && [ -d "build" ]; then if [ $buildtools$installtools != 00 ] && [ -d "build" ]; then
cd build cd build
makecmd="make -k"
if [ $buildtools == 1 ]; then
rm -f *{.x86,.x64,.ppc} rm -f *{.x86,.x64,.ppc}
make veryclean make veryclean
EXESUFFIX_OVERRIDE=.debug make veryclean EXESUFFIX_OVERRIDE=.debug make veryclean
@ -183,33 +211,35 @@ if [ $buildtools == 1 ] && [ -d "build" ]; then
if [ $build64 == 1 ]; then if [ $build64 == 1 ]; then
if [ $builddebug == 1 ]; then if [ $builddebug == 1 ]; then
dobuildtools "x86_64 debug" \ dobuildtools "x86_64 debug" \
"ARCH='-arch x86_64' EXESUFFIX_OVERRIDE=.debug.x64 $commonargs RELEASE=0 BUILD32_ON_64=0 USE_LIBVPX=1 make -k utils" "ARCH='-arch x86_64' EXESUFFIX_OVERRIDE=.debug.x64 $commonargs RELEASE=0 BUILD32_ON_64=0 USE_LIBVPX=1 $makecmd utils"
fi fi
dobuildtools "x86_64 release" \ dobuildtools "x86_64 release" \
"ARCH='-arch x86_64' EXESUFFIX_OVERRIDE=.x64 $commonargs RELEASE=1 BUILD32_ON_64=0 USE_LIBVPX=1 make -k utils" "ARCH='-arch x86_64' EXESUFFIX_OVERRIDE=.x64 $commonargs RELEASE=1 BUILD32_ON_64=0 USE_LIBVPX=1 $makecmd utils"
fi fi
if [ $build86 == 1 ]; then if [ $build86 == 1 ]; then
if [ $builddebug == 1 ]; then if [ $builddebug == 1 ]; then
dobuildtools "x86 debug" \ dobuildtools "x86 debug" \
"EXESUFFIX_OVERRIDE=.debug.x86 $commonargs RELEASE=0 BUILD32_ON_64=1 USE_LIBVPX=0 make -k utils" "EXESUFFIX_OVERRIDE=.debug.x86 $commonargs RELEASE=0 BUILD32_ON_64=1 USE_LIBVPX=0 $makecmd utils"
fi fi
dobuildtools "x86 release" \ dobuildtools "x86 release" \
"EXESUFFIX_OVERRIDE=.x86 $commonargs RELEASE=1 BUILD32_ON_64=1 USE_LIBVPX=0 make -k utils" "EXESUFFIX_OVERRIDE=.x86 $commonargs RELEASE=1 BUILD32_ON_64=1 USE_LIBVPX=0 $makecmd utils"
fi fi
if [ $buildppc == 1 ]; then if [ $buildppc == 1 ]; then
if [ $builddebug == 1 ]; then if [ $builddebug == 1 ]; then
dobuildtools "PowerPC debug" \ dobuildtools "PowerPC debug" \
"ARCH='-arch ppc' EXESUFFIX_OVERRIDE=.debug.ppc $commonargs RELEASE=0 BUILD32_ON_64=0 USE_LIBVPX=0 make -k utils" "ARCH='-arch ppc' EXESUFFIX_OVERRIDE=.debug.ppc $commonargs RELEASE=0 BUILD32_ON_64=0 USE_LIBVPX=0 $makecmd utils"
fi fi
dobuildtools "PowerPC release" \ dobuildtools "PowerPC release" \
"ARCH='-arch ppc' EXESUFFIX_OVERRIDE=.ppc $commonargs RELEASE=1 BUILD32_ON_64=0 USE_LIBVPX=0 make -k utils" "ARCH='-arch ppc' EXESUFFIX_OVERRIDE=.ppc $commonargs RELEASE=1 BUILD32_ON_64=0 USE_LIBVPX=0 $makecmd utils"
fi fi
mkdir -p ../tools
echo buildtools: Creating fat binaries. echo buildtools: Creating fat binaries.
utils=`make printutils && EXESUFFIX_OVERRIDE=.debug make printutils` utils=`make printutils && EXESUFFIX_OVERRIDE=.debug make printutils`
for i in $utils; do for i in $utils; do
@ -220,15 +250,19 @@ if [ $buildtools == 1 ] && [ -d "build" ]; then
fi fi
done done
if [ -n "$binaries" ]; then if [ -n "$binaries" ]; then
lipo -create $binaries -output $i lipo -create $binaries -output $i || exit 1
# ln -f -s ../build/$i ../tools/$i || exit 1
cp -f $i ../tools/$i || exit 1
fi fi
done done
fi
if [ $installtools == 1 ]; then
if [ -d "/opt/local/bin" ]; then if [ -d "/opt/local/bin" ]; then
echo buildtools: Installing to MacPorts search path. echo buildtools: Installing to MacPorts search path.
for i in $utils; do for i in $utils; do
if [ -f "$i" ]; then if [ -f "$i" ]; then
cp -f "$i" "/opt/local/bin/" cp -f "$i" "/opt/local/bin/" || exit 1
fi fi
done done
fi fi
@ -237,10 +271,11 @@ if [ $buildtools == 1 ] && [ -d "build" ]; then
echo buildtools: Installing to Homebrew search path. echo buildtools: Installing to Homebrew search path.
for i in $utils; do for i in $utils; do
if [ -f "$i" ]; then if [ -f "$i" ]; then
cp -f "$i" "/usr/local/bin/" cp -f "$i" "/usr/local/bin/" || exit 1
fi fi
done done
fi fi
fi
cd .. cd ..
fi fi
@ -250,28 +285,34 @@ if [ $buildmain == 1 ]; then
rm -f {eduke32,mapster32}{.debug,}{.x86,.x64,.ppc,} rm -f {eduke32,mapster32}{.debug,}{.x86,.x64,.ppc,}
rm -rf {EDuke32,Mapster32}{.debug,}.app rm -rf {EDuke32,Mapster32}{.debug,}.app
if [ $build64 == 1 ]; then if [ $iamhelix == 1 ]; then
if [ $builddebug == 1 ]; then makecmd="make -j 2"
dobuildem debug.x64 "ARCH='-arch x86_64' $commonargs RELEASE=0 BUILD32_ON_64=0 USE_LIBVPX=1 make" else
makecmd="make"
fi fi
dobuildem x64 "ARCH='-arch x86_64' $commonargs RELEASE=1 BUILD32_ON_64=0 USE_LIBVPX=1 make" if [ $build64 == 1 ]; then
if [ $builddebug == 1 ]; then
dobuildem debug.x64 "ARCH='-arch x86_64' $commonargs RELEASE=0 BUILD32_ON_64=0 $makecmd"
fi
dobuildem x64 "ARCH='-arch x86_64' $commonargs RELEASE=1 BUILD32_ON_64=0 $makecmd"
fi fi
if [ $build86 == 1 ]; then if [ $build86 == 1 ]; then
if [ $builddebug == 1 ]; then if [ $builddebug == 1 ]; then
dobuildem debug.x86 "$commonargs RELEASE=0 BUILD32_ON_64=1 USE_LIBVPX=0 make" dobuildem debug.x86 "$commonargs RELEASE=0 BUILD32_ON_64=1 USE_LIBPNG=0 USE_LIBVPX=0 $makecmd"
fi fi
dobuildem x86 "$commonargs RELEASE=1 BUILD32_ON_64=1 USE_LIBVPX=0 make" dobuildem x86 "$commonargs RELEASE=1 BUILD32_ON_64=1 USE_LIBPNG=0 USE_LIBVPX=0 $makecmd"
fi fi
if [ $buildppc == 1 ]; then if [ $buildppc == 1 ]; then
if [ $builddebug == 1 ]; then if [ $builddebug == 1 ]; then
dobuildem debug.ppc "ARCH='-arch ppc' $commonargs RELEASE=0 BUILD32_ON_64=0 USE_LIBVPX=0 make" dobuildem debug.ppc "ARCH='-arch ppc' $commonargs RELEASE=0 BUILD32_ON_64=0 USE_LIBPNG=0 USE_LIBVPX=0 $makecmd"
fi fi
dobuildem ppc "ARCH='-arch ppc' $commonargs RELEASE=1 BUILD32_ON_64=0 USE_LIBVPX=0 make" dobuildem ppc "ARCH='-arch ppc' $commonargs RELEASE=1 BUILD32_ON_64=0 USE_LIBPNG=0 USE_LIBVPX=0 $makecmd"
fi fi
fi fi
@ -283,7 +324,7 @@ elif [ "$vc" == "git" ]; then
fi fi
# Duplicating .app bundles for debug build: # Duplicating .app bundles for debug build:
if [ $builddebug == 1 ]; then if [ $builddebug == 1 ] || [ $pack == 1 ]; then
for i in Mapster32 EDuke32; do for i in Mapster32 EDuke32; do
if [ -d "$i.app" ]; then if [ -d "$i.app" ]; then
cp -RP "$i.app" "$i.debug.app" cp -RP "$i.app" "$i.debug.app"
@ -292,7 +333,7 @@ if [ $builddebug == 1 ]; then
fi fi
# Begin assembling archive contents: # Begin assembling archive contents:
arcontents="README.OSX Changelog.txt" arcontents="README.OSX Changelog.txt tools/kextract tools/kgroup tools/arttool"
echo Creating fat binaries. echo Creating fat binaries.
success=0 success=0
@ -304,6 +345,7 @@ for i in {eduke32,mapster32}{.debug,}; do
success=1 success=1
fi fi
done done
if [ -n "$binaries" ]; then if [ -n "$binaries" ]; then
lipo -create $binaries -output $i lipo -create $binaries -output $i
app=${i//eduke32/EDuke32} app=${i//eduke32/EDuke32}
@ -315,6 +357,7 @@ done
# Almost done... # Almost done...
if [ $success == 1 ]; then if [ $success == 1 ]; then
echo "Generating README.OSX and Changelog.txt"
# Output README.OSX: # Output README.OSX:
let "darwinversion -= 4" let "darwinversion -= 4"
@ -323,10 +366,11 @@ if [ $success == 1 ]; then
echo "EDuke32 home: http://www.eduke32.com" >> README.OSX echo "EDuke32 home: http://www.eduke32.com" >> README.OSX
echo "OS X build discussion on Duke4.net: http://forums.duke4.net/topic/4242-building-eduke-on-mac-os-x/" >> README.OSX echo "OS X build discussion on Duke4.net: http://forums.duke4.net/topic/4242-building-eduke-on-mac-os-x/" >> README.OSX
echo "The 64-bit build in this archive has LibVPX (http://www.webmproject.org/code/)" >> README.OSX echo "The 64-bit build in this archive has LibVPX (http://www.webmproject.org/code/)" >> README.OSX
echo "from MacPorts (http://www.macports.org/) statically linked into it." >> README.OSX echo "from MacPorts (http://www.macports.org/) and" >> README.OSX
echo "LibPNG from Fink (http://www.finkproject.org/) statically linked into it." >> README.OSX
# Generate Changelog: # Generate Changelog:
lastrevision=`ls -A1 eduke32-osx* | tail -n1 | cut -d- -f3 | cut -d. -f1` lastrevision=$(ls -A1 eduke32-osx* | tail -n1 | cut -d- -f3 | cut -d. -f1)
if [ -z $lastrevision ]; then if [ -z $lastrevision ]; then
let lastrevision=rev-1 let lastrevision=rev-1
@ -339,12 +383,15 @@ if [ $success == 1 ]; then
if [ "$vc" == "svn" ]; then if [ "$vc" == "svn" ]; then
svn log -r $rev:$lastrevision > Changelog.txt svn log -r $rev:$lastrevision > Changelog.txt
elif [ "$vc" == "git" ]; then elif [ "$vc" == "git" ]; then
git svn log -r $rev:$lastrevision > Changelog.txt commitid=$(git log --grep="git-svn-id: .*@$lastrevision" -n 1 | grep -E '^commit ' | head -n 1 | awk '{print $2}')
# Get the commit messages and strip the email addresses
git log $commitid..HEAD | sed 's/<.*@.*>//g' > Changelog.txt
fi fi
# Package # Package
if [ $pack == 1 ]; then if [ $pack == 1 ]; then
arfilename="eduke32-osx-$rev.zip" arfilename="eduke32-osx-$rev.zip"
echo "Packing distribution into $arfilename"
rm -f "$arfilename" rm -f "$arfilename"
zip -r -y "$arfilename" $arcontents -x "*.svn*" "*.git*" zip -r -y "$arfilename" $arcontents -x "*.svn*" "*.git*"
fi fi