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

Solution: Fix the qt-android build
This commit is contained in:
Joe McIlvain 2014-11-04 12:57:39 -08:00
parent 57eff1bec0
commit 5b6293c57e
3 changed files with 37 additions and 37 deletions

View File

@ -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

View File

@ -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 {
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

View File

@ -1,7 +1,8 @@
#!/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"
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}"
##
# Build libsodium from latest release tarball
echo (android_build_verify_so "libsodium.so" &> /dev/null) || {
echo "Building qt-android libsodium from latest release tarball..." rm -rf "${cache}/libsodium"
echo (cd "${cache}" && mkdir libsodium \
&& wget https://download.libsodium.org/libsodium/releases/LATEST.tar.gz\
-O "${cache}/libsodium.tar.gz" \
&& tar -C libsodium -xf libsodium.tar.gz --strip=1) || exit 1
(cd "${cache}/libsodium" && ./autogen.sh \
&& ./configure "${ANDROID_BUILD_OPTS[@]}" --disable-soname-versions \
&& make \
&& make install) || exit 1
}
wget "https://download.libsodium.org/libsodium/releases/LATEST.tar.gz" \ ##
-O "${cache}/libsodium.tar.gz" # Build libzmq from local source
(cd "${cache}" && mkdir libsodium \ LIBTOOL_EXTRA_LDFLAGS='-avoid-version'
&& tar -C libsodium -xf libsodium.tar.gz --strip=1 \
&& cd "libsodium" && ./autogen.sh \
&& ./configure "${ANDROID_BUILD_OPTS[@]}" --disable-soname-versions \
&& make \
&& make install) || exit 1
echo (android_build_verify_so "libzmq.so" "libsodium.so" &> /dev/null) || {
echo "Building qt-android libzmq from local source..." rm -rf "${cache}/libzmq"
echo (cp -r ../.. "${cache}/libzmq" && cd "${cache}/libzmq" && make clean)
(cd "${cache}/libzmq" && ./autogen.sh \
&& ./configure "${ANDROID_BUILD_OPTS[@]}" --with-libsodium=yes \
&& make \
&& make install) || exit 1
}
cp -r ../.. "${cache}/libzmq" ##
# Verify shared libraries in prefix
(cd "${cache}/libzmq" && ./autogen.sh \
&& ./configure "${ANDROID_BUILD_OPTS[@]}" --with-libsodium=yes \
&& make \
&& make install) || exit 1
echo
echo "Verifying qt-android libsodium.so and libzmq.so libraries..."
echo
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