Commit 5b6293c5 authored by Joe McIlvain's avatar Joe McIlvain

Problem: qt-android build doesn't fully work for downstream builds

Solution: Fix the qt-android build
parent 57eff1be
...@@ -3,8 +3,8 @@ ...@@ -3,8 +3,8 @@
language: c language: c
env: env:
- BUILD_TYPE=default - BUILD_TYPE=default
- BUILD_TYPE=qt-android - BUILD_TYPE=qt-android
# Build and check this project according to the BUILD_TYPE # Build and check this project according to the BUILD_TYPE
script: ./ci_build.sh script: ./ci_build.sh
...@@ -60,7 +60,7 @@ ANDROID_BUILD_FAIL=() ...@@ -60,7 +60,7 @@ ANDROID_BUILD_FAIL=()
function android_build_check_fail { function android_build_check_fail {
if [ ! ${#ANDROID_BUILD_FAIL[@]} -eq 0 ]; then if [ ! ${#ANDROID_BUILD_FAIL[@]} -eq 0 ]; then
echo "qt-android build failed for the following reasons:" echo "Android build failed for the following reasons:"
for reason in "${ANDROID_BUILD_FAIL[@]}"; do for reason in "${ANDROID_BUILD_FAIL[@]}"; do
local formatted_reason=" ${reason}" local formatted_reason=" ${reason}"
echo "${formatted_reason}" echo "${formatted_reason}"
...@@ -248,7 +248,7 @@ function android_build_opts { ...@@ -248,7 +248,7 @@ function android_build_opts {
local CFLAGS="--sysroot=${ANDROID_BUILD_SYSROOT} -I${ANDROID_BUILD_PREFIX}/include" local CFLAGS="--sysroot=${ANDROID_BUILD_SYSROOT} -I${ANDROID_BUILD_PREFIX}/include"
local CPPFLAGS="--sysroot=${ANDROID_BUILD_SYSROOT} -I${ANDROID_BUILD_PREFIX}/include" local CPPFLAGS="--sysroot=${ANDROID_BUILD_SYSROOT} -I${ANDROID_BUILD_PREFIX}/include"
local CXXFLAGS="--sysroot=${ANDROID_BUILD_SYSROOT} -I${ANDROID_BUILD_PREFIX}/include" local CXXFLAGS="--sysroot=${ANDROID_BUILD_SYSROOT} -I${ANDROID_BUILD_PREFIX}/include"
local LDFLAGS="" local LDFLAGS="-L${ANDROID_BUILD_PREFIX}/lib"
local LIBS="-lc -lgcc -ldl" local LIBS="-lc -lgcc -ldl"
_android_build_opts_process_binaries _android_build_opts_process_binaries
......
#!/usr/bin/env bash #!/usr/bin/env bash
# Get directory of current script # Use directory of current script as the build directory and working directory
ANDROID_BUILD_DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )" cd "$( dirname "${BASH_SOURCE[0]}" )"
ANDROID_BUILD_DIR="$(pwd)"
# Get access to android_build functions and variables # Get access to android_build functions and variables
source ${ANDROID_BUILD_DIR}/android_build_helper.sh source ${ANDROID_BUILD_DIR}/android_build_helper.sh
...@@ -13,44 +14,43 @@ ANDROID_BUILD_CXXSTL="gnustl_shared_48" ...@@ -13,44 +14,43 @@ ANDROID_BUILD_CXXSTL="gnustl_shared_48"
android_build_env android_build_env
android_build_opts android_build_opts
# Clear a temporary build directory # Use a temporary build directory
cache="/tmp/android_build/${TOOLCHAIN_NAME}" cache="/tmp/android_build/${TOOLCHAIN_NAME}"
rm -rf "${cache}"
mkdir -p "${cache}" mkdir -p "${cache}"
##
echo # Build libsodium from latest release tarball
echo "Building qt-android libsodium from latest release tarball..."
echo (android_build_verify_so "libsodium.so" &> /dev/null) || {
rm -rf "${cache}/libsodium"
wget "https://download.libsodium.org/libsodium/releases/LATEST.tar.gz" \ (cd "${cache}" && mkdir libsodium \
-O "${cache}/libsodium.tar.gz" && wget https://download.libsodium.org/libsodium/releases/LATEST.tar.gz\
-O "${cache}/libsodium.tar.gz" \
(cd "${cache}" && mkdir libsodium \ && tar -C libsodium -xf libsodium.tar.gz --strip=1) || exit 1
&& tar -C libsodium -xf libsodium.tar.gz --strip=1 \
&& cd "libsodium" && ./autogen.sh \ (cd "${cache}/libsodium" && ./autogen.sh \
&& ./configure "${ANDROID_BUILD_OPTS[@]}" --disable-soname-versions \ && ./configure "${ANDROID_BUILD_OPTS[@]}" --disable-soname-versions \
&& make \ && make \
&& make install) || exit 1 && make install) || exit 1
}
echo
echo "Building qt-android libzmq from local source..." ##
echo # Build libzmq from local source
cp -r ../.. "${cache}/libzmq" LIBTOOL_EXTRA_LDFLAGS='-avoid-version'
(cd "${cache}/libzmq" && ./autogen.sh \ (android_build_verify_so "libzmq.so" "libsodium.so" &> /dev/null) || {
&& ./configure "${ANDROID_BUILD_OPTS[@]}" --with-libsodium=yes \ rm -rf "${cache}/libzmq"
&& make \ (cp -r ../.. "${cache}/libzmq" && cd "${cache}/libzmq" && make clean)
&& make install) || exit 1
(cd "${cache}/libzmq" && ./autogen.sh \
echo && ./configure "${ANDROID_BUILD_OPTS[@]}" --with-libsodium=yes \
echo "Verifying qt-android libsodium.so and libzmq.so libraries..." && make \
echo && make install) || exit 1
}
##
# Verify shared libraries in prefix
android_build_verify_so "libsodium.so" android_build_verify_so "libsodium.so"
android_build_verify_so "libzmq.so" "libsodium.so" android_build_verify_so "libzmq.so" "libsodium.so"
echo
echo "Completed qt-android build!"
echo
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment