mirror of
https://github.com/zeromq/libzmq.git
synced 2025-01-07 09:48:07 +01:00
Problem: Android helpers must provide build/clone functions.
Reason: Code factorisation & code sharing. Solution: Create more functions in helper file: - android_clone_library # Clone a library source tree. - android_build_library # Build a library in its source tree.
This commit is contained in:
parent
3dd2a6964a
commit
6fb3a58ca8
@ -445,6 +445,48 @@ function android_show_configure_opts {
|
|||||||
echo ""
|
echo ""
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function android_clone_library {
|
||||||
|
local tag="$1" ; shift
|
||||||
|
local clone_root="$1" ; shift
|
||||||
|
local clone_url="$1" ; shift
|
||||||
|
local clone_branch="$1" ; shift
|
||||||
|
|
||||||
|
mkdir -p "$(dirname "${clone_root}")"
|
||||||
|
if [ -n "${clone_branch}" ] ; then
|
||||||
|
android_build_trace "Cloning '${clone_url}' (branch '${clone_branch}') under '${clone_root}'."
|
||||||
|
git clone --quiet --depth 1 -b "${clone_branch}" "${clone_url}" "${clone_root}"
|
||||||
|
else
|
||||||
|
android_build_trace "Cloning '${clone_url}' (default branch) under '${clone_root}'."
|
||||||
|
git clone --quiet --depth 1 "${clone_url}" "${clone_root}"
|
||||||
|
fi
|
||||||
|
( cd "${clone_root}" && git log --oneline -n 1) || exit 1
|
||||||
|
}
|
||||||
|
|
||||||
|
# Caller must set CONFIG_OPTS before call.
|
||||||
|
function android_build_library {
|
||||||
|
local tag=$1 ; shift
|
||||||
|
local clone_root=$1 ; shift
|
||||||
|
|
||||||
|
android_build_trace "Cleaning library '${tag}'."
|
||||||
|
(
|
||||||
|
cd "${clone_root}" \
|
||||||
|
&& ( make clean || : ) && \
|
||||||
|
rm -f config.status
|
||||||
|
) || exit 1
|
||||||
|
|
||||||
|
(
|
||||||
|
# Remove *.la files as they might cause errors with cross compiled libraries
|
||||||
|
find "${ANDROID_BUILD_PREFIX}" -name '*.la' -exec rm {} +
|
||||||
|
|
||||||
|
cd "${clone_root}" \
|
||||||
|
&& ./autogen.sh \
|
||||||
|
&& android_show_configure_opts "${tag}" "${CONFIG_OPTS[@]}" \
|
||||||
|
&& ./configure "${CONFIG_OPTS[@]}" \
|
||||||
|
&& make -j 4 \
|
||||||
|
&& make install
|
||||||
|
) || exit 1
|
||||||
|
}
|
||||||
|
|
||||||
########################################################################
|
########################################################################
|
||||||
# Initialization
|
# Initialization
|
||||||
########################################################################
|
########################################################################
|
||||||
|
@ -126,13 +126,7 @@ elif [ "${CURVE}" == "libsodium" ]; then
|
|||||||
|
|
||||||
(android_build_verify_so "libsodium.so" &> /dev/null) || {
|
(android_build_verify_so "libsodium.so" &> /dev/null) || {
|
||||||
if [ ! -d "${LIBSODIUM_ROOT}" ] ; then
|
if [ ! -d "${LIBSODIUM_ROOT}" ] ; then
|
||||||
android_build_trace "Cloning 'https://github.com/jedisct1/libsodium.git' (branch 'stable') under '${LIBSODIUM_ROOT}'."
|
android_clone_library "LIBSODIUM" "${LIBSODIUM_ROOT}" "https://github.com/jedisct1/libsodium.git" "stable"
|
||||||
mkdir -p "$(dirname "${LIBSODIUM_ROOT}")"
|
|
||||||
git clone --quiet -b stable --depth 1 https://github.com/jedisct1/libsodium.git "${LIBSODIUM_ROOT}"
|
|
||||||
( cd "${LIBSODIUM_ROOT}" && git log --oneline -n 1) || exit 1
|
|
||||||
else
|
|
||||||
android_build_trace "Cleaning LIBSODIUM folder '${LIBSODIUM_ROOT}'."
|
|
||||||
( cd "${LIBSODIUM_ROOT}" && (make clean || :) && rm -f config.status ) || exit 1
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
(
|
(
|
||||||
@ -141,15 +135,7 @@ elif [ "${CURVE}" == "libsodium" ]; then
|
|||||||
CONFIG_OPTS+=("${ANDROID_BUILD_OPTS[@]}")
|
CONFIG_OPTS+=("${ANDROID_BUILD_OPTS[@]}")
|
||||||
CONFIG_OPTS+=("--disable-soname-versions")
|
CONFIG_OPTS+=("--disable-soname-versions")
|
||||||
|
|
||||||
# Remove *.la files as they might cause errors with cross compiled libraries
|
android_build_library "LIBSODIUM" "${LIBSODIUM_ROOT}"
|
||||||
find "${ANDROID_BUILD_PREFIX}" -name '*.la' -exec rm {} +
|
|
||||||
|
|
||||||
cd "${LIBSODIUM_ROOT}" \
|
|
||||||
&& ./autogen.sh \
|
|
||||||
&& android_show_configure_opts "LIBSODIUM" "${CONFIG_OPTS[@]}" \
|
|
||||||
&& ./configure "${CONFIG_OPTS[@]}" \
|
|
||||||
&& make -j 4 \
|
|
||||||
&& make install
|
|
||||||
) || exit 1
|
) || exit 1
|
||||||
}
|
}
|
||||||
elif [ $CURVE == "tweetnacl" ]; then
|
elif [ $CURVE == "tweetnacl" ]; then
|
||||||
@ -170,15 +156,7 @@ fi
|
|||||||
CONFIG_OPTS+=("${CURVE}")
|
CONFIG_OPTS+=("${CURVE}")
|
||||||
CONFIG_OPTS+=("--without-docs")
|
CONFIG_OPTS+=("--without-docs")
|
||||||
|
|
||||||
# Remove *.la files as they might cause errors with cross compiled libraries
|
android_build_library "LIBZMQ" "${LIBZMQ_ROOT}"
|
||||||
find "${ANDROID_BUILD_PREFIX}" -name '*.la' -exec rm {} +
|
|
||||||
|
|
||||||
cd "${LIBZMQ_ROOT}" \
|
|
||||||
&& ./autogen.sh \
|
|
||||||
&& android_show_configure_opts "LIBZMQ" "${CONFIG_OPTS[@]}" \
|
|
||||||
&& ./configure "${CONFIG_OPTS[@]}" \
|
|
||||||
&& make -j 4 \
|
|
||||||
&& make install
|
|
||||||
) || exit 1
|
) || exit 1
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user