summaryrefslogtreecommitdiffstats
path: root/packaging/ios/build.sh
diff options
context:
space:
mode:
authorGravatar Tomaz Canabrava <tomaz.canabrava@gmail.com>2015-12-20 12:03:05 -0200
committerGravatar Dirk Hohndel <dirk@hohndel.org>2015-12-20 08:06:29 -0800
commit105d6987595b144fbd17093157a1a059fed6afaa (patch)
treebb53cc581f4a426283e76b9586912c3704e109ae /packaging/ios/build.sh
parenta639332edf0ac415dfc622f9e79814005731e56d (diff)
downloadsubsurface-105d6987595b144fbd17093157a1a059fed6afaa.tar.gz
Start the iOS cross compile
The build.sh and readme files are the same as the Android ones and I'll be changing them over time. The configure-for-ios.sh script is a file that manages to set everything, compilers frameworks and such, for iOS compilation. I'll probably dissecate the configure-for-ios.sh file and put it back on the build.sh, but not now. Signed-off-by: Tomaz Canabrava <tomaz.canabrava@gmail.com> Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
Diffstat (limited to 'packaging/ios/build.sh')
-rw-r--r--packaging/ios/build.sh280
1 files changed, 280 insertions, 0 deletions
diff --git a/packaging/ios/build.sh b/packaging/ios/build.sh
new file mode 100644
index 000000000..c0bd52df3
--- /dev/null
+++ b/packaging/ios/build.sh
@@ -0,0 +1,280 @@
+#!/bin/bash
+set -e
+
+PLATFORMPATH="/Applications/Xcode.app/Contents/Developer/Platforms"
+TOOLSPATH="/Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/bin"
+export IPHONEOS_DEPLOYMENT_TARGET="8.0"
+pwd=`pwd`
+
+# Which versions are we building against?
+SQLITE_VERSION=3081002
+LIBXML2_VERSION=2.9.3
+LIBXSLT_VERSION=1.1.28
+LIBZIP_VERSION=1.0.1
+LIBZIP_VERSION=0.11.2
+LIBGIT2_VERSION=0.23.4
+LIBSSH2_VERSION=1.6.0
+LIBUSB_VERSION=1.0.19
+OPENSSL_VERSION=1.0.1p
+LIBFTDI_VERSION=1.2
+
+target=i386
+hosttarget=i386
+platform=iPhoneSimulator
+
+export CC="$(xcrun -sdk iphoneos -find clang)"
+export CPP="$CC -E"
+export CFLAGS="-arch ${target} -isysroot $PLATFORMPATH/$platform.platform/Developer/SDKs/$platform$SDKVERSION.sdk -miphoneos-version-min=$SDKVERSION"
+export AR=$(xcrun -sdk iphoneos -find ar)
+export RANLIB=$(xcrun -sdk iphoneos -find ranlib)
+export CPPFLAGS="-arch ${target} -isysroot $PLATFORMPATH/$platform.platform/Developer/SDKs/$platform$SDKVERSION.sdk -miphoneos-version-min=$SDKVERSION"
+export LDFLAGS="-arch ${target} -isysroot $PLATFORMPATH/$platform.platform/Developer/SDKs/$platform$SDKVERSION.sdk"
+
+echo "BUILDCHAIN: ${BUILDCHAIN}"
+echo "ARCH: ${ARCH}"
+echo "PREFIX:${PREFIX}"
+
+if [ ! -e sqlite-autoconf-${SQLITE_VERSION}.tar.gz ] ; then
+ curl -O http://www.sqlite.org/2015/sqlite-autoconf-${SQLITE_VERSION}.tar.gz
+fi
+if [ ! -e sqlite-autoconf-${SQLITE_VERSION} ] ; then
+ tar -zxf sqlite-autoconf-${SQLITE_VERSION}.tar.gz
+fi
+if [ ! -e $PKG_CONFIG_LIBDIR/sqlite3.pc ] ; then
+ mkdir -p sqlite-build-$platform
+ pushd sqlite-build-$platform
+ ../sqlite-autoconf-${SQLITE_VERSION}/configure \
+ --host=$hosttarget-apple-darwin
+ --enable-static \
+ --disable-shared
+ make
+ make install
+ popd
+fi
+
+# if [ ! -e libxml2-${LIBXML2_VERSION}.tar.gz ] ; then
+# wget ftp://xmlsoft.org/libxml2/libxml2-${LIBXML2_VERSION}.tar.gz
+# fi
+# if [ ! -e libxml2-${LIBXML2_VERSION} ] ; then
+# tar -zxf libxml2-${LIBXML2_VERSION}.tar.gz
+# fi
+# if [ ! -e $PKG_CONFIG_LIBDIR/libxml-2.0.pc ] ; then
+# mkdir -p libxml2-build-$ARCH
+# pushd libxml2-build-$ARCH
+# ../libxml2-${LIBXML2_VERSION}/configure --host=${BUILDCHAIN} --prefix=${PREFIX} --without-python --without-iconv --enable-static --disable-shared
+# perl -pi -e 's/runtest\$\(EXEEXT\)//' Makefile
+# perl -pi -e 's/testrecurse\$\(EXEEXT\)//' Makefile
+# make
+# make install
+# popd
+# fi
+#
+# if [ ! -e libxslt-${LIBXSLT_VERSION}.tar.gz ] ; then
+# wget ftp://xmlsoft.org/libxml2/libxslt-${LIBXSLT_VERSION}.tar.gz
+# fi
+# if [ ! -e libxslt-${LIBXSLT_VERSION} ] ; then
+# tar -zxf libxslt-${LIBXSLT_VERSION}.tar.gz
+# # libxslt have too old config.sub for android
+# cp libxml2-${LIBXML2_VERSION}/config.sub libxslt-${LIBXSLT_VERSION}
+# fi
+# if [ ! -e $PKG_CONFIG_LIBDIR/libxslt.pc ] ; then
+# mkdir -p libxslt-build-$ARCH
+# pushd libxslt-build-$ARCH
+# ../libxslt-${LIBXSLT_VERSION}/configure --host=${BUILDCHAIN} --prefix=${PREFIX} --with-libxml-prefix=${PREFIX} --without-python --without-crypto --enable-static --disable-shared
+# make
+# make install
+# popd
+# fi
+#
+# if [ ! -e libzip-${LIBZIP_VERSION}.tar.gz ] ; then
+# wget http://www.nih.at/libzip/libzip-${LIBZIP_VERSION}.tar.gz
+# fi
+# if [ ! -e libzip-${LIBZIP_VERSION} ] ; then
+# tar -zxf libzip-${LIBZIP_VERSION}.tar.gz
+# fi
+# if [ ! -e $PKG_CONFIG_LIBDIR/libzip.pc ] ; then
+# mkdir -p libzip-build-$ARCH
+# pushd libzip-build-$ARCH
+# ../libzip-${LIBZIP_VERSION}/configure --host=${BUILDCHAIN} --prefix=${PREFIX} --enable-static --disable-shared
+# make
+# make install
+# popd
+# fi
+#
+# if [ ! -e openssl-${OPENSSL_VERSION}.tar.gz ] ; then
+# wget -O openssl-${OPENSSL_VERSION}.tar.gz http://www.openssl.org/source/openssl-${OPENSSL_VERSION}.tar.gz
+# fi
+# if [ ! -e openssl-build-$ARCH ] ; then
+# tar -zxf openssl-${OPENSSL_VERSION}.tar.gz
+# mv openssl-${OPENSSL_VERSION} openssl-build-$ARCH
+# fi
+# if [ ! -e $PKG_CONFIG_LIBDIR/libssl.pc ] ; then
+# pushd openssl-build-$ARCH
+# perl -pi -e 's/install: all install_docs install_sw/install: install_docs install_sw/g' Makefile.org
+# # Use env to make all these temporary, so they don't pollute later builds.
+# env SYSTEM=android \
+# CROSS_COMPILE="${BUILDCHAIN}-" \
+# MACHINE=$OPENSSL_MACHINE \
+# HOSTCC=gcc \
+# CC=gcc \
+# ANDROID_DEV=$PREFIX \
+# bash -x ./config shared no-ssl2 no-ssl3 no-comp no-hw no-engine --openssldir=$PREFIX
+# make depend
+# make
+# make install
+# popd
+# fi
+#
+# if [ ! -e libssh2-${LIBSSH2_VERSION}.tar.gz ] ; then
+# wget http://www.libssh2.org/download/libssh2-${LIBSSH2_VERSION}.tar.gz
+# fi
+# if [ ! -e libssh2-${LIBSSH2_VERSION} ] ; then
+# tar -zxf libssh2-${LIBSSH2_VERSION}.tar.gz
+# fi
+# if [ ! -e $PKG_CONFIG_LIBDIR/libssh2.pc ] ; then
+# mkdir -p libssh2-build-$ARCH
+# pushd libssh2-build-$ARCH
+# ../libssh2-${LIBSSH2_VERSION}/configure --host=${BUILDCHAIN} --prefix=${PREFIX} --enable-static --disable-shared
+# make
+# make install
+# # Patch away pkg-config dependency to zlib, its there, i promise
+# perl -pi -e 's/^(Requires.private:.*),zlib$/$1 $2/' $PKG_CONFIG_LIBDIR/libssh2.pc
+# popd
+# fi
+#
+# if [ ! -e libgit2-${LIBGIT2_VERSION}.tar.gz ] ; then
+# wget -O libgit2-${LIBGIT2_VERSION}.tar.gz https://github.com/libgit2/libgit2/archive/v${LIBGIT2_VERSION}.tar.gz
+# fi
+# if [ ! -e libgit2-${LIBGIT2_VERSION} ] ; then
+# tar -zxf libgit2-${LIBGIT2_VERSION}.tar.gz
+# fi
+# if [ ! -e $PKG_CONFIG_LIBDIR/libgit2.pc ] ; then
+# mkdir -p libgit2-build-$ARCH
+# pushd libgit2-build-$ARCH
+# cmake -DCMAKE_SYSTEM_NAME=Android -DSHA1_TYPE=builtin \
+# -DBUILD_CLAR=OFF -DBUILD_SHARED_LIBS=OFF \
+# -DCMAKE_INSTALL_PREFIX=${PREFIX} \
+# -DCURL=OFF \
+# -DUSE_SSH=ON \
+# -DOPENSSL_SSL_LIBRARY=${PREFIX}/lib/libssl.a \
+# -DOPENSSL_CRYPTO_LIBRARY=${PREFIX}/lib/libcrypto.a \
+# -DOPENSSL_INCLUDE_DIR=${PREFIX}/include/openssl \
+# -D_OPENSSL_VERSION=1.0.1p \
+# ../libgit2-${LIBGIT2_VERSION}/
+# make
+# make install
+# # Patch away pkg-config dependency to zlib, its there, i promise
+# perl -pi -e 's/^(Requires.private:.*)zlib(.*)$/$1 $2/' $PKG_CONFIG_LIBDIR/libgit2.pc
+# popd
+# fi
+#
+# if [ ! -e libusb-${LIBUSB_VERSION}.tar.gz ] ; then
+# wget -O libusb-${LIBUSB_VERSION}.tar.gz https://github.com/libusb/libusb/archive/v${LIBUSB_VERSION}.tar.gz
+# fi
+# if [ ! -e libusb-${LIBUSB_VERSION} ] ; then
+# tar -zxf libusb-${LIBUSB_VERSION}.tar.gz
+# fi
+# if ! grep -q libusb_set_android_open_callback libusb-${LIBUSB_VERSION}/libusb/libusb.h ; then
+# # Patch in our libusb callback
+# pushd libusb-${LIBUSB_VERSION}
+# patch -p1 < $SUBSURFACE_SOURCE/packaging/android/patches/libusb-android.patch
+# popd
+# fi
+# if [ ! -e libusb-${LIBUSB_VERSION}/configure ] ; then
+# pushd libusb-${LIBUSB_VERSION}
+# mkdir m4
+# autoreconf -i
+# popd
+# fi
+# if [ ! -e $PKG_CONFIG_LIBDIR/libusb-1.0.pc ] ; then
+# mkdir -p libusb-build-$ARCH
+# pushd libusb-build-$ARCH
+# ../libusb-${LIBUSB_VERSION}/configure --host=${BUILDCHAIN} --prefix=${PREFIX} --enable-static --disable-shared --disable-udev --enable-system-log
+# # --enable-debug-log
+# make
+# make install
+# popd
+# # Patch libusb-1.0.pc due to bug in there
+# # Fix comming in 1.0.20
+# sed -ie 's/Libs.private: -c/Libs.private: /' $PKG_CONFIG_LIBDIR/libusb-1.0.pc
+# fi
+#
+# if [ ! -e libftdi1-${LIBFTDI_VERSION}.tar.bz2 ] ; then
+# wget -O libftdi1-${LIBFTDI_VERSION}.tar.bz2 http://www.intra2net.com/en/developer/libftdi/download/libftdi1-${LIBFTDI_VERSION}.tar.bz2
+# fi
+# if [ ! -e libftdi1-${LIBFTDI_VERSION} ] ; then
+# tar -jxf libftdi1-${LIBFTDI_VERSION}.tar.bz2
+# fi
+# if [ ! -e $PKG_CONFIG_LIBDIR/libftdi1.pc ] && [ $PLATFORM != Darwin ] ; then
+# mkdir -p libftdi1-build-$ARCH
+# pushd libftdi1-build-$ARCH
+# cmake ../libftdi1-${LIBFTDI_VERSION} -DCMAKE_C_COMPILER=${CC} -DCMAKE_INSTALL_PREFIX=${PREFIX} -DCMAKE_PREFIX_PATH=${PREFIX} -DSTATICLIBS=ON -DPYTHON_BINDINGS=OFF -DDOCUMENTATION=OFF -DFTDIPP=OFF -DBUILD_TESTS=OFF -DEXAMPLES=OFF -DFTDI_EEPROM=OFF
+# make
+# make install
+# popd
+# fi
+# # Blast away the shared version to force static linking
+# if [ -e $PREFIX/lib/libftdi1.so ] ; then
+# rm $PREFIX/lib/libftdi1.so*
+# fi
+#
+# if [ ! -e $PKG_CONFIG_LIBDIR/libdivecomputer.pc ] ; then
+# mkdir -p libdivecomputer-build-$ARCH
+# pushd libdivecomputer-build-$ARCH
+# $SUBSURFACE_SOURCE/../libdivecomputer/configure --host=${BUILDCHAIN} --prefix=${PREFIX} --enable-static --disable-shared --enable-examples=no
+# make
+# make install
+# popd
+# fi
+#
+# if [ ! -e qt-android-cmake ] ; then
+# git clone git://github.com/LaurentGomila/qt-android-cmake.git
+# else
+# pushd qt-android-cmake
+# git pull
+# popd
+# fi
+#
+# # Should we build the mobile ui or the desktop ui?
+# if [ ! -z "$SUBSURFACE_MOBILE" ] ; then
+# mkdir -p subsurface-mobile-build-$ARCH
+# cd subsurface-mobile-build-$ARCH
+# MOBILE_CMAKE="-DSUBSURFACE_TARGET_EXECUTABLE=MobileExecutable"
+# # FIXME: We should install as a different package and name to.
+# else
+# mkdir -p subsurface-build-$ARCH
+# cd subsurface-build-$ARCH
+# fi
+#
+# # somehting in the qt-android-cmake-thingies mangles your path, so thats why we need to hard-code ant and pkg-config here.
+# if [ $PLATFORM = Darwin ] ; then
+# ANT=/usr/local/bin/ant
+# FTDI=OFF
+# else
+# ANT=/usr/bin/ant
+# FTDI=ON
+# fi
+# PKGCONF=$(which pkg-config)
+# cmake $MOBILE_CMAKE \
+# -DQT_ANDROID_ANT=${ANT} \
+# -DPKG_CONFIG_EXECUTABLE=${PKGCONF} \
+# -DQT_ANDROID_SDK_ROOT=$ANDROID_SDK_ROOT \
+# -DQT_ANDROID_NDK_ROOT=$ANDROID_NDK_ROOT \
+# -DCMAKE_TOOLCHAIN_FILE=$BUILDROOT/qt-android-cmake/toolchain/android.toolchain.cmake \
+# -DQT_ANDROID_CMAKE=$BUILDROOT/qt-android-cmake/AddQtAndroidApk.cmake \
+# -DFORCE_LIBSSH=ON \
+# -DLIBDC_FROM_PKGCONFIG=ON \
+# -DLIBGIT2_FROM_PKGCONFIG=ON \
+# -DNO_MARBLE=ON \
+# -DNO_PRINTING=ON \
+# -DNO_USERMANUAL=ON \
+# -DFBSUPPORT=OFF \
+# -DCMAKE_PREFIX_PATH:UNINITIALIZED=${QT5_ANDROID}/android_${QT_ARCH}/lib/cmake \
+# -DCMAKE_BUILD_TYPE=Debug \
+# -DFTDISUPPORT=${FTDI} \
+# $SUBSURFACE_SOURCE
+# make
+# #make install INSTALL_ROOT=android_build
+# # bug in androiddeployqt? why is it looking for something with the builddir in it?
+# #ln -fs android-libsubsurface.so-deployment-settings.json android-libsubsurface-build-${ARCH}.so-deployment-settings.json
+# #$QT5_ANDROID_BIN/androiddeployqt --output android_build