summaryrefslogtreecommitdiffstats
path: root/packaging/android/build.sh
diff options
context:
space:
mode:
authorGravatar Anton Lundin <glance@acc.umu.se>2015-03-09 20:28:54 +0100
committerGravatar Dirk Hohndel <dirk@hohndel.org>2015-03-09 12:53:01 -0700
commitdeb2caf3e0ac90850a793ca86190d44222c60db8 (patch)
tree52a5cd226cd67271194e6e97b9039b9f9c7eab98 /packaging/android/build.sh
parent20a82e2b21ecfa6f00b624ebee2cf9958f3190cf (diff)
downloadsubsurface-deb2caf3e0ac90850a793ca86190d44222c60db8.tar.gz
Import subsurface-android build script
Over one year ago i started with a crazy idea, "Wouldn't Subsurface on android be nice?" when i read about Android support in Qt. After playing around with it and doing some quite ugly hacks i got it to build and run. Now are all the patches upstream and this imports the quite crude build script, for others to continue on. This is a squash-import of what have have happened in https://github.com/glance-/subsurface-android during 2014. Signed-off-by: Anton Lundin <glance@acc.umu.se> CC: Joseph W. Joshua <joejoshw@gmail.com> CC: Venkatesh Shukla <venkatesh.shukla.eee11@iitbhu.ac.in> Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
Diffstat (limited to 'packaging/android/build.sh')
-rw-r--r--packaging/android/build.sh164
1 files changed, 164 insertions, 0 deletions
diff --git a/packaging/android/build.sh b/packaging/android/build.sh
new file mode 100644
index 000000000..fa029e5e0
--- /dev/null
+++ b/packaging/android/build.sh
@@ -0,0 +1,164 @@
+#!/bin/bash
+set -e
+
+# Configure where we can find things here
+export ANDROID_NDK_ROOT=$PWD/../../../android-ndk-r10d
+export ANDROID_SDK_ROOT=$PWD/../../../android-sdk-linux
+export QT5_ANDROID=$PWD/../../../Qt/5.4
+export ANDROID_NDK_HOST=linux-x86
+
+# Which versions are we building against?
+SQLITE_VERSION=3080704
+LIBXML2_VERSION=2.9.2
+LIBXSLT_VERSION=1.1.28
+LIBZIP_VERSION=0.11.2
+LIBGIT2_VERSION=0.21.2
+LIBUSB_VERSION=1.0.19
+
+# arm or x86
+export ARCH=${1-arm}
+
+if [ "$ARCH" = "arm" ] ; then
+ QT_ARCH="armv7"
+ BUILDCHAIN=arm-linux-androideabi
+elif [ "$ARCH" = "x86" ] ; then
+ QT_ARCH=$ARCH
+ BUILDCHAIN=i686-linux-android
+fi
+export QT5_ANDROID_BIN=${QT5_ANDROID}/android_${QT_ARCH}/bin
+
+if [ ! -e ndk-$ARCH ] ; then
+ $ANDROID_NDK_ROOT/build/tools/make-standalone-toolchain.sh --arch=$ARCH --install-dir=ndk-$ARCH --platform=android-14
+fi
+export BUILDROOT=$PWD
+export PATH=${BUILDROOT}/ndk-$ARCH/bin:$PATH
+export PREFIX=${BUILDROOT}/ndk-$ARCH/sysroot/usr
+export PKG_CONFIG_LIBDIR=${PREFIX}/lib/pkgconfig
+export CC=${BUILDCHAIN}-gcc
+export CXX=${BUILDCHAIN}-g++
+
+if [ ! -e sqlite-autoconf-${SQLITE_VERSION}.tar.gz ] ; then
+ wget http://www.sqlite.org/2014/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-$ARCH
+ pushd sqlite-build-$ARCH
+ ../sqlite-autoconf-${SQLITE_VERSION}/configure --host=${BUILDCHAIN} --prefix=${PREFIX} --enable-static --disable-shared
+ make -j4
+ 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 -j4
+ 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 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
+ # -DCMAKE_CXX_COMPILER=arm-linux-androideabi-g++
+ cmake -DCMAKE_SYSTEM_NAME=Linux -DCMAKE_SYSTEM_VERSION=Android -DCMAKE_C_COMPILER=${CC} -DCMAKE_FIND_ROOT_PATH=${PREFIX} -DCMAKE_FIND_ROOT_PATH_MODE_PROGRAM=NEVER -DCMAKE_FIND_ROOT_PATH_MODE_LIBRARY=ONLY -DCMAKE_FIND_ROOT_PATH_MODE_INCLUDE=ONLY -DANDROID=ON -DSHA1_TYPE=builtin -DBUILD_CLAR=OFF -DBUILD_SHARED_LIBS=OFF -DCMAKE_INSTALL_PREFIX=${PREFIX} ../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 [ ! -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
+ 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 $PKG_CONFIG_LIBDIR/libdivecomputer.pc ] ; then
+ mkdir -p libdivecomputer-build-$ARCH
+ pushd libdivecomputer-build-$ARCH
+ ../../../../libdivecomputer/configure --host=${BUILDCHAIN} --prefix=${PREFIX} --enable-static --disable-shared
+ make
+ make install
+ popd
+fi
+
+mkdir -p subsurface-build-$ARCH
+cd subsurface-build-$ARCH
+if [ ! -e Makefile ] ; then
+ $QT5_ANDROID_BIN/qmake V=1 QT_CONFIG=+pkg-config ../../../
+fi
+make -j4
+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