iOS build: Updated build script

This now only builds all the prerequisits but not the actual Subsurface
binaries - that will be done with qmake (oh the irony) in a later commit.

[Dirk Hohndel: refactored the patches]

Signed-off-by: Tomaz Canabrava <tomaz.canabrava@gmail.com>
Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
This commit is contained in:
Tomaz Canabrava 2016-03-06 06:41:11 -08:00 committed by Dirk Hohndel
parent e9e453b009
commit 74e6e0ed37

View file

@ -1,46 +1,56 @@
#!/bin/bash #!/bin/bash
set -e set -x
TOP=$(pwd) TOP=$(pwd)
SUBSURFACE_SOURCE=${TOP}/../subsurface SUBSURFACE_SOURCE=${TOP}/../../../subsurface
IOS_QT=${TOP}/Qt IOS_QT=${TOP}/Qt
# Build Subsurface-mobile by default
SUBSURFACE_MOBILE=1
mkdir -p $TOP/install-root/lib $TOP/install-root/bin $TOP/install-root/include mkdir -p $TOP/install-root/lib $TOP/install-root/bin $TOP/install-root/include
PKG_CONFIG_LIBDIR=$TOP/install-root/lib/pkgconfig PKG_CONFIG_LIBDIR=$TOP/install-root/lib/pkgconfig
# Build architecture, [armv7|armv7s|arm64|i386|x86_64] export PKG_CONFIG_PATH=$PKG_CONFIG_LIBDIR
export ARCH=i386
#arm-apple-darwin, arch64-apple-darwin, i386-apple-darwin*, x86_64-apple-darwin* declare TOOLCHAIN_FILE="iPhoneSimulatorCMakeToolchain"
export BUILDCHAIN=i386-apple-darwin* declare -x PREFIX=$TOP/install-root
declare -x SDK_NAME="iphonesimulator"
# Build architecture, [armv7|armv7s|arm64|i386|x86_64]
declare -x ARCH_NAME="x86_64"
declare -x ARCH=$ARCH_NAME
declare -x SDK_DIR=`xcrun --sdk $SDK_NAME --show-sdk-path`
declare -x PLATFORM_DIR=`xcrun --sdk $SDK_NAME --show-sdk-platform-path`
declare -x CC=`xcrun -sdk $SDK_NAME -find clang`
declare -x CXX=`xcrun -sdk $SDK_NAME -find clang++`
declare -x LD=`xcrun -sdk $SDK_NAME -find ld`
declare -x CFLAGS="-arch $ARCH_NAME -isysroot $SDK_DIR -miphoneos-version-min=6.0 -I$SDK_DIR/usr/include"
declare -x CXXFLAGS="$CFLAGS"
declare -x LDFLAGS="$CFLAGS -lpthread -lc++ -L$SDK_DIR/usr/lib"
export BUILDCHAIN=${ARCH_NAME}-apple-darwin
#iphonesimulator or iphoneos // SIMULATOR or OS #iphonesimulator or iphoneos // SIMULATOR or OS
export SDK=iphonesimulator export SDK=iphonesimulator
export IOS_PLATFORM=SIMULATOR export IOS_PLATFORM=SIMULATOR64
export SDKVERSION=$(xcrun --sdk $SDK --show-sdk-version) # current version # openssl build stuff.
export SDKROOT=$(xcrun --sdk $SDK --show-sdk-path) # current version export DEVELOPER=$(xcode-select --print-path)\
export IPHONEOS_SDK_VERSION=$(xcrun --sdk iphoneos --show-sdk-version)
#make subsurface set this to a saner value export IPHONEOS_DEPLOYMENT_VERSION="6.0"
export PREFIX=$TOP/install-root export IPHONEOS_PLATFORM=$(xcrun --sdk iphoneos --show-sdk-platform-path)
export IPHONEOS_SDK=$(xcrun --sdk iphoneos --show-sdk-path)
# Binaries export IPHONESIMULATOR_PLATFORM=$(xcrun --sdk iphonesimulator --show-sdk-platform-path)
export CC=$(xcrun --sdk $SDK --find gcc) export IPHONESIMULATOR_SDK=$(xcrun --sdk iphonesimulator --show-sdk-path)
export CPP=$(xcrun --sdk $SDK --find gcc)" -E" export OSX_SDK_VERSION=$(xcrun --sdk macosx --show-sdk-version)
export CXX=$(xcrun --sdk $SDK --find g++) export OSX_DEPLOYMENT_VERSION="10.8"
export LD=$(xcrun --sdk $SDK --find ld) export OSX_PLATFORM=$(xcrun --sdk macosx --show-sdk-platform-path)
export OSX_SDK=$(xcrun --sdk macosx --show-sdk-path)
# Flags
export CFLAGS="$CFLAGS -arch $ARCH -isysroot $SDKROOT -I$PREFIX/include -miphoneos-version-min=$SDKVERSION"
export CPPFLAGS="$CPPFLAGS -arch $ARCH -isysroot $SDKROOT -I$PREFIX/include -miphoneos-version-min=$SDKVERSION"
export CXXFLAGS="$CXXFLAGS -arch $ARCH -isysroot $SDKROOT -I$PREFIX/include"
export LDFLAGS="$LDFLAGS -arch $ARCH -isysroot $SDKROOT -L$PREFIX/lib"
export PKG_CONFIG_PATH="$PKG_CONFIG_PATH":"$SDKROOT/usr/lib/pkgconfig":"$PREFIX/lib/pkgconfig"
# Which versions are we building against? # Which versions are we building against?
SQLITE_VERSION=3090200 SQLITE_VERSION=3090200
LIBXML2_VERSION=2.9.3 LIBXML2_VERSION=2.9.2
LIBXSLT_VERSION=1.1.28 LIBXSLT_VERSION=1.1.28
LIBZIP_VERSION=1.0.1 LIBZIP_VERSION=1.0.1
LIBZIP_VERSION=0.11.2 LIBZIP_VERSION=0.11.2
@ -50,10 +60,8 @@ LIBUSB_VERSION=1.0.19
OPENSSL_VERSION=1.0.1p OPENSSL_VERSION=1.0.1p
LIBFTDI_VERSION=1.2 LIBFTDI_VERSION=1.2
target=i386 target=$ARCH
hosttarget=i386 hosttarget=$ARCH
platform=iPhoneSimulator
if [ ! -e sqlite-autoconf-${SQLITE_VERSION}.tar.gz ] ; then if [ ! -e sqlite-autoconf-${SQLITE_VERSION}.tar.gz ] ; then
curl -O http://www.sqlite.org/2015/sqlite-autoconf-${SQLITE_VERSION}.tar.gz curl -O http://www.sqlite.org/2015/sqlite-autoconf-${SQLITE_VERSION}.tar.gz
@ -62,8 +70,8 @@ if [ ! -e sqlite-autoconf-${SQLITE_VERSION} ] ; then
tar -zxf sqlite-autoconf-${SQLITE_VERSION}.tar.gz tar -zxf sqlite-autoconf-${SQLITE_VERSION}.tar.gz
fi fi
if [ ! -e $PKG_CONFIG_LIBDIR/sqlite3.pc ] ; then if [ ! -e $PKG_CONFIG_LIBDIR/sqlite3.pc ] ; then
mkdir -p sqlite-build-$platform mkdir -p sqlite-build-$ARCH_NAME
pushd sqlite-build-$platform pushd sqlite-build-$ARCH_NAME
CFLAGS="${CFLAGS} -DSQLITE_ENABLE_LOCKING_STYLE=0" CFLAGS="${CFLAGS} -DSQLITE_ENABLE_LOCKING_STYLE=0"
../sqlite-autoconf-${SQLITE_VERSION}/configure \ ../sqlite-autoconf-${SQLITE_VERSION}/configure \
@ -108,8 +116,8 @@ if [ ! -e libxslt-${LIBXSLT_VERSION} ] ; then
cp libxml2-${LIBXML2_VERSION}/config.sub libxslt-${LIBXSLT_VERSION} cp libxml2-${LIBXML2_VERSION}/config.sub libxslt-${LIBXSLT_VERSION}
fi fi
if [ ! -e $PKG_CONFIG_LIBDIR/libxslt.pc ] ; then if [ ! -e $PKG_CONFIG_LIBDIR/libxslt.pc ] ; then
mkdir -p libxslt-build-$ARCH mkdir -p libxslt-build-$ARCH_NAME
pushd libxslt-build-$ARCH pushd libxslt-build-$ARCH_NAME
../libxslt-${LIBXSLT_VERSION}/configure --host=${BUILDCHAIN} --prefix=${PREFIX} --with-libxml-prefix=${PREFIX} --without-python --without-crypto --enable-static --disable-shared ../libxslt-${LIBXSLT_VERSION}/configure --host=${BUILDCHAIN} --prefix=${PREFIX} --with-libxml-prefix=${PREFIX} --without-python --without-crypto --enable-static --disable-shared
make make
make install make install
@ -123,14 +131,59 @@ if [ ! -e libzip-${LIBZIP_VERSION} ] ; then
tar -zxf libzip-${LIBZIP_VERSION}.tar.gz tar -zxf libzip-${LIBZIP_VERSION}.tar.gz
fi fi
if [ ! -e $PKG_CONFIG_LIBDIR/libzip.pc ] ; then if [ ! -e $PKG_CONFIG_LIBDIR/libzip.pc ] ; then
mkdir -p libzip-build-$ARCH mkdir -p libzip-build-$ARCH_NAME
pushd libzip-build-$ARCH pushd libzip-build-$ARCH_NAME
../libzip-${LIBZIP_VERSION}/configure --host=${BUILDCHAIN} --prefix=${PREFIX} --enable-static --disable-shared ../libzip-${LIBZIP_VERSION}/configure --host=${BUILDCHAIN} --prefix=${PREFIX} --enable-static --disable-shared
make make
make install make install
popd popd
fi fi
configure_openssl() {
OS=$1
ARCH=$2
PLATFORM=$3
SDK_VERSION=$4
DEPLOYMENT_VERSION=$5
export CROSS_TOP="${PLATFORM}/Developer"
export CROSS_SDK="${OS}${SDK_VERSION}.sdk"
# if [ "$ARCH" == "i386" ]; then
./Configure darwin64-${ARCH}-cc --openssldir="${PREFIX}" --prefix="${PREFIX}"
sed -ie "s!^CFLAG=!CFLAG=-isysroot ${CROSS_TOP}/SDKs/${CROSS_SDK} -arch $ARCH -mios-simulator-version-min=${DEPLOYMENT_VERSION} !" "Makefile"
# else
# ./Configure iphoneos-cross -no-asm --openssldir="${PREFIX}"
# sed -ie "s!^CFLAG=!CFLAG=-mios-simulator-version-min=${DEPLOYMENT_VERSION} !" "Makefile"
# perl -i -pe 's|static volatile sig_atomic_t intr_signal|static volatile int intr_signal|' crypto/ui/ui_openssl.c
# fi
}
build_openssl()
{
ARCH=$1
SDK=$2
TYPE=$3
export BUILD_TOOLS="${DEVELOPER}"
mkdir -p "lib-${TYPE}"
rm -rf openssl-${OPENSSL_VERSION}
tar xfz openssl-${OPENSSL_VERSION}.tar.gz
pushd .
cd "openssl-${OPENSSL_VERSION}"
#fix header for Swift
sed -ie "s/BIGNUM \*I,/BIGNUM \*i,/g" crypto/rsa/rsa.h
if [ "$TYPE" == "ios" ]; then
# if [ "$ARCH" == "i386" ]; then
configure_openssl "iPhoneSimulator" $ARCH ${IPHONESIMULATOR_PLATFORM} ${IPHONEOS_SDK_VERSION} ${IPHONEOS_DEPLOYMENT_VERSION}
# else
# configure_openssl "iPhoneOS" $ARCH ${IPHONEOS_PLATFORM} ${IPHONEOS_SDK_VERSION} ${IPHONEOS_DEPLOYMENT_VERSION}
# fi
fi
make
make install_sw
popd
}
if [ ! -e openssl-${OPENSSL_VERSION}.tar.gz ] ; then 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 wget -O openssl-${OPENSSL_VERSION}.tar.gz http://www.openssl.org/source/openssl-${OPENSSL_VERSION}.tar.gz
fi fi
@ -139,20 +192,7 @@ if [ ! -e openssl-build-$ARCH ] ; then
mv openssl-${OPENSSL_VERSION} openssl-build-$ARCH mv openssl-${OPENSSL_VERSION} openssl-build-$ARCH
fi fi
if [ ! -e $PKG_CONFIG_LIBDIR/libssl.pc ] ; then if [ ! -e $PKG_CONFIG_LIBDIR/libssl.pc ] ; then
pushd openssl-build-$ARCH build_openssl "$ARCH" "${IPHONESIMULATOR_SDK}" "ios"
perl -pi -e 's/install: all install_docs install_sw/install: install_docs install_sw/g' Makefile.org
if [[ "${ARCH}" != "i386" && "${ARCH}" != "x86_64" ]]; then
sed -ie "s!static volatile sig_atomic_t intr_signal;!static volatile intr_signal;!" "crypto/ui/ui_openssl.c"
fi
./Configure iphoneos-cross --openssldir="$PREFIX"
sed -ie "s!^CFLAG=!CFLAG=-isysroot ${BUILDCHAIN} -miphoneos-version-min=${SDKVERSION} !" "Makefile"
sed -ie "s!^DIRS=.*!DIRS= crypto ssl !" "Makefile"
# Use env to make all these temporary, so they don't pollute later builds.
# bash -x ./config shared no-ssl2 no-ssl3 no-comp no-hw no-engine --openssldir=$PREFIX
make depend
make build_libs
make install_sw
popd
fi fi
if [ ! -e libssh2-${LIBSSH2_VERSION}.tar.gz ] ; then if [ ! -e libssh2-${LIBSSH2_VERSION}.tar.gz ] ; then
@ -172,15 +212,6 @@ if [ ! -e $PKG_CONFIG_LIBDIR/libssh2.pc ] ; then
popd popd
fi fi
# ios cmake toolchain
if [ ! -e ios-cmake-master.tar.gz ] ; then
wget -O ios-cmake-master.tar.gz https://github.com/cristeab/ios-cmake/archive/master.tar.gz
fi
if [ ! -e ios-cmake-master ] ; then
tar -zxf ios-cmake-master.tar.gz
fi
if [ ! -e libgit2-${LIBGIT2_VERSION}.tar.gz ] ; then 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 wget -O libgit2-${LIBGIT2_VERSION}.tar.gz https://github.com/libgit2/libgit2/archive/v${LIBGIT2_VERSION}.tar.gz
fi fi
@ -190,12 +221,12 @@ fi
if [ ! -e $PKG_CONFIG_LIBDIR/libgit2.pc ] ; then if [ ! -e $PKG_CONFIG_LIBDIR/libgit2.pc ] ; then
mkdir -p libgit2-build-$ARCH mkdir -p libgit2-build-$ARCH
pushd libgit2-build-$ARCH pushd libgit2-build-$ARCH
PKGCONF=$(which pkg-config) cmake ../libgit2-${LIBGIT2_VERSION} \
cmake -DCMAKE_TOOLCHAIN_FILE=${TOP}/ios-cmake-master/toolchain/iOS.cmake -DIOS_PLATFORM=${IOS_PLATFORM} \ -G "Unix Makefiles" \
-DCMAKE_SIZEOF_VOID_P=4 \ -DBUILD_SHARED_LIBS="OFF" \
-DPKG_CONFIG_EXECUTABLE=${PKGCONF} \ -DCMAKE_TOOLCHAIN_FILE="$TOOLCHAIN_DEV" \
-DSHA1_TYPE=builtin \ -DSHA1_TYPE=builtin \
-DBUILD_CLAR=OFF -DBUILD_SHARED_LIBS=OFF \ -DBUILD_CLAR=OFF \
-DCMAKE_INSTALL_PREFIX=${PREFIX} \ -DCMAKE_INSTALL_PREFIX=${PREFIX} \
-DCMAKE_PREFIX_PATH=${PREFIX} \ -DCMAKE_PREFIX_PATH=${PREFIX} \
-DCURL=OFF \ -DCURL=OFF \
@ -265,63 +296,29 @@ fi
# rm $PREFIX/lib/libftdi1.so* # rm $PREFIX/lib/libftdi1.so*
# fi # fi
# #
# if [ ! -e $PKG_CONFIG_LIBDIR/libdivecomputer.pc ] ; then
# mkdir -p libdivecomputer-build-$ARCH # build libdivecomputer
# pushd libdivecomputer-build-$ARCH if [ ! -d libdivecomputer ] ; then
# $SUBSURFACE_SOURCE/../libdivecomputer/configure --host=${BUILDCHAIN} --prefix=${PREFIX} --enable-static --disable-shared --enable-examples=no git clone -b Subsurface-branch git://subsurface-divelog.org/libdc libdivecomputer
# make fi
# make install cd libdivecomputer
# popd git pull --rebase
# fi if ! git checkout Subsurface-branch ; then
# echo "can't check out the Subsurface-branch branch of libdivecomputer -- giving up"
# if [ ! -e qt-android-cmake ] ; then exit 1
# git clone git://github.com/LaurentGomila/qt-android-cmake.git fi
# else cd ..
# pushd qt-android-cmake
# git pull if [ ! -e $PKG_CONFIG_LIBDIR/libdivecomputer.pc ] ; then
# popd if [ ! -f ../libvidecomputer/configure ] ; then
# fi autoreconf --install ../libdivecomputer
# fi
# # Should we build the mobile ui or the desktop ui? mkdir -p libdivecomputer-build-$ARCH
# if [ ! -z "$SUBSURFACE_MOBILE" ] ; then pushd libdivecomputer-build-$ARCH
# mkdir -p subsurface-mobile-build-$ARCH ../libdivecomputer/configure --host=${BUILDCHAIN} --prefix=${PREFIX} --enable-static --disable-shared --enable-examples=no
# cd subsurface-mobile-build-$ARCH make
# MOBILE_CMAKE="-DSUBSURFACE_TARGET_EXECUTABLE=MobileExecutable" make install
# # FIXME: We should install as a different package and name to. popd
# else fi
# mkdir -p subsurface-build-$ARCH
# cd subsurface-build-$ARCH # Should we build the mobile ui or the desktop ui?
# 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