diff --git a/packaging/android/.gitignore b/packaging/android/.gitignore new file mode 100644 index 000000000..d25632a41 --- /dev/null +++ b/packaging/android/.gitignore @@ -0,0 +1,9 @@ +*.tar.* +*-build-*/ +libusb-*/ +libxml2-*/ +libxslt-*/ +libzip-*/ +libgit2-*/ +ndk-*/ +sqlite-autoconf-*/ diff --git a/packaging/android/README b/packaging/android/README new file mode 100644 index 000000000..7168fc1c1 --- /dev/null +++ b/packaging/android/README @@ -0,0 +1,41 @@ +Tool repo to crosscompile subsurface to android-arm +--------------------------------------------------- + +Dependencies: + +1. android_sdk, android_ndk and Qt5.4. See step 0. +2. cmake +3. ant +4. Java JDK +5. working adb is recommended +6. dependencies of libdivecomputer and subsurface - + visit http://subsurface.hohndel.org/documentation/building/ + +Steps to install: + +Step 0. +Grab.. +Android ndk from: http://developer.android.com/tools/sdk/ndk/index.html +Android sdk from: http://developer.android.com/sdk/index.html#download +And QT for android from: http://qt-project.org/downloads + +Step 1. +Extract and install these into known directories. +Have a look in the top of build.sh for where the cross build tool expects +them. By default thats is: ../../../android-ndk-r9d ../../../android-sdk-linux +and ../../../Qt/5.4 + +Step 2. +Run bash build.sh in the terminal. By default it builds for arm but you +can pass x86 as first arg to build.sh to have it build for x86. Nice when +debugging in a fast emulator. +The script will download and build the whole dependency chain. + +After this, subsurface will be built for android. + +The output folder is subsurface-build-arm/android_build and your newly +created apk shows up as: +subsurface-build-arm/android_build/bin/QtApp-debug.apk + +Where the x86 apk shows up when built for x86 is left as a exercise for the +reader. 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