From 9a754b663a2751f2ca86c636d6a1c55f0cf23912 Mon Sep 17 00:00:00 2001 From: Dirk Hohndel Date: Fri, 3 Feb 2017 17:27:45 -0800 Subject: Extend Android wrapper shell to be smarter Move it to packaging/android where it belongs Use direct URLs to download Android components Make sure required packages are installed (only tested on Ubuntu) Signed-off-by: Dirk Hohndel --- packaging/android/android-build-wrapper.sh | 137 +++++++++++++++++++++++++++++ 1 file changed, 137 insertions(+) create mode 100644 packaging/android/android-build-wrapper.sh (limited to 'packaging/android/android-build-wrapper.sh') diff --git a/packaging/android/android-build-wrapper.sh b/packaging/android/android-build-wrapper.sh new file mode 100644 index 000000000..523283f35 --- /dev/null +++ b/packaging/android/android-build-wrapper.sh @@ -0,0 +1,137 @@ +#!/bin/bash + +# run this in the top level folder you want to create Android binaries in +# +# it seems that with Qt5.7.1 and current cmake there is an odd bug where +# cmake fails reporting :No known features for CXX compiler "GNU". In that +# case simly comment out the "set(property(TARGET Qt5::Core PROPERTY...)" +# at line 101 of +# Qt/5.7/android_armv7/lib/cmake/Qt5Core/Qt5CoreConfigExtras.cmake + +exec 1> >(tee ./build.log) 2>&1 + +USE_X=$(case "$-" in *x*) echo "-x" ;; esac) + +# these are the current versions for Qt, Android SDK & NDK: + +QT_VERSION=5.7 +LATEST_QT=5.7.1 +NDK_VERSION=r13b +SDK_VERSION=r25.2.3 + +ANDROID_NDK=android-ndk-${NDK_VERSION} +ANDROID_SDK=android-sdk-linux + +PLATFORM=$(uname) + +if [ "$PLATFORM" = "Linux" ] ; then + QT_BINARIES=qt-opensource-linux-x64-android-${LATEST_QT}.run + NDK_BINARIES=${ANDROID_NDK}-linux-x86_64.zip + SDK_TOOLS=tools_${SDK_VERSION}-linux.zip +else + echo "only on Linux so far" + exit 1 +fi + +# make sure we have the required commands installed +MISSING="" +for i in git cmake autoconf libtool java ant; do + which $i > /dev/null 2>&1 || + if [ "$i" = "libtool" ] ; then + MISSING="${MISSING}libtool-bin " + elif [ "$i" = "java" ] ; then + MISSING="${MISSING}openjdk-8-jdk " + else + MISSING="${MISSING}${i} " + fi +done +if [ "$MISSING" != "" ] ; then + echo "The following packages are missing: $MISSING" + echo "Please install via your package manager." + exit +fi + +# download the Qt installer including Android bits and unpack / install +QT_DOWNLOAD_URL=https://download.qt.io/archive/qt/${QT_VERSION}/${LATEST_QT}/${QT_BINARIES} +if [ ! -d Qt${LATEST_QT} ] ; then + if [ ! -f ${QT_BINARIES} ] ; then + wget ${QT_DOWNLOAD_URL} + fi + echo "In the binary installer select $(pwd)/${LATEST_QT} as install directory" + chmod +x ./${QT_BINARIES} + ./${QT_BINARIES} +fi + +[ -e Qt ] || ln -s Qt${LATEST_QT} Qt + +# patch the cmake / Qt5.7.1 incompatibility mentioned above +sed -i 's/set_property(TARGET Qt5::Core PROPERTY INTERFACE_COMPILE_FEATURES cxx_decltype)/# set_property(TARGET Qt5::Core PROPERTY INTERFACE_COMPILE_FEATURES cxx_decltype)/' Qt/5.7/android_armv7/lib/cmake/Qt5Core/Qt5CoreConfigExtras.cmake + +# next we need to get the Android SDK and NDK +if [ ! -d $ANDROID_NDK ] ; then + if [ ! -f $NDK_BINARIES ] ; then + wget https://dl.google.com/android/repository/$NDK_BINARIES + fi + unzip $NDK_BINARIES +fi + +if [ ! -d $ANDROID_SDK ] ; then + if [ ! -f $SDK_TOOLS ] ; then + wget https://dl.google.com/android/repository/$SDK_TOOLS + fi + mkdir $ANDROID_SDK + pushd $ANDROID_SDK + unzip ../$SDK_TOOLS + bash tools/android update sdk --no-ui -a -t 1,2,3,33 + popd +fi + +# ok, now we have Qt, SDK, and NDK - let's get us some Subsurface +if [ ! -d subsurface ] ; then + git clone git://github.com/Subsurface-divelog/subsurface +fi +pushd subsurface +git pull --rebase +popd + +if [ ! -d libdivecomputer ] ; then + git clone -b Subsurface-branch git://github.com/Subsurface-divelog/libdc libdivecomputer + pushd libdivecomputer + autoreconf --install + autoreconf --install + popd +fi +pushd libdivecomputer +git pull --rebase +if ! git checkout Subsurface-branch ; then + echo "can't check out the Subsurface-branch branch of libdivecomputer -- giving up" + exit 1 +fi +popd + + +# and now we need a monotonic build number... +if [ ! -f "./buildnr.dat" ] ; then + BUILDNR=0 +else + BUILDNR=$(cat ./buildnr.dat) +fi +((BUILDNR++)) +echo "${BUILDNR}" > ./buildnr.dat + +echo "Building Subsurface-mobile ${VERSION} for Android, build nr ${BUILDNR} as Subsurface-mobile-$VERSION-${NAME}arm.apk" + +if [ "$1" = "release" ] || [ "$1" = "Release" ] || [ "$1" = "debug" ] || [ "$1" = "Debug" ] ; then + RELEASE=$1 + shift +else + RELEASE=Debug +fi + +rm -f ./subsurface-mobile-build-arm/bin/QtApp-debug.apk +rm -d ./subsurface-mobile-build-arm/AndroidManifest.xml +rm -d ./subsurface-mobile-build-arm/bin/AndroidManifest.xml +bash "$USE_X" subsurface/packaging/android/build.sh "$RELEASE" -buildnr "$BUILDNR" arm "$@" + +ls -l ./subsurface-mobile-build-arm/bin/*.apk + -- cgit v1.2.3-70-g09d2