mirror of
https://github.com/subsurface/subsurface.git
synced 2025-01-19 22:35:27 +00:00
6451adfec1
It seems that the Qt team deviated from their previous practice to keep the Qt/x.y directory structure the same for all minor releases - so now it is indeed Qt/5.9.1 Oh well. Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
157 lines
4.8 KiB
Bash
157 lines
4.8 KiB
Bash
#!/bin/bash -eu
|
|
|
|
# run this in the top level folder you want to create Android binaries in
|
|
#
|
|
# it seems that with Qt5.7 (and later) 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
|
|
# or at line 95 of
|
|
# Qt/5.8/android_armv7/lib/cmake/Qt5Core/Qt5CoreConfigExtras.cmake
|
|
# or at line 105 of
|
|
# Qt/5.9/android_armv7/lib/cmake/Qt5Core/Qt5CoreConfigExtras.cmake
|
|
# (this script tries to do this automatically)
|
|
|
|
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.9.1
|
|
LATEST_QT=5.9.1
|
|
NDK_VERSION=r14b
|
|
SDK_VERSION=r25.2.3
|
|
|
|
ANDROID_NDK=android-ndk-${NDK_VERSION}
|
|
ANDROID_SDK=android-sdk-linux
|
|
|
|
PLATFORM=$(uname)
|
|
|
|
pushd $(dirname "$0")/../../
|
|
export SUBSURFACE_SOURCE=$PWD
|
|
popd
|
|
|
|
if [ "$PLATFORM" = Linux ] ; then
|
|
QT_BINARIES=qt-opensource-linux-x64-${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 wget unzip; do
|
|
command -v $i >/dev/null ||
|
|
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 1
|
|
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 ] ; then
|
|
if [ ! -f ${QT_BINARIES} ] ; then
|
|
wget -q ${QT_DOWNLOAD_URL}
|
|
fi
|
|
chmod +x ./${QT_BINARIES}
|
|
./${QT_BINARIES} --script "$SUBSURFACE_SOURCE"/qt-installer-noninteractive.qs --no-force-installations
|
|
fi
|
|
|
|
# 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/${QT_VERSION}/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 -q https://dl.google.com/android/repository/$NDK_BINARIES
|
|
fi
|
|
unzip -q $NDK_BINARIES
|
|
fi
|
|
|
|
if [ ! -d $ANDROID_SDK ] ; then
|
|
if [ ! -f $SDK_TOOLS ] ; then
|
|
wget -q https://dl.google.com/android/repository/$SDK_TOOLS
|
|
fi
|
|
mkdir $ANDROID_SDK
|
|
pushd $ANDROID_SDK
|
|
unzip -q ../$SDK_TOOLS
|
|
echo "Please select the SDK Platform for the latest API and for API 16 (Android 4.2.1)"
|
|
echo "as well as the latest Android SDK Tools and Android SDK Platform-tools."
|
|
echo "You can unselect the various system images that usually are selected by default."
|
|
echo "Then accept the licenses and install."
|
|
bash tools/android update sdk
|
|
# ( sleep 5 && while true ; do sleep 1; echo y; done ) | bash tools/android update sdk --no-ui -a -t 1,2,3,33
|
|
# this is copied from https://stackoverflow.com/questions/38096225/automatically-accept-all-sdk-licences
|
|
mkdir -p licenses
|
|
echo -e "\n8933bad161af4178b1185d1a37fbf41ea5269c55" > "licenses/android-sdk-license"
|
|
echo -e "\n84831b9409646a918e30573bab4c9c91346d8abd" > "licenses/android-sdk-preview-license"
|
|
|
|
popd
|
|
fi
|
|
|
|
# ok, now we have Qt, SDK, and NDK - let's get us some Subsurface
|
|
if [ ! -d subsurface ] ; then
|
|
git clone https://github.com/Subsurface-divelog/subsurface.git
|
|
fi
|
|
pushd subsurface
|
|
git pull --rebase
|
|
popd
|
|
|
|
if [ ! -d libdivecomputer ] ; then
|
|
git clone -b Subsurface-branch https://github.com/Subsurface-divelog/libdc.git 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}-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/build/outputs/apk/*.apk
|
|
rm -d ./subsurface-mobile-build-arm/AndroidManifest.xml
|
|
|
|
if [ "$USE_X" ] ; then
|
|
bash "$USE_X" subsurface/packaging/android/build.sh "$RELEASE" -buildnr "$BUILDNR" arm "$@"
|
|
else
|
|
bash subsurface/packaging/android/build.sh "$RELEASE" -buildnr "$BUILDNR" arm "$@"
|
|
fi
|
|
|
|
ls -l ./subsurface-mobile-build-arm/build/outputs/apk/*.apk
|
|
|