android: Rework build.sh

This reworks build.sh for proper argument parsing and variable quoting.

Signed-off-by: Anton Lundin <glance@acc.umu.se>
Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
This commit is contained in:
Anton Lundin 2017-02-06 15:55:41 +01:00 committed by Dirk Hohndel
parent bed5ad31e6
commit 56b518d956
2 changed files with 76 additions and 62 deletions

View file

@ -2,8 +2,8 @@
<manifest xmlns:android="http://schemas.android.com/apk/res/android" <manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="org.subsurfacedivelog.mobile" package="org.subsurfacedivelog.mobile"
android:installLocation="auto" android:installLocation="auto"
android:versionCode=@BUILD_NR@ android:versionCode="@BUILD_NR@"
android:versionName=@SUBSURFACE_MOBILE_VERSION@ > android:versionName="@SUBSURFACE_MOBILE_VERSION@" >
<application <application
android:name="org.qtproject.qt5.android.bindings.QtApplication" android:name="org.qtproject.qt5.android.bindings.QtApplication"

View file

@ -21,7 +21,7 @@
# #
# Or just set QT5_ANDROID, ANDROID_SDK_ROOT and ANDROID_NDK_ROOT to where ever you have them. # Or just set QT5_ANDROID, ANDROID_SDK_ROOT and ANDROID_NDK_ROOT to where ever you have them.
# #
set -e set -eu
PLATFORM=$(uname) PLATFORM=$(uname)
# (trick to get the absolute path, either if we're called with a # (trick to get the absolute path, either if we're called with a
# absolute path or a relative path) # absolute path or a relative path)
@ -29,29 +29,50 @@ pushd "$(dirname "$0")/../../"
export SUBSURFACE_SOURCE=$PWD export SUBSURFACE_SOURCE=$PWD
popd popd
# Set build defaults
# is this a release or debug build # is this a release or debug build
BUILD_TYPE=Debug BUILD_TYPE=Debug
if [ "$1" = "release" ] || [ "$1" = "Release" ] ; then # Build-nr in the android manifest.
shift BUILD_NR=0
BUILD_TYPE=Release # Should we build the desktop ui or the mobile ui?
fi SUBSURFACE_DESKTOP=OFF
if [ "$1" = "debug" ] || [ "$1" = "Debug" ] ; then # Which arch should we build for?
# this is the default - still need to eat the argument if given ARCH=arm
shift
fi
if [ "$1" = "-buildnr" ] ; then while [ "$#" -gt 0 ] ; do
shift case "$1" in
BUILD_NR="\"$1\"" Release|release)
shift shift
else BUILD_TYPE=Release
BUILD_NR="\"0\"" ;;
fi Debug|debug)
# this is the default - still need to eat the argument if given
BUILD_TYPE=Debug
shift
;;
-buildnr)
shift
BUILD_NR=$1
shift
;;
desktop)
SUBSURFACE_DESKTOP=ON
shift
;;
arm|x86)
ARCH=$1
shift
;;
esac
done
# Its needed by all sub-cmds
export ARCH
# Configure where we can find things here # Configure where we can find things here
export ANDROID_NDK_ROOT=${ANDROID_NDK_ROOT-$SUBSURFACE_SOURCE/../android-ndk-r13b} export ANDROID_NDK_ROOT=${ANDROID_NDK_ROOT-$SUBSURFACE_SOURCE/../android-ndk-r13b}
if [ ! -z "$QT5_ANDROID" ] ; then if [ -n "${QT5_ANDROID+X}" ] ; then
echo "Using Qt5 in $QT5_ANDROID" echo "Using Qt5 in $QT5_ANDROID"
elif [ -d "$SUBSURFACE_SOURCE/../Qt/5.8" ] ; then elif [ -d "$SUBSURFACE_SOURCE/../Qt/5.8" ] ; then
export QT5_ANDROID=$SUBSURFACE_SOURCE/../Qt/5.8 export QT5_ANDROID=$SUBSURFACE_SOURCE/../Qt/5.8
@ -84,27 +105,19 @@ LIBUSB_VERSION=1.0.20
OPENSSL_VERSION=1.0.2h OPENSSL_VERSION=1.0.2h
LIBFTDI_VERSION=1.3 LIBFTDI_VERSION=1.3
# arm or x86
if [ "$1" = "arm" ] || [ "$1" = "x86" ] ; then
export ARCH=$1
shift
else
export ARCH=arm
fi
if [ "$ARCH" = "arm" ] ; then if [ "$ARCH" = "arm" ] ; then
QT_ARCH="armv7" QT_ARCH=armv7
BUILDCHAIN=arm-linux-androideabi BUILDCHAIN=arm-linux-androideabi
OPENSSL_MACHINE="armv7" OPENSSL_MACHINE=armv7
elif [ "$ARCH" = "x86" ] ; then elif [ "$ARCH" = "x86" ] ; then
QT_ARCH=$ARCH QT_ARCH=$ARCH
BUILDCHAIN=i686-linux-android BUILDCHAIN=i686-linux-android
OPENSSL_MACHINE="i686" OPENSSL_MACHINE=i686
fi fi
export QT5_ANDROID_BIN=${QT5_ANDROID}/android_${QT_ARCH}/bin export QT5_ANDROID_BIN=${QT5_ANDROID}/android_${QT_ARCH}/bin
if [ ! -e ndk-$ARCH ] ; then if [ ! -e ndk-"$ARCH" ] ; then
"$ANDROID_NDK_ROOT/build/tools/make_standalone_toolchain.py" --arch=$ARCH --install-dir=ndk-$ARCH --api=16 "$ANDROID_NDK_ROOT/build/tools/make_standalone_toolchain.py" --arch="$ARCH" --install-dir=ndk-"$ARCH" --api=16
fi fi
export BUILDROOT=$PWD export BUILDROOT=$PWD
export PATH=${BUILDROOT}/ndk-$ARCH/bin:$PATH export PATH=${BUILDROOT}/ndk-$ARCH/bin:$PATH
@ -114,9 +127,9 @@ export CC=${BUILDROOT}/ndk-$ARCH/bin/${BUILDCHAIN}-gcc
export CXX=${BUILDROOT}/ndk-$ARCH/bin/${BUILDCHAIN}-g++ export CXX=${BUILDROOT}/ndk-$ARCH/bin/${BUILDCHAIN}-g++
# autoconf seems to get lost without this # autoconf seems to get lost without this
export SYSROOT=${BUILDROOT}/ndk-$ARCH/sysroot export SYSROOT=${BUILDROOT}/ndk-$ARCH/sysroot
export CFLAGS="--sysroot=${SYSROOT}" export CFLAGS=--sysroot=${SYSROOT}
export CPPFLAGS="--sysroot=${SYSROOT}" export CPPFLAGS=--sysroot=${SYSROOT}
export CXXFLAGS="--sysroot=${SYSROOT}" export CXXFLAGS=--sysroot=${SYSROOT}
# Junk needed for qt-android-cmake # Junk needed for qt-android-cmake
export ANDROID_STANDALONE_TOOLCHAIN=${BUILDROOT}/ndk-$ARCH export ANDROID_STANDALONE_TOOLCHAIN=${BUILDROOT}/ndk-$ARCH
if [ "$PLATFORM" = "Darwin" ] ; then if [ "$PLATFORM" = "Darwin" ] ; then
@ -133,8 +146,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-$ARCH mkdir -p sqlite-build-"$ARCH"
pushd sqlite-build-$ARCH pushd sqlite-build-"$ARCH"
../sqlite-autoconf-${SQLITE_VERSION}/configure --host=${BUILDCHAIN} --prefix="$PREFIX" --enable-static --disable-shared ../sqlite-autoconf-${SQLITE_VERSION}/configure --host=${BUILDCHAIN} --prefix="$PREFIX" --enable-static --disable-shared
make make
make install make install
@ -148,8 +161,8 @@ if [ ! -e libxml2-${LIBXML2_VERSION} ] ; then
tar -zxf libxml2-${LIBXML2_VERSION}.tar.gz tar -zxf libxml2-${LIBXML2_VERSION}.tar.gz
fi fi
if [ ! -e "$PKG_CONFIG_LIBDIR/libxml-2.0.pc" ] ; then if [ ! -e "$PKG_CONFIG_LIBDIR/libxml-2.0.pc" ] ; then
mkdir -p libxml2-build-$ARCH mkdir -p libxml2-build-"$ARCH"
pushd libxml2-build-$ARCH pushd libxml2-build-"$ARCH"
../libxml2-${LIBXML2_VERSION}/configure --host=${BUILDCHAIN} --prefix="$PREFIX" --without-python --without-iconv --enable-static --disable-shared ../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/runtest\$\(EXEEXT\)//' Makefile
perl -pi -e 's/testrecurse\$\(EXEEXT\)//' Makefile perl -pi -e 's/testrecurse\$\(EXEEXT\)//' Makefile
@ -167,8 +180,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"
pushd 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 ../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
@ -182,8 +195,8 @@ 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"
pushd libzip-build-$ARCH pushd libzip-build-"$ARCH"
../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
@ -193,16 +206,16 @@ fi
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
if [ ! -e openssl-build-$ARCH ] ; then if [ ! -e openssl-build-"$ARCH" ] ; then
tar -zxf openssl-${OPENSSL_VERSION}.tar.gz tar -zxf openssl-${OPENSSL_VERSION}.tar.gz
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 pushd openssl-build-"$ARCH"
perl -pi -e 's/install: all install_docs install_sw/install: install_docs install_sw/g' Makefile.org 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. # Use env to make all these temporary, so they don't pollute later builds.
env SYSTEM=android \ env SYSTEM=android \
CROSS_COMPILE="${BUILDCHAIN}-" \ CROSS_COMPILE=${BUILDCHAIN}- \
MACHINE=$OPENSSL_MACHINE \ MACHINE=$OPENSSL_MACHINE \
HOSTCC=gcc \ HOSTCC=gcc \
CC=gcc \ CC=gcc \
@ -226,8 +239,8 @@ fi
if [ ! -e "$PKG_CONFIG_LIBDIR/libgit2.pc" ] ; then if [ ! -e "$PKG_CONFIG_LIBDIR/libgit2.pc" ] ; then
# We don't want to find the HTTP_Parser package of the build host by mistake # We don't want to find the HTTP_Parser package of the build host by mistake
perl -pi -e 's/FIND_PACKAGE\(HTTP_Parser\)/#FIND_PACKAGE(HTTP_Parser)/' libgit2-${LIBGIT2_VERSION}/CMakeLists.txt perl -pi -e 's/FIND_PACKAGE\(HTTP_Parser\)/#FIND_PACKAGE(HTTP_Parser)/' libgit2-${LIBGIT2_VERSION}/CMakeLists.txt
mkdir -p libgit2-build-$ARCH mkdir -p libgit2-build-"$ARCH"
pushd libgit2-build-$ARCH pushd libgit2-build-"$ARCH"
cmake -DCMAKE_SYSTEM_NAME=Android -DSHA1_TYPE=builtin \ cmake -DCMAKE_SYSTEM_NAME=Android -DSHA1_TYPE=builtin \
-DBUILD_CLAR=OFF -DBUILD_SHARED_LIBS=OFF \ -DBUILD_CLAR=OFF -DBUILD_SHARED_LIBS=OFF \
-DCMAKE_INSTALL_PREFIX="$PREFIX" \ -DCMAKE_INSTALL_PREFIX="$PREFIX" \
@ -264,8 +277,8 @@ if [ ! -e libusb-${LIBUSB_VERSION}/configure ] ; then
popd popd
fi fi
if [ ! -e "$PKG_CONFIG_LIBDIR/libusb-1.0.pc" ] ; then if [ ! -e "$PKG_CONFIG_LIBDIR/libusb-1.0.pc" ] ; then
mkdir -p libusb-build-$ARCH mkdir -p libusb-build-"$ARCH"
pushd libusb-build-$ARCH pushd libusb-build-"$ARCH"
../libusb-${LIBUSB_VERSION}/configure --host=${BUILDCHAIN} --prefix="$PREFIX" --enable-static --disable-shared --disable-udev --enable-system-log ../libusb-${LIBUSB_VERSION}/configure --host=${BUILDCHAIN} --prefix="$PREFIX" --enable-static --disable-shared --disable-udev --enable-system-log
# --enable-debug-log # --enable-debug-log
make make
@ -280,8 +293,8 @@ if [ ! -e libftdi1-${LIBFTDI_VERSION} ] ; then
tar -jxf libftdi1-${LIBFTDI_VERSION}.tar.bz2 tar -jxf libftdi1-${LIBFTDI_VERSION}.tar.bz2
fi fi
if [ ! -e "$PKG_CONFIG_LIBDIR/libftdi1.pc" ] && [ "$PLATFORM" != "Darwin" ] ; then if [ ! -e "$PKG_CONFIG_LIBDIR/libftdi1.pc" ] && [ "$PLATFORM" != "Darwin" ] ; then
mkdir -p libftdi1-build-$ARCH mkdir -p libftdi1-build-"$ARCH"
pushd 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 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
make install make install
@ -293,8 +306,8 @@ if [ -e "$PREFIX/lib/libftdi1.so" ] ; then
fi fi
if [ ! -e "$PKG_CONFIG_LIBDIR/libdivecomputer.pc" ] ; then if [ ! -e "$PKG_CONFIG_LIBDIR/libdivecomputer.pc" ] ; then
mkdir -p libdivecomputer-build-$ARCH mkdir -p libdivecomputer-build-"$ARCH"
pushd libdivecomputer-build-$ARCH pushd libdivecomputer-build-"$ARCH"
"$SUBSURFACE_SOURCE"/../libdivecomputer/configure --host=${BUILDCHAIN} --prefix="$PREFIX" --enable-static --disable-shared --enable-examples=no "$SUBSURFACE_SOURCE"/../libdivecomputer/configure --host=${BUILDCHAIN} --prefix="$PREFIX" --enable-static --disable-shared --enable-examples=no
make make
make install make install
@ -314,7 +327,7 @@ fi
if [ "$SUBSURFACE_DESKTOP" = "ON" ] ; then if [ "$SUBSURFACE_DESKTOP" = "ON" ] ; then
SUBSURFACE_MOBILE= SUBSURFACE_MOBILE=
else else
SUBSURFACE_MOBILE="ON" SUBSURFACE_MOBILE=ON
fi fi
if [ "$SUBSURFACE_MOBILE" = "ON" ] ; then if [ "$SUBSURFACE_MOBILE" = "ON" ] ; then
@ -324,12 +337,13 @@ if [ "$SUBSURFACE_MOBILE" = "ON" ] ; then
fi fi
if [ ! -z "$SUBSURFACE_MOBILE" ] ; then if [ ! -z "$SUBSURFACE_MOBILE" ] ; then
mkdir -p subsurface-mobile-build-$ARCH mkdir -p subsurface-mobile-build-"$ARCH"
cd subsurface-mobile-build-$ARCH cd subsurface-mobile-build-"$ARCH"
MOBILE_CMAKE="-DSUBSURFACE_TARGET_EXECUTABLE=MobileExecutable" MOBILE_CMAKE=-DSUBSURFACE_TARGET_EXECUTABLE=MobileExecutable
else else
mkdir -p subsurface-build-$ARCH MOBILE_CMAKE=""
cd subsurface-build-$ARCH mkdir -p subsurface-build-"$ARCH"
cd subsurface-build-"$ARCH"
fi fi
# something in the qt-android-cmake-thingies mangles your path, so thats why we need to hard-code ant and pkg-config here. # something in the qt-android-cmake-thingies mangles your path, so thats why we need to hard-code ant and pkg-config here.
@ -375,7 +389,7 @@ if [ ! -z "$SUBSURFACE_MOBILE" ] ; then
rm -rf android-mobile rm -rf android-mobile
cp -a "$SUBSURFACE_SOURCE/android-mobile" . cp -a "$SUBSURFACE_SOURCE/android-mobile" .
sed -i -e "s/@SUBSURFACE_MOBILE_VERSION@/\"$SUBSURFACE_MOBILE_VERSION\"/;s/@BUILD_NR@/$BUILD_NR/" android-mobile/AndroidManifest.xml sed -i -e "s/@SUBSURFACE_MOBILE_VERSION@/$SUBSURFACE_MOBILE_VERSION/;s/@BUILD_NR@/$BUILD_NR/" android-mobile/AndroidManifest.xml
else else
SUBSURFACE_VERSION=$(grep CANONICAL_VERSION_STRING ssrf-version.h | awk '{ print $3 }' | tr -d \") SUBSURFACE_VERSION=$(grep CANONICAL_VERSION_STRING ssrf-version.h | awk '{ print $3 }' | tr -d \")