| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277 | 
							- #!/bin/sh
 
- #
 
- # Build a fat binary for iOS
 
- # Based on fatbuild.sh and code from the Ignifuga Game Engine
 
- # Number of CPUs (for make -j)
 
- NCPU=`sysctl -n hw.ncpu`
 
- if test x$NJOB = x; then
 
-     NJOB=$NCPU
 
- fi
 
- # SDK path
 
- XCODE_PATH=`xcode-select --print-path`
 
- if [ -z "$XCODE_PATH" ]; then
 
-     echo "Could not find XCode location (use xcode-select -switch to set the correct path)"
 
-     exit 1
 
- fi
 
- prepare_environment() {
 
-     ARCH=$1
 
-     
 
-     if test x$SDK_VERSION = x; then
 
-       export SDK_VERSION=`xcodebuild -showsdks | grep iphoneos | sed "s|.*iphoneos||"`
 
-       if [ -z "$XCODE_PATH" ]; then
 
-           echo "Could not find a valid iOS SDK"
 
-           exit 1
 
-       fi  
 
-     fi
 
-     
 
-     case $ARCH in
 
-         armv6)
 
-             DEV_PATH="$XCODE_PATH/Platforms/iPhoneOS.platform/Developer"
 
-             SDK_PATH="$DEV_PATH/SDKs/iPhoneOS$SDK_VERSION.sdk"
 
-             ;;
 
-         armv7)
 
-             DEV_PATH="$XCODE_PATH/Platforms/iPhoneOS.platform/Developer"
 
-             SDK_PATH="$DEV_PATH/SDKs/iPhoneOS$SDK_VERSION.sdk"
 
-             ;;
 
-         i386)
 
-             DEV_PATH="$XCODE_PATH/Platforms/iPhoneSimulator.platform/Developer"
 
-             SDK_PATH="$DEV_PATH/SDKs/iPhoneSimulator$SDK_VERSION.sdk"
 
-             ;;
 
-         *)
 
-             echo "Unknown Architecture $ARCH"
 
-             exit 1
 
-             ;;
 
-     esac
 
-     if [ ! -d "$SDK_PATH" ]; then
 
-         echo "Could not find iOS SDK at $SDK_PATH"
 
-         exit 1
 
-     fi
 
-     if test x$MIN_OS_VERSION = x; then
 
-         export MIN_OS_VERSION="3.0"
 
-     fi
 
-     
 
-     # Environment flags
 
-     CFLAGS="-g -O2 -pipe -no-cpp-precomp -isysroot $SDK_PATH \
 
-             -miphoneos-version-min=$MIN_OS_VERSION -I$SDK_PATH/usr/include/"
 
-     LDFLAGS="-L$SDK_PATH/usr/lib/ -isysroot $SDK_PATH \
 
-              -miphoneos-version-min=$MIN_OS_VERSION -static-libgcc"
 
-     export CXXFLAGS="$CFLAGS"
 
-     export CXXCPP="$DEV_PATH/usr/bin/llvm-cpp-4.2"
 
-     export CPP="$CXXCPP"
 
-     export CXX="$DEV_PATH/usr/bin/llvm-g++-4.2"
 
-     export CC="$DEV_PATH/usr/bin/llvm-gcc-4.2"
 
-     export LD="$DEV_PATH/usr/bin/ld"
 
-     export AR="$DEV_PATH/usr/bin/ar"
 
-     export AS="$DEV_PATH/usr/bin/ls"
 
-     export NM="$DEV_PATH/usr/bin/nm"
 
-     export RANLIB="$DEV_PATH/usr/bin/ranlib"
 
-     export STRIP="$DEV_PATH/usr/bin/strip"
 
-     
 
-     # We dynamically load X11, so using the system X11 headers is fine.
 
-     CONFIG_FLAGS="--disable-shared --enable-static"
 
-     
 
-     case $ARCH in
 
-         armv6)
 
-             export CONFIG_FLAGS="$CONFIG_FLAGS --host=armv6-apple-darwin"
 
-             export CFLAGS="$CFLAGS -arch armv6"
 
-             export LDFLAGS="$LDFLAGS -arch armv6"
 
-             ;;
 
-         armv7)
 
-             export CONFIG_FLAGS="$CONFIG_FLAGS --host=armv7-apple-darwin"
 
-             export CFLAGS="$CFLAGS -arch armv7"
 
-             export LDFLAGS="$LDFLAGS -arch armv7"
 
-             ;;
 
-         i386)
 
-             export CONFIG_FLAGS="$CONFIG_FLAGS --host=i386-apple-darwin"
 
-             export CFLAGS="$CFLAGS -arch i386"
 
-             export LDFLAGS="$LDFLAGS -arch i386"
 
-             ;;
 
-         *)
 
-             echo "Unknown Architecture $ARCH"
 
-             exit 1
 
-             ;;
 
-     esac
 
- }
 
- prepare_environment "armv6"
 
- echo "Building with iOS SDK v$SDK_VERSION for iOS >= $MIN_OS_VERSION"
 
- #
 
- # Find the configure script
 
- #
 
- srcdir=`dirname $0`/..
 
- srcdir=`cd $srcdir && pwd`
 
- auxdir=$srcdir/build-scripts
 
- cd $srcdir
 
- #
 
- # Figure out which phase to build:
 
- # all,
 
- # configure, configure-armv6, configure-armv7, configure-i386
 
- # make, make-armv6, make-armv7, make-i386, merge
 
- # clean
 
- if test x"$1" = x; then
 
-     phase=all
 
- else
 
-     phase="$1"
 
- fi
 
- case $phase in
 
-     all)
 
-         configure_armv6="yes"
 
-         configure_armv7="yes"
 
-         configure_i386="yes"
 
-         make_armv6="yes"
 
-         make_armv7="yes"
 
-         make_i386="yes"
 
-         merge="yes"
 
-         ;;
 
-     configure)
 
-         configure_armv6="yes"
 
-         configure_armv7="yes"
 
-         configure_i386="yes"
 
-         ;;
 
-     configure-armv6)
 
-         configure_armv6="yes"
 
-         ;;
 
-     configure-armv7)
 
-         configure_armv7="yes"
 
-         ;;
 
-     configure-i386)
 
-         configure_i386="yes"
 
-         ;;
 
-     make)
 
-         make_armv6="yes"
 
-         make_armv7="yes"
 
-         make_i386="yes"
 
-         merge="yes"
 
-         ;;
 
-     make-armv6)
 
-         make_armv6="yes"
 
-         ;;
 
-     make-armv7)
 
-         make_armv7="yes"
 
-         ;;
 
-     make-i386)
 
-         make_i386="yes"
 
-         ;;
 
-     merge)
 
-         merge="yes"
 
-         ;;
 
-     clean)
 
-         clean_armv6="yes"
 
-         clean_armv7="yes"
 
-         clean_i386="yes"
 
-         ;;
 
-     clean-armv6)
 
-         clean_armv6="yes"
 
-         ;;
 
-     clean-armv7)
 
-         clean_armv7="yes"
 
-         ;;
 
-     clean-i386)
 
-         clean_i386="yes"
 
-         ;;
 
-     *)
 
-         echo "Usage: $0 [all|configure[-armv6|-armv7|-i386]|make[-armv6|-armv7|-i386]|merge|clean[-armv6|-armv7|-i386]]"
 
-         exit 1
 
-         ;;
 
- esac
 
- #
 
- # Create the build directories
 
- #
 
- for dir in build build/armv6 build/armv7 build/i386; do
 
-     if test -d $dir; then
 
-         :
 
-     else
 
-         mkdir $dir || exit 1
 
-     fi
 
- done
 
- #
 
- # Build the armv6 binary
 
- #
 
- prepare_environment "armv6"
 
- if test x$configure_armv6 = xyes; then
 
-     (cd build/armv6 && \
 
-      sh ../../configure $CONFIG_FLAGS CC="$CC" CXX="$CXX" CFLAGS="$CFLAGS" LDFLAGS="$LDFLAGS") || exit 2
 
-      # configure is not yet fully ready for iOS, some manual patching is required
 
-      cp include/* build/armv6/include
 
-      cp include/SDL_config_iphoneos.h build/armv6/include/SDL_config.h || exit 2
 
-      sed -i "" -e "s|^EXTRA_CFLAGS.*|EXTRA_CFLAGS=-I./include|g" build/armv6/Makefile || exit 2
 
-      sed -i "" -e "s|^EXTRA_LDFLAGS.*|EXTRA_LDFLAGS=-lm|g" build/armv6/Makefile || exit 2
 
- fi
 
- if test x$make_armv6 = xyes; then
 
-     (cd build/armv6 && make -j$NJOB) || exit 3
 
- fi
 
- #
 
- # Build the armv7 binary
 
- #
 
- prepare_environment "armv7"
 
- if test x$configure_armv7 = xyes; then
 
-     (cd build/armv7 && \
 
-      sh ../../configure $CONFIG_FLAGS CC="$CC" CXX="$CXX" CFLAGS="$CFLAGS" LDFLAGS="$LDFLAGS") || exit 2
 
-      # configure is not yet fully ready for iOS, some manual patching is required
 
-      cp include/* build/armv7/include
 
-      cp include/SDL_config_iphoneos.h build/armv7/include/SDL_config.h || exit 2
 
-      sed -i "" -e "s|^EXTRA_CFLAGS.*|EXTRA_CFLAGS=-I./include|g" build/armv7/Makefile || exit 2
 
-      sed -i "" -e "s|^EXTRA_LDFLAGS.*|EXTRA_LDFLAGS=-lm|g" build/armv7/Makefile || exit 2
 
- fi
 
- if test x$make_armv7 = xyes; then
 
-     (cd build/armv7 && make -j$NJOB) || exit 3
 
- fi
 
- #
 
- # Build the i386 binary
 
- #
 
- prepare_environment "i386"
 
- if test x$configure_i386 = xyes; then
 
-     (cd build/i386 && \
 
-      sh ../../configure $CONFIG_FLAGS CC="$CC" CXX="$CXX" CFLAGS="$CFLAGS" LDFLAGS="$LDFLAGS") || exit 2
 
-      # configure is not yet fully ready for iOS, some manual patching is required
 
-      cp include/* build/i386/include
 
-      cp include/SDL_config_iphoneos.h build/i386/include/SDL_config.h || exit 2
 
-      sed -i "" -e "s|^EXTRA_CFLAGS.*|EXTRA_CFLAGS=-I./include|g" build/i386/Makefile || exit 2
 
-      sed -i "" -e "s|^EXTRA_LDFLAGS.*|EXTRA_LDFLAGS=-lm|g" build/i386/Makefile || exit 2
 
- fi
 
- if test x$make_i386 = xyes; then
 
-     (cd build/i386 && make -j$NJOB) || exit 3
 
- fi
 
- #
 
- # Combine into fat binary
 
- #
 
- if test x$merge = xyes; then
 
-     output=ios/lib
 
-     sh $auxdir/mkinstalldirs build/$output
 
-     cd build
 
-     target=`find . -mindepth 4 -maxdepth 4 -type f -name '*.dylib' | head -1 | sed 's|.*/||'`
 
-     (lipo -create -o $output/libSDL2.a armv6/build/.libs/libSDL2.a armv7/build/.libs/libSDL2.a i386/build/.libs/libSDL2.a &&
 
-      lipo -create -o $output/libSDL2main.a armv6/build/libSDL2main.a armv7/build/libSDL2main.a i386/build/libSDL2main.a &&
 
-      cp -r armv6/include ios
 
-      echo "Build complete!" &&
 
-      echo "Files can be found under the build/ios directory.") || exit 4
 
-     cd ..
 
- fi
 
- #
 
- # Clean up
 
- #
 
- do_clean()
 
- {
 
-     echo $*
 
-     $* || exit 6
 
- }
 
- if test x$clean_armv6 = xyes; then
 
-     do_clean rm -r build/armv6
 
- fi
 
- if test x$clean_armv7 = xyes; then
 
-     do_clean rm -r build/armv7
 
- fi
 
- if test x$clean_i386 = xyes; then
 
-     do_clean rm -r build/i386
 
- fi
 
 
  |