2015-03-09 20:28:54 +01:00
|
|
|
#!/bin/bash
|
2017-01-02 04:46:51 -08:00
|
|
|
#
|
|
|
|
# Filesystem layout considerations...
|
|
|
|
# for this explanation I assume that your Subsurface sources are in
|
|
|
|
# ~/src/subsurface
|
|
|
|
#
|
|
|
|
# You need to have a version of Qt that contains the Android bits
|
|
|
|
# installed. You should be able to find the correct installer for
|
|
|
|
# Linux or Mac here:
|
2017-02-06 15:55:38 +01:00
|
|
|
# http://download.qt.io/official_releases/qt/
|
2017-01-02 04:46:51 -08:00
|
|
|
# make sure you pick one with 'android' in its name.
|
|
|
|
#
|
|
|
|
# Install this wherever you want - and then have a link named ~/src/Qt that
|
|
|
|
# points to it.
|
2017-02-06 15:55:38 +01:00
|
|
|
# So let's assume that you are installing the package above in ~/Qt
|
2017-01-02 04:46:51 -08:00
|
|
|
# (which I think is the default location), then simply do
|
|
|
|
# cd ~/src
|
2017-02-06 15:55:38 +01:00
|
|
|
# ln -s ~/Qt Qt
|
2017-01-02 04:46:51 -08:00
|
|
|
#
|
|
|
|
# you also need to have the current Android SDK and NDK installed under ~/src
|
|
|
|
#
|
2017-01-09 11:47:39 +01:00
|
|
|
# Or just set QT5_ANDROID, ANDROID_SDK_ROOT and ANDROID_NDK_ROOT to where ever you have them.
|
|
|
|
#
|
2017-02-06 15:55:41 +01:00
|
|
|
set -eu
|
2015-07-20 11:13:00 +02:00
|
|
|
PLATFORM=$(uname)
|
2015-07-09 00:42:09 +02:00
|
|
|
# (trick to get the absolute path, either if we're called with a
|
|
|
|
# absolute path or a relative path)
|
2017-01-03 09:00:52 +01:00
|
|
|
pushd "$(dirname "$0")/../../"
|
2015-07-09 00:42:09 +02:00
|
|
|
export SUBSURFACE_SOURCE=$PWD
|
|
|
|
popd
|
2015-12-24 09:41:39 -08:00
|
|
|
|
2017-02-06 15:55:41 +01:00
|
|
|
# Set build defaults
|
2015-12-24 09:41:39 -08:00
|
|
|
# is this a release or debug build
|
|
|
|
BUILD_TYPE=Debug
|
2017-02-06 15:55:41 +01:00
|
|
|
# Build-nr in the android manifest.
|
|
|
|
BUILD_NR=0
|
|
|
|
# Should we build the desktop ui or the mobile ui?
|
|
|
|
SUBSURFACE_DESKTOP=OFF
|
|
|
|
# Which arch should we build for?
|
|
|
|
ARCH=arm
|
2017-05-25 19:15:51 +02:00
|
|
|
# Which SDK buildtools revision is used?
|
2017-06-01 17:04:53 +02:00
|
|
|
ANDROID_BUILDTOOLS_REVISION=25.0.3
|
2017-02-06 15:55:41 +01:00
|
|
|
|
|
|
|
while [ "$#" -gt 0 ] ; do
|
|
|
|
case "$1" in
|
|
|
|
Release|release)
|
|
|
|
shift
|
|
|
|
BUILD_TYPE=Release
|
|
|
|
;;
|
|
|
|
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
|
2017-11-15 21:03:28 +01:00
|
|
|
;;
|
|
|
|
*)
|
|
|
|
echo "Unknown argument $1"
|
|
|
|
exit 1
|
|
|
|
;;
|
2017-02-06 15:55:41 +01:00
|
|
|
esac
|
|
|
|
done
|
|
|
|
|
|
|
|
# Its needed by all sub-cmds
|
|
|
|
export ARCH
|
2016-03-05 21:23:27 -08:00
|
|
|
|
2015-03-09 20:28:54 +01:00
|
|
|
# Configure where we can find things here
|
2017-06-01 17:04:53 +02:00
|
|
|
export ANDROID_NDK_ROOT=${ANDROID_NDK_ROOT-$SUBSURFACE_SOURCE/../android-ndk-r14b}
|
2016-03-03 14:32:23 -08:00
|
|
|
|
2017-02-06 15:55:41 +01:00
|
|
|
if [ -n "${QT5_ANDROID+X}" ] ; then
|
2016-06-23 22:56:31 +02:00
|
|
|
echo "Using Qt5 in $QT5_ANDROID"
|
2018-03-19 12:08:06 -07:00
|
|
|
elif [ -d "$SUBSURFACE_SOURCE/../Qt/5.10.1" ] ; then
|
|
|
|
export QT5_ANDROID=$SUBSURFACE_SOURCE/../Qt/5.10.1
|
2018-02-23 14:01:52 +01:00
|
|
|
elif [ -d "$SUBSURFACE_SOURCE/../Qt/5.9.3" ] ; then
|
|
|
|
export QT5_ANDROID=$SUBSURFACE_SOURCE/../Qt/5.9.3
|
2017-06-30 16:57:13 -07:00
|
|
|
elif [ -d "$SUBSURFACE_SOURCE/../Qt/5.9.1" ] ; then
|
|
|
|
export QT5_ANDROID=$SUBSURFACE_SOURCE/../Qt/5.9.1
|
2017-05-27 14:54:28 -07:00
|
|
|
elif [ -d "$SUBSURFACE_SOURCE/../Qt/5.9" ] ; then
|
|
|
|
export QT5_ANDROID=$SUBSURFACE_SOURCE/../Qt/5.9
|
2017-02-06 15:55:39 +01:00
|
|
|
elif [ -d "$SUBSURFACE_SOURCE/../Qt/5.8" ] ; then
|
|
|
|
export QT5_ANDROID=$SUBSURFACE_SOURCE/../Qt/5.8
|
2016-06-22 13:25:26 -07:00
|
|
|
elif [ -d "$SUBSURFACE_SOURCE/../Qt/5.7" ] ; then
|
|
|
|
export QT5_ANDROID=$SUBSURFACE_SOURCE/../Qt/5.7
|
2016-06-23 22:56:31 +02:00
|
|
|
elif [ -d "$SUBSURFACE_SOURCE/../Qt/5.6" ] ; then
|
|
|
|
export QT5_ANDROID=$SUBSURFACE_SOURCE/../Qt/5.6
|
|
|
|
elif [ -d "$SUBSURFACE_SOURCE/../Qt/5.5" ] ; then
|
|
|
|
export QT5_ANDROID=$SUBSURFACE_SOURCE/../Qt/5.5
|
2016-03-03 14:32:23 -08:00
|
|
|
else
|
2017-05-27 14:54:28 -07:00
|
|
|
echo "Cannot find Qt 5.5 or newer under $SUBSURFACE_SOURCE/../Qt"
|
2016-03-03 14:32:23 -08:00
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
2017-01-03 09:00:52 +01:00
|
|
|
if [ "$PLATFORM" = "Darwin" ] ; then
|
2017-01-03 09:05:04 +01:00
|
|
|
export ANDROID_SDK_ROOT=${ANDROID_SDK_ROOT-$SUBSURFACE_SOURCE/../android-sdk-macosx}
|
|
|
|
export ANDROID_NDK_HOST=darwin-x86_64
|
2015-07-20 11:13:00 +02:00
|
|
|
else
|
2017-01-03 09:05:04 +01:00
|
|
|
export ANDROID_SDK_ROOT=${ANDROID_SDK_ROOT-$SUBSURFACE_SOURCE/../android-sdk-linux}
|
2018-03-09 00:24:12 +02:00
|
|
|
export ANDROID_NDK_HOST=linux-x86_64
|
2015-07-20 11:13:00 +02:00
|
|
|
fi
|
2015-03-09 20:28:54 +01:00
|
|
|
|
|
|
|
# Which versions are we building against?
|
2017-06-01 17:04:53 +02:00
|
|
|
SQLITE_VERSION=3190200
|
2016-06-23 22:56:37 +02:00
|
|
|
LIBXML2_VERSION=2.9.4
|
|
|
|
LIBXSLT_VERSION=1.1.29
|
|
|
|
LIBZIP_VERSION=1.1.3
|
2017-07-29 08:18:05 +02:00
|
|
|
LIBGIT2_VERSION=0.26.0
|
2016-06-23 22:56:37 +02:00
|
|
|
LIBUSB_VERSION=1.0.20
|
2017-06-01 17:04:53 +02:00
|
|
|
OPENSSL_VERSION=1.0.2l
|
2016-06-23 22:56:37 +02:00
|
|
|
LIBFTDI_VERSION=1.3
|
2015-03-09 20:28:54 +01:00
|
|
|
|
|
|
|
if [ "$ARCH" = "arm" ] ; then
|
2017-02-06 15:55:41 +01:00
|
|
|
QT_ARCH=armv7
|
2015-03-09 20:28:54 +01:00
|
|
|
BUILDCHAIN=arm-linux-androideabi
|
2017-02-06 15:55:41 +01:00
|
|
|
OPENSSL_MACHINE=armv7
|
2015-03-09 20:28:54 +01:00
|
|
|
elif [ "$ARCH" = "x86" ] ; then
|
|
|
|
QT_ARCH=$ARCH
|
|
|
|
BUILDCHAIN=i686-linux-android
|
2017-02-06 15:55:41 +01:00
|
|
|
OPENSSL_MACHINE=i686
|
2015-03-09 20:28:54 +01:00
|
|
|
fi
|
|
|
|
|
2017-07-05 11:26:12 +02:00
|
|
|
# Verify Qt install and adjust for single-arch Qt install layout
|
|
|
|
# (e.g. when building Qt from scratch)
|
|
|
|
export QT5_ANDROID_CMAKE
|
|
|
|
if [ -d "${QT5_ANDROID}/android_${QT_ARCH}/lib/cmake" ] ; then
|
|
|
|
export QT5_ANDROID_CMAKE=$QT5_ANDROID/android_${QT_ARCH}/lib/cmake
|
2017-07-18 12:45:26 +02:00
|
|
|
elif [ -d "${QT5_ANDROID}/lib/cmake" ] ; then
|
2017-07-05 11:26:12 +02:00
|
|
|
export QT5_ANDROID_CMAKE=$QT5_ANDROID/lib/cmake
|
|
|
|
else
|
|
|
|
echo "Cannot find Qt cmake configuration"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
2017-02-06 15:55:41 +01:00
|
|
|
if [ ! -e ndk-"$ARCH" ] ; then
|
|
|
|
"$ANDROID_NDK_ROOT/build/tools/make_standalone_toolchain.py" --arch="$ARCH" --install-dir=ndk-"$ARCH" --api=16
|
2015-03-09 20:28:54 +01:00
|
|
|
fi
|
|
|
|
export BUILDROOT=$PWD
|
|
|
|
export PATH=${BUILDROOT}/ndk-$ARCH/bin:$PATH
|
|
|
|
export PREFIX=${BUILDROOT}/ndk-$ARCH/sysroot/usr
|
2017-01-03 09:00:52 +01:00
|
|
|
export PKG_CONFIG_LIBDIR=$PREFIX/lib/pkgconfig
|
2015-07-01 17:08:37 +02:00
|
|
|
export CC=${BUILDROOT}/ndk-$ARCH/bin/${BUILDCHAIN}-gcc
|
|
|
|
export CXX=${BUILDROOT}/ndk-$ARCH/bin/${BUILDCHAIN}-g++
|
2015-07-15 10:32:48 -07:00
|
|
|
# autoconf seems to get lost without this
|
|
|
|
export SYSROOT=${BUILDROOT}/ndk-$ARCH/sysroot
|
2017-02-06 15:55:41 +01:00
|
|
|
export CFLAGS=--sysroot=${SYSROOT}
|
|
|
|
export CPPFLAGS=--sysroot=${SYSROOT}
|
|
|
|
export CXXFLAGS=--sysroot=${SYSROOT}
|
2015-07-09 00:42:12 +02:00
|
|
|
# Junk needed for qt-android-cmake
|
|
|
|
export ANDROID_STANDALONE_TOOLCHAIN=${BUILDROOT}/ndk-$ARCH
|
2017-01-03 09:00:52 +01:00
|
|
|
if [ "$PLATFORM" = "Darwin" ] ; then
|
2015-07-20 11:13:00 +02:00
|
|
|
JAVA_HOME=$(/usr/libexec/java_home)
|
|
|
|
export JAVA_HOME
|
|
|
|
else
|
|
|
|
export JAVA_HOME=/usr
|
|
|
|
fi
|
2015-03-09 20:28:54 +01:00
|
|
|
|
2018-03-09 00:24:12 +02:00
|
|
|
|
|
|
|
# find qmake
|
|
|
|
QMAKE=$QT5_ANDROID/android_armv7/bin/qmake
|
|
|
|
$QMAKE -query
|
|
|
|
|
|
|
|
# build google maps plugin
|
|
|
|
if [ ! -e googlemaps ] ; then
|
|
|
|
git clone https://github.com/Subsurface-divelog/googlemaps.git
|
|
|
|
fi
|
|
|
|
cd googlemaps
|
|
|
|
git checkout master
|
|
|
|
git pull --rebase
|
|
|
|
mkdir -p build-"$ARCH"
|
|
|
|
cd build-"$ARCH"
|
|
|
|
$QMAKE ../googlemaps.pro
|
|
|
|
# on Travis the compiler doesn't support c++1z, yet qmake adds that flag;
|
|
|
|
# since things compile fine with c++11, let's just hack that away
|
|
|
|
# similarly, don't use -Wdata-time
|
|
|
|
mv Makefile Makefile.bak
|
|
|
|
cat Makefile.bak | sed -e 's/std=c++1z/std=c++11/g ; s/-Wdate-time//' > Makefile
|
|
|
|
make -j4
|
|
|
|
QT_PLUGINS_PATH=`$QMAKE -query QT_INSTALL_PLUGINS`
|
|
|
|
GOOGLEMAPS_BIN=libqtgeoservices_googlemaps.so
|
|
|
|
$QMAKE -install qinstall -exe $GOOGLEMAPS_BIN $QT_PLUGINS_PATH/geoservices/$GOOGLEMAPS_BIN
|
|
|
|
cd ../../
|
|
|
|
|
2015-03-09 20:28:54 +01:00
|
|
|
if [ ! -e sqlite-autoconf-${SQLITE_VERSION}.tar.gz ] ; then
|
2017-06-01 17:04:53 +02:00
|
|
|
wget http://www.sqlite.org/2017/sqlite-autoconf-${SQLITE_VERSION}.tar.gz
|
2015-03-09 20:28:54 +01:00
|
|
|
fi
|
|
|
|
if [ ! -e sqlite-autoconf-${SQLITE_VERSION} ] ; then
|
|
|
|
tar -zxf sqlite-autoconf-${SQLITE_VERSION}.tar.gz
|
|
|
|
fi
|
2017-01-03 09:00:52 +01:00
|
|
|
if [ ! -e "$PKG_CONFIG_LIBDIR/sqlite3.pc" ] ; then
|
2017-02-06 15:55:41 +01:00
|
|
|
mkdir -p sqlite-build-"$ARCH"
|
|
|
|
pushd sqlite-build-"$ARCH"
|
2017-01-03 09:00:52 +01:00
|
|
|
../sqlite-autoconf-${SQLITE_VERSION}/configure --host=${BUILDCHAIN} --prefix="$PREFIX" --enable-static --disable-shared
|
2015-07-09 00:42:10 +02:00
|
|
|
make
|
2015-03-09 20:28:54 +01:00
|
|
|
make install
|
|
|
|
popd
|
|
|
|
fi
|
|
|
|
|
|
|
|
if [ ! -e libxml2-${LIBXML2_VERSION}.tar.gz ] ; then
|
2018-03-19 09:49:13 -07:00
|
|
|
wget http://api.github.com/repos/GNOME/libxml2/tarball/v${LIBXML2_VERSION} -O libxml2-${LIBXML2_VERSION}.tar.gz
|
2015-03-09 20:28:54 +01:00
|
|
|
fi
|
|
|
|
if [ ! -e libxml2-${LIBXML2_VERSION} ] ; then
|
2018-03-19 09:49:13 -07:00
|
|
|
mkdir -p libxml2-${LIBXML2_VERSION}
|
|
|
|
tar -xzf libxml2-${LIBXML2_VERSION}.tar.gz --strip 1 -C libxml2-${LIBXML2_VERSION}
|
|
|
|
pushd libxml2-${LIBXML2_VERSION}
|
|
|
|
autoreconf --install
|
|
|
|
popd
|
2015-03-09 20:28:54 +01:00
|
|
|
fi
|
2017-01-03 09:00:52 +01:00
|
|
|
if [ ! -e "$PKG_CONFIG_LIBDIR/libxml-2.0.pc" ] ; then
|
2017-02-06 15:55:41 +01:00
|
|
|
mkdir -p libxml2-build-"$ARCH"
|
|
|
|
pushd libxml2-build-"$ARCH"
|
2017-01-03 09:00:52 +01:00
|
|
|
../libxml2-${LIBXML2_VERSION}/configure --host=${BUILDCHAIN} --prefix="$PREFIX" --without-python --without-iconv --enable-static --disable-shared
|
2015-03-09 20:28:54 +01:00
|
|
|
perl -pi -e 's/runtest\$\(EXEEXT\)//' Makefile
|
|
|
|
perl -pi -e 's/testrecurse\$\(EXEEXT\)//' Makefile
|
2015-07-09 00:42:10 +02:00
|
|
|
make
|
2015-03-09 20:28:54 +01:00
|
|
|
make install
|
|
|
|
popd
|
|
|
|
fi
|
|
|
|
|
|
|
|
if [ ! -e libxslt-${LIBXSLT_VERSION}.tar.gz ] ; then
|
2018-03-19 09:49:13 -07:00
|
|
|
wget http://api.github.com/repos/GNOME/libxslt/tarball/v${LIBXSLT_VERSION} -O libxslt-${LIBXSLT_VERSION}.tar.gz
|
2015-03-09 20:28:54 +01:00
|
|
|
fi
|
|
|
|
if [ ! -e libxslt-${LIBXSLT_VERSION} ] ; then
|
2018-03-19 09:49:13 -07:00
|
|
|
mkdir -p libxslt-${LIBXSLT_VERSION}
|
|
|
|
tar -zxf libxslt-${LIBXSLT_VERSION}.tar.gz --strip 1 -C libxslt-${LIBXSLT_VERSION}
|
|
|
|
pushd libxslt-${LIBXSLT_VERSION}
|
|
|
|
autoreconf --install
|
|
|
|
popd
|
2015-03-09 20:28:54 +01:00
|
|
|
fi
|
2017-01-03 09:00:52 +01:00
|
|
|
if [ ! -e "$PKG_CONFIG_LIBDIR/libxslt.pc" ] ; then
|
2017-02-06 15:55:41 +01:00
|
|
|
mkdir -p libxslt-build-"$ARCH"
|
|
|
|
pushd libxslt-build-"$ARCH"
|
2017-01-03 09:00:52 +01:00
|
|
|
../libxslt-${LIBXSLT_VERSION}/configure --host=${BUILDCHAIN} --prefix="$PREFIX" --with-libxml-prefix="$PREFIX" --without-python --without-crypto --enable-static --disable-shared
|
2015-03-09 20:28:54 +01:00
|
|
|
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
|
2017-01-03 09:00:52 +01:00
|
|
|
if [ ! -e "$PKG_CONFIG_LIBDIR/libzip.pc" ] ; then
|
2017-02-06 15:55:41 +01:00
|
|
|
mkdir -p libzip-build-"$ARCH"
|
|
|
|
pushd libzip-build-"$ARCH"
|
2017-01-03 09:00:52 +01:00
|
|
|
../libzip-${LIBZIP_VERSION}/configure --host=${BUILDCHAIN} --prefix="$PREFIX" --enable-static --disable-shared
|
2015-03-09 20:28:54 +01:00
|
|
|
make
|
|
|
|
make install
|
|
|
|
popd
|
|
|
|
fi
|
|
|
|
|
2015-07-13 14:25:31 -07:00
|
|
|
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
|
|
|
|
fi
|
2017-02-06 15:55:41 +01:00
|
|
|
if [ ! -e openssl-build-"$ARCH" ] ; then
|
2015-07-13 14:25:31 -07:00
|
|
|
tar -zxf openssl-${OPENSSL_VERSION}.tar.gz
|
2017-02-06 15:55:41 +01:00
|
|
|
mv openssl-${OPENSSL_VERSION} openssl-build-"$ARCH"
|
2015-07-13 14:25:31 -07:00
|
|
|
fi
|
2017-01-03 09:00:52 +01:00
|
|
|
if [ ! -e "$PKG_CONFIG_LIBDIR/libssl.pc" ] ; then
|
2017-02-06 15:55:41 +01:00
|
|
|
pushd openssl-build-"$ARCH"
|
2015-07-13 14:25:31 -07:00
|
|
|
perl -pi -e 's/install: all install_docs install_sw/install: install_docs install_sw/g' Makefile.org
|
2015-07-16 00:59:32 +02:00
|
|
|
# Use env to make all these temporary, so they don't pollute later builds.
|
|
|
|
env SYSTEM=android \
|
2017-02-06 15:55:41 +01:00
|
|
|
CROSS_COMPILE=${BUILDCHAIN}- \
|
2015-07-16 00:59:32 +02:00
|
|
|
MACHINE=$OPENSSL_MACHINE \
|
|
|
|
HOSTCC=gcc \
|
|
|
|
CC=gcc \
|
2017-01-03 09:00:52 +01:00
|
|
|
ANDROID_DEV="$PREFIX" \
|
|
|
|
bash -x ./config shared no-ssl2 no-ssl3 no-comp no-hw no-engine --openssldir="$PREFIX"
|
2016-08-28 19:14:06 -07:00
|
|
|
# sed -i.bak -e 's/soname=\$\$SHLIB\$\$SHLIB_SOVER\$\$SHLIB_SUFFIX/soname=\$\$SHLIB/g' Makefile.shared
|
2015-07-13 14:25:31 -07:00
|
|
|
make depend
|
|
|
|
make
|
2017-01-21 06:38:22 -08:00
|
|
|
# now fix the reference to libcrypto.so.1.0.0 to be just to libcrypto.so
|
|
|
|
perl -pi -e 's/libcrypto.so.1.0.0/libcrypto.so\x00\x00\x00\x00\x00\x00/' libssl.so.1.0.0
|
2016-04-20 11:45:28 -07:00
|
|
|
make install_sw
|
2015-07-13 14:25:31 -07:00
|
|
|
popd
|
|
|
|
fi
|
2015-07-16 00:59:35 +02:00
|
|
|
|
2015-03-09 20:28:54 +01:00
|
|
|
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
|
2017-01-03 09:00:52 +01:00
|
|
|
if [ ! -e "$PKG_CONFIG_LIBDIR/libgit2.pc" ] ; then
|
2017-01-20 21:47:06 -08:00
|
|
|
# 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
|
2017-06-21 21:12:19 -07:00
|
|
|
# also, with libgit-0.25.1 and ndk-14b we see an odd build failure with a missing rand() symbol
|
|
|
|
# trivial workaround is to just call lrand48()
|
|
|
|
perl -pi -e 's/seed = rand/seed = (int)lrand48/' libgit2-${LIBGIT2_VERSION}/src/cache.c
|
2017-02-06 15:55:41 +01:00
|
|
|
mkdir -p libgit2-build-"$ARCH"
|
|
|
|
pushd libgit2-build-"$ARCH"
|
2015-07-13 14:25:31 -07:00
|
|
|
cmake -DCMAKE_SYSTEM_NAME=Android -DSHA1_TYPE=builtin \
|
|
|
|
-DBUILD_CLAR=OFF -DBUILD_SHARED_LIBS=OFF \
|
2017-01-03 09:00:52 +01:00
|
|
|
-DCMAKE_INSTALL_PREFIX="$PREFIX" \
|
2015-07-13 14:25:31 -07:00
|
|
|
-DCURL=OFF \
|
2016-08-28 19:14:06 -07:00
|
|
|
-DUSE_SSH=OFF \
|
2017-01-03 09:00:52 +01:00
|
|
|
-DOPENSSL_SSL_LIBRARY="$PREFIX"/lib/libssl.so \
|
|
|
|
-DOPENSSL_CRYPTO_LIBRARY="$PREFIX"/lib/libcrypto.so \
|
|
|
|
-DOPENSSL_INCLUDE_DIR="$PREFIX"/include/openssl \
|
2017-01-20 21:39:01 -08:00
|
|
|
-D_OPENSSL_VERSION=${OPENSSL_VERSION} \
|
2015-07-13 14:25:31 -07:00
|
|
|
../libgit2-${LIBGIT2_VERSION}/
|
2015-03-09 20:28:54 +01:00
|
|
|
make
|
|
|
|
make install
|
|
|
|
# Patch away pkg-config dependency to zlib, its there, i promise
|
2017-01-03 09:00:52 +01:00
|
|
|
perl -pi -e 's/^(Requires.private:.*)zlib(.*)$/$1 $2/' "$PKG_CONFIG_LIBDIR"/libgit2.pc
|
2015-03-09 20:28:54 +01:00
|
|
|
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
|
2015-08-21 00:19:37 +02:00
|
|
|
if ! grep -q libusb_set_android_open_callback libusb-${LIBUSB_VERSION}/libusb/libusb.h ; then
|
|
|
|
# Patch in our libusb callback
|
|
|
|
pushd libusb-${LIBUSB_VERSION}
|
2017-01-03 09:00:52 +01:00
|
|
|
patch -p1 < "$SUBSURFACE_SOURCE"/packaging/android/patches/libusb-android.patch
|
2015-08-21 00:19:37 +02:00
|
|
|
popd
|
|
|
|
fi
|
2015-03-09 20:28:54 +01:00
|
|
|
if [ ! -e libusb-${LIBUSB_VERSION}/configure ] ; then
|
|
|
|
pushd libusb-${LIBUSB_VERSION}
|
|
|
|
mkdir m4
|
|
|
|
autoreconf -i
|
|
|
|
popd
|
|
|
|
fi
|
2017-01-03 09:00:52 +01:00
|
|
|
if [ ! -e "$PKG_CONFIG_LIBDIR/libusb-1.0.pc" ] ; then
|
2017-02-06 15:55:41 +01:00
|
|
|
mkdir -p libusb-build-"$ARCH"
|
|
|
|
pushd libusb-build-"$ARCH"
|
2017-01-03 09:00:52 +01:00
|
|
|
../libusb-${LIBUSB_VERSION}/configure --host=${BUILDCHAIN} --prefix="$PREFIX" --enable-static --disable-shared --disable-udev --enable-system-log
|
2015-08-21 00:19:38 +02:00
|
|
|
# --enable-debug-log
|
2015-03-09 20:28:54 +01:00
|
|
|
make
|
|
|
|
make install
|
|
|
|
popd
|
|
|
|
fi
|
|
|
|
|
2015-08-21 00:19:45 +02:00
|
|
|
if [ ! -e libftdi1-${LIBFTDI_VERSION}.tar.bz2 ] ; then
|
|
|
|
wget -O libftdi1-${LIBFTDI_VERSION}.tar.bz2 http://www.intra2net.com/en/developer/libftdi/download/libftdi1-${LIBFTDI_VERSION}.tar.bz2
|
|
|
|
fi
|
|
|
|
if [ ! -e libftdi1-${LIBFTDI_VERSION} ] ; then
|
|
|
|
tar -jxf libftdi1-${LIBFTDI_VERSION}.tar.bz2
|
|
|
|
fi
|
2017-01-03 09:00:52 +01:00
|
|
|
if [ ! -e "$PKG_CONFIG_LIBDIR/libftdi1.pc" ] && [ "$PLATFORM" != "Darwin" ] ; then
|
2017-02-06 15:55:41 +01:00
|
|
|
mkdir -p libftdi1-build-"$ARCH"
|
|
|
|
pushd libftdi1-build-"$ARCH"
|
2017-01-03 09:00:52 +01:00
|
|
|
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
|
2015-08-21 00:19:45 +02:00
|
|
|
make
|
|
|
|
make install
|
|
|
|
popd
|
|
|
|
fi
|
|
|
|
# Blast away the shared version to force static linking
|
2017-01-03 09:00:52 +01:00
|
|
|
if [ -e "$PREFIX/lib/libftdi1.so" ] ; then
|
|
|
|
rm "$PREFIX"/lib/libftdi1.so*
|
2015-08-21 00:19:45 +02:00
|
|
|
fi
|
|
|
|
|
2018-04-25 12:49:28 -07:00
|
|
|
if [ ! -f libdivecomputer-${ARCH}.SHA ] ; then
|
|
|
|
echo "" > libdivecomputer-${ARCH}.SHA
|
|
|
|
fi
|
|
|
|
pushd subsurface
|
|
|
|
git submodule update --recursive
|
|
|
|
popd
|
|
|
|
CURRENT_SHA=$(cd subsurface/libdivecomputer ; git describe)
|
|
|
|
PREVIOUS_SHA=$(cat libdivecomputer-${ARCH}.SHA)
|
2018-04-27 14:49:02 -07:00
|
|
|
if [[ ! "$CURRENT_SHA" = "$PREVIOUS_SHA" || ! -e "$PKG_CONFIG_LIBDIR/libdivecomputer.pc" ]] ; then
|
2017-02-06 15:55:41 +01:00
|
|
|
mkdir -p libdivecomputer-build-"$ARCH"
|
|
|
|
pushd libdivecomputer-build-"$ARCH"
|
2017-12-06 19:02:58 -08:00
|
|
|
"$SUBSURFACE_SOURCE"/libdivecomputer/configure --host=${BUILDCHAIN} --prefix="$PREFIX" --enable-static --disable-shared --enable-examples=no
|
2015-03-09 20:28:54 +01:00
|
|
|
make
|
|
|
|
make install
|
|
|
|
popd
|
|
|
|
fi
|
|
|
|
|
2015-07-09 00:42:12 +02:00
|
|
|
if [ ! -e qt-android-cmake ] ; then
|
2017-04-15 12:33:38 +02:00
|
|
|
git clone https://github.com/LaurentGomila/qt-android-cmake.git
|
2015-07-09 00:42:12 +02:00
|
|
|
else
|
|
|
|
pushd qt-android-cmake
|
2015-11-06 21:57:53 +00:00
|
|
|
git pull
|
2015-07-09 00:42:12 +02:00
|
|
|
popd
|
|
|
|
fi
|
2017-12-26 12:06:12 -08:00
|
|
|
# the Qt Android cmake addon runs androiddeployqt with '--verbose' which
|
|
|
|
# is, err, rather verbose. Let's not do that.
|
|
|
|
sed -i -e 's/--verbose//' qt-android-cmake/AddQtAndroidApk.cmake
|
2015-07-09 00:42:12 +02:00
|
|
|
|
2015-07-10 00:02:35 +02:00
|
|
|
# Should we build the mobile ui or the desktop ui?
|
2015-12-29 17:38:30 -08:00
|
|
|
# doing this backwards in order not to break people's setup
|
|
|
|
if [ "$SUBSURFACE_DESKTOP" = "ON" ] ; then
|
|
|
|
SUBSURFACE_MOBILE=
|
|
|
|
else
|
2017-02-06 15:55:41 +01:00
|
|
|
SUBSURFACE_MOBILE=ON
|
2015-12-29 17:38:30 -08:00
|
|
|
fi
|
2016-01-07 06:59:33 -08:00
|
|
|
|
|
|
|
if [ "$SUBSURFACE_MOBILE" = "ON" ] ; then
|
2017-01-03 09:00:52 +01:00
|
|
|
pushd "$SUBSURFACE_SOURCE"
|
2016-01-08 21:46:44 -08:00
|
|
|
bash ./scripts/mobilecomponents.sh
|
2016-01-07 06:59:33 -08:00
|
|
|
popd
|
|
|
|
fi
|
|
|
|
|
2015-07-10 00:02:35 +02:00
|
|
|
if [ ! -z "$SUBSURFACE_MOBILE" ] ; then
|
2017-02-06 15:55:41 +01:00
|
|
|
mkdir -p subsurface-mobile-build-"$ARCH"
|
|
|
|
cd subsurface-mobile-build-"$ARCH"
|
|
|
|
MOBILE_CMAKE=-DSUBSURFACE_TARGET_EXECUTABLE=MobileExecutable
|
2017-05-27 14:54:28 -07:00
|
|
|
BUILD_NAME=Subsurface-mobile
|
2015-07-10 00:02:35 +02:00
|
|
|
else
|
2017-02-06 15:55:41 +01:00
|
|
|
MOBILE_CMAKE=""
|
|
|
|
mkdir -p subsurface-build-"$ARCH"
|
|
|
|
cd subsurface-build-"$ARCH"
|
2017-05-27 14:54:28 -07:00
|
|
|
BUILD_NAME=Subsurface
|
2015-07-10 00:02:35 +02:00
|
|
|
fi
|
|
|
|
|
2017-01-03 09:00:52 +01:00
|
|
|
if [ "$PLATFORM" = "Darwin" ] ; then
|
2015-11-08 16:50:49 +01:00
|
|
|
FTDI=OFF
|
2015-07-20 11:13:00 +02:00
|
|
|
else
|
2015-11-08 16:50:49 +01:00
|
|
|
FTDI=ON
|
2015-07-20 11:13:00 +02:00
|
|
|
fi
|
2016-01-07 06:59:33 -08:00
|
|
|
|
2015-11-08 16:50:50 +01:00
|
|
|
PKGCONF=$(which pkg-config)
|
2015-07-13 14:25:31 -07:00
|
|
|
cmake $MOBILE_CMAKE \
|
2017-01-03 09:00:52 +01:00
|
|
|
-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 \
|
2016-08-28 19:14:06 -07:00
|
|
|
-DFORCE_LIBSSH=OFF \
|
2015-07-13 14:25:31 -07:00
|
|
|
-DLIBDC_FROM_PKGCONFIG=ON \
|
|
|
|
-DLIBGIT2_FROM_PKGCONFIG=ON \
|
|
|
|
-DNO_PRINTING=ON \
|
|
|
|
-DNO_USERMANUAL=ON \
|
2017-12-26 09:24:35 -08:00
|
|
|
-DNO_DOCS=ON \
|
2015-12-01 20:46:58 +01:00
|
|
|
-DFBSUPPORT=OFF \
|
2017-07-05 11:26:12 +02:00
|
|
|
-DCMAKE_PREFIX_PATH:UNINITIALIZED="$QT5_ANDROID_CMAKE" \
|
2017-01-03 09:00:52 +01:00
|
|
|
-DCMAKE_BUILD_TYPE="$BUILD_TYPE" \
|
2015-12-24 09:41:39 -08:00
|
|
|
-DMAKE_TESTS=OFF \
|
2015-11-08 16:50:49 +01:00
|
|
|
-DFTDISUPPORT=${FTDI} \
|
2017-01-03 09:00:52 +01:00
|
|
|
-DANDROID_NATIVE_LIBSSL="$BUILDROOT/ndk-$ARCH/sysroot/usr/lib/libssl.so" \
|
|
|
|
-DANDROID_NATIVE_LIBCRYPT="$BUILDROOT/ndk-$ARCH/sysroot/usr/lib/libcrypto.so" \
|
2017-05-25 19:15:51 +02:00
|
|
|
-DBUILDTOOLS_REVISION="$ANDROID_BUILDTOOLS_REVISION" \
|
2017-12-26 09:27:02 -08:00
|
|
|
-DCMAKE_MAKE_PROGRAM="make" \
|
2017-01-03 09:00:52 +01:00
|
|
|
"$SUBSURFACE_SOURCE"
|
2015-12-24 09:49:05 -08:00
|
|
|
|
2016-03-05 17:14:33 -08:00
|
|
|
# set up the version number
|
2016-03-10 06:28:20 -08:00
|
|
|
|
2016-04-12 17:56:25 +03:00
|
|
|
rm -f ssrf-version.h
|
2016-03-10 06:35:40 -08:00
|
|
|
make version
|
2016-03-10 06:28:20 -08:00
|
|
|
|
2016-06-23 22:56:33 +02:00
|
|
|
if [ ! -z "$SUBSURFACE_MOBILE" ] ; then
|
|
|
|
SUBSURFACE_MOBILE_VERSION=$(grep MOBILE_VERSION_STRING ssrf-version.h | awk '{ print $3 }' | tr -d \" )
|
2017-01-03 09:00:52 +01:00
|
|
|
SUBSURFACE_MOBILE_VERSION="$SUBSURFACE_MOBILE_VERSION ($(grep CANONICAL_VERSION_STRING ssrf-version.h | awk '{ print $3 }' | tr -d \"))"
|
2016-06-23 22:56:33 +02:00
|
|
|
|
|
|
|
rm -rf android-mobile
|
2017-01-03 09:00:52 +01:00
|
|
|
cp -a "$SUBSURFACE_SOURCE/android-mobile" .
|
2017-02-06 15:55:41 +01:00
|
|
|
sed -i -e "s/@SUBSURFACE_MOBILE_VERSION@/$SUBSURFACE_MOBILE_VERSION/;s/@BUILD_NR@/$BUILD_NR/" android-mobile/AndroidManifest.xml
|
2016-06-23 22:56:33 +02:00
|
|
|
else
|
|
|
|
SUBSURFACE_VERSION=$(grep CANONICAL_VERSION_STRING ssrf-version.h | awk '{ print $3 }' | tr -d \")
|
|
|
|
|
2016-12-28 23:22:34 +01:00
|
|
|
# android-mobile is hardcoded in CMakeLists.txt nowadays.
|
|
|
|
rm -rf android-mobile
|
2017-02-07 08:15:33 +02:00
|
|
|
cp -a "$SUBSURFACE_SOURCE/android" android-mobile
|
2016-12-28 23:22:34 +01:00
|
|
|
sed -i -e "s/@SUBSURFACE_VERSION@/\"$SUBSURFACE_VERSION\"/;s/@BUILD_NR@/$BUILD_NR/" android-mobile/AndroidManifest.xml
|
2016-06-23 22:56:33 +02:00
|
|
|
fi
|
2016-03-05 17:14:33 -08:00
|
|
|
|
2016-05-03 17:20:53 -07:00
|
|
|
# now make the translations
|
|
|
|
make translations
|
|
|
|
mkdir -p assets/translations
|
|
|
|
cp -a translations/*.qm assets/translations
|
|
|
|
|
2015-12-24 09:49:05 -08:00
|
|
|
# now build Subsurface and use the rest of the command line arguments
|
2017-01-03 09:00:52 +01:00
|
|
|
make "$@"
|
2015-12-24 09:49:05 -08:00
|
|
|
|
2017-05-27 14:54:28 -07:00
|
|
|
echo "Done building $BUILD_NAME for Android"
|