Compile android with vcpkg (rappture, curl and openssl)

This commit is contained in:
Tal Regev 2021-04-10 01:40:48 +03:00
parent 9dae22bbe0
commit e01073d585
35 changed files with 469 additions and 140 deletions

View File

@ -13,7 +13,7 @@ jobs:
runs-on: ubuntu-latest runs-on: ubuntu-latest
strategy: strategy:
matrix: matrix:
type: [manager, libs, apps] type: [manager, libs, apps, manager-vcpkg, libs-vcpkg, apps-vcpkg]
fail-fast: false fail-fast: false
steps: steps:
- uses: actions/checkout@v2 - uses: actions/checkout@v2
@ -38,7 +38,7 @@ jobs:
if: ${{ success() && matrix.type == 'manager' }} if: ${{ success() && matrix.type == 'manager' }}
run: | run: |
./android/ci_build_manager.sh ./android/ci_build_manager.sh
- name: Build libs - name: Build libs
if: ${{ success() && matrix.type == 'libs' }} if: ${{ success() && matrix.type == 'libs' }}
run: ./android/ci_build_libraries.sh run: ./android/ci_build_libraries.sh
@ -47,6 +47,18 @@ jobs:
if: ${{ success() && matrix.type == 'apps' }} if: ${{ success() && matrix.type == 'apps' }}
run: ./android/ci_build_apps.sh run: ./android/ci_build_apps.sh
- name: Build vcpkg manager
if: ${{ success() && matrix.type == 'manager-vcpkg' }}
run: ./android/ci_build_vcpkg_manager.sh
- name: Build vcpkg libs
if: ${{ success() && matrix.type == 'libs-vcpkg' }}
run: ./android/ci_build_vcpkg_libraries.sh
- name: Build vcpkg apps
if: ${{ success() && matrix.type == 'apps-vcpkg' }}
run: ./android/ci_build_vcpkg_apps.sh
- name: Deploy to BinTray - name: Deploy to BinTray
if: ${{ success() && ! contains(matrix.type, 'libs') }} if: ${{ success() && ! contains(matrix.type, 'libs') }}
env: env:

View File

@ -207,21 +207,28 @@ if [ ! -e "${ANDROID_TC_FLAGFILE}" ]; then
touch ${ANDROID_TC_FLAGFILE} touch ${ANDROID_TC_FLAGFILE}
fi fi
if [ ! -e "${OPENSSL_FLAGFILE}" ]; then if [ $arch != "armv6" -a ! -d ${PREFIX}/${arch} ]; then
rm -rf "$BUILD_DIR/openssl-${OPENSSL_VERSION}" mkdir -p ${PREFIX}/${arch}
wget -c --no-verbose -O /tmp/openssl_${OPENSSL_VERSION}.tgz https://www.openssl.org/source/openssl-${OPENSSL_VERSION}.tar.gz
tar xzf /tmp/openssl_${OPENSSL_VERSION}.tgz --directory=$BUILD_DIR
fi fi
if [ ! -e "${CURL_FLAGFILE}" ]; then if [ $build_with_vcpkg = "no" -o $arch = "armv6" ]; then
rm -rf "$BUILD_DIR/curl-${CURL_VERSION}"
wget -c --no-verbose -O /tmp/curl_${CURL_VERSION}.tgz https://curl.haxx.se/download/curl-${CURL_VERSION}.tar.gz if [ ! -e "${OPENSSL_FLAGFILE}" ]; then
tar xzf /tmp/curl_${CURL_VERSION}.tgz --directory=$BUILD_DIR rm -rf "$BUILD_DIR/openssl-${OPENSSL_VERSION}"
wget -c --no-verbose -O /tmp/openssl_${OPENSSL_VERSION}.tgz https://www.openssl.org/source/openssl-${OPENSSL_VERSION}.tar.gz
tar xzf /tmp/openssl_${OPENSSL_VERSION}.tgz --directory=$BUILD_DIR
fi
if [ ! -e "${CURL_FLAGFILE}" ]; then
rm -rf "$BUILD_DIR/curl-${CURL_VERSION}"
wget -c --no-verbose -O /tmp/curl_${CURL_VERSION}.tgz https://curl.haxx.se/download/curl-${CURL_VERSION}.tar.gz
tar xzf /tmp/curl_${CURL_VERSION}.tgz --directory=$BUILD_DIR
fi
fi fi
packegesToInstall() packegesToInstall()
{ {
pkgs="rappture" pkgs="rappture curl[core,openssl]"
echo $(packegesList $1 $pkgs) echo $(packegesList $1 $pkgs)
} }
@ -254,7 +261,7 @@ packegesList()
echo $list_pkgs echo $list_pkgs
} }
if [ $component = "apps" -a $build_with_vcpkg = "yes" ]; then if [ $build_with_vcpkg = "yes" -a $arch != "armv6" ]; then
export XDG_CACHE_HOME=$cache_dir/vcpkgcache/ export XDG_CACHE_HOME=$cache_dir/vcpkgcache/
vcpkg_flags="--overlay-triplets=$vcpkg_ports_dir/triplets/default --clean-after-build" vcpkg_flags="--overlay-triplets=$vcpkg_ports_dir/triplets/default --clean-after-build"
if [ ! -d "$VCPKG_ROOT" ]; then if [ ! -d "$VCPKG_ROOT" ]; then
@ -301,14 +308,43 @@ if [ $component = "apps" -a $build_with_vcpkg = "yes" ]; then
$VCPKG_ROOT/vcpkg upgrade --no-dry-run $VCPKG_ROOT/vcpkg upgrade --no-dry-run
fi fi
list_apps_name="boinc_gahp uc2 ucn multi_thread sleeper worker wrapper wrappture_example fermi" vcpkgDir()
{
arch=$1
shift
vcpkg_dir="$VCPKG_ROOT/installed"
if [ $arch = "armv6" ]; then
vcpkg_dir="$vcpkg_dir/armv6-android"
elif [ $arch = "arm" ]; then
vcpkg_dir="$vcpkg_dir/arm-android"
elif [ $arch = "arm64" ]; then
vcpkg_dir="$vcpkg_dir/arm64-android"
elif [ $arch = "x86" ]; then
vcpkg_dir="$vcpkg_dir/x86-android"
elif [ $arch = "x86_64" ]; then
vcpkg_dir="$vcpkg_dir/x64-android"
fi
echo $vcpkg_dir
}
list_apps_name="boinc_gahp uc2 ucn multi_thread sleeper worker wrapper"
if [ $build_with_vcpkg = "yes" -a $arch != "armv6" ]; then
list_apps_name="$list_apps_name wrappture_example fermi"
fi
NeonTest() NeonTest()
{ {
while [ $# -gt 0 ]; do while [ $# -gt 0 ]; do
echo "NeonTest: readelf -A" "$1" echo "NeonTest: readelf -A" "$1"
if [ $(readelf -A $(find $ANDROID_TC/${arch} "../samples" -type f -name "$1") | grep -i neon | head -c1 | wc -c) -ne 0 ]; then vcpkg_dir_search=""
echo $(readelf -A $(find $ANDROID_TC/${arch} "../samples" -type f -name "$1") | grep -i neon) if [ $build_with_vcpkg = "yes" -a $arch != "armv6" ]; then
vcpkg_dir_search=$(vcpkgDir $arch)
fi
if [ $(readelf -A $(find $ANDROID_TC/${arch} "../samples" $vcpkg_dir_search -type f -name "$1") | grep -i neon | head -c1 | wc -c) -ne 0 ]; then
echo $(readelf -A $(find $ANDROID_TC/${arch} "../samples" $vcpkg_dir_search -type f -name "$1") | grep -i neon)
echo [ERROR] "$1" contains neon optimization echo [ERROR] "$1" contains neon optimization
exit 1 exit 1
fi fi
@ -330,8 +366,12 @@ Armv6Test()
{ {
while [ $# -gt 0 ]; do while [ $# -gt 0 ]; do
echo "Armv6Test: readelf -A" "$1" echo "Armv6Test: readelf -A" "$1"
if [ $(readelf -A $(find $ANDROID_TC/armv6 "BOINC/app/src/main/assets/armeabi" "../samples" -type f -name "$1") | grep -i "Tag_CPU_arch: v6" | head -c1 | wc -c) -eq 0 ]; then vcpkg_dir_search=""
echo $(readelf -A $(find $ANDROID_TC/armv6 "BOINC/app/src/main/assets/armeabi" "../samples" -type f -name "$1") | grep -i "Tag_CPU_arch:") if [ $build_with_vcpkg = "yes" -a $arch != "armv6" ]; then
vcpkg_dir_search=$(vcpkgDir $arch)
fi
if [ $(readelf -A $(find $ANDROID_TC/armv6 "BOINC/app/src/main/assets/armeabi" "../samples" $vcpkg_dir_search -type f -name "$1") | grep -i -E "Tag_CPU_arch: (v6|v5TE)" | head -c1 | wc -c) -eq 0 ]; then
echo $(readelf -A $(find $ANDROID_TC/armv6 "BOINC/app/src/main/assets/armeabi" "../samples" $vcpkg_dir_search -type f -name "$1") | grep -i "Tag_CPU_arch:")
echo [ERROR] "$1" is not armv6 cpu arch echo [ERROR] "$1" is not armv6 cpu arch
exit 1 exit 1
fi fi
@ -362,15 +402,19 @@ NeonTestApps()
RenameAllApps() RenameAllApps()
{ {
list_apps="../samples/condor/ boinc_gahp list_apps="../samples/condor/ boinc_gahp
../samples/example_app/ uc2 ../samples/example_app/ uc2
../samples/example_app/ ucn ../samples/example_app/ ucn
../samples/multi_thread/ multi_thread ../samples/multi_thread/ multi_thread
../samples/sleeper/ sleeper ../samples/sleeper/ sleeper
../samples/worker/ worker ../samples/worker/ worker
../samples/wrapper/ wrapper ../samples/wrapper/ wrapper
"
if [ $build_with_vcpkg = "yes" -a $arch != "armv6" ]; then
list_apps="$list_apps
../samples/wrappture/ wrappture_example ../samples/wrappture/ wrappture_example
../samples/wrappture/ fermi ../samples/wrappture/ fermi
" "
fi
RenameApp $1 $list_apps RenameApp $1 $list_apps
} }

View File

@ -23,6 +23,18 @@ export TOOLCHAINROOT="$NDK_ROOT/toolchains/llvm/prebuilt/linux-x86_64/"
export TCBINARIES="$TOOLCHAINROOT/bin" export TCBINARIES="$TOOLCHAINROOT/bin"
export TCINCLUDES="$ANDROIDTC/arm-linux-androideabi" export TCINCLUDES="$ANDROIDTC/arm-linux-androideabi"
export TCSYSROOT="$TOOLCHAINROOT/sysroot" export TCSYSROOT="$TOOLCHAINROOT/sysroot"
export VCPKG_DIR=$VCPKG_ROOT/installed/arm-android
CONFIG_FLAGS=""
CONFIG_LDFLAGS=""
if [ $BUILD_WITH_VCPKG = "yes" ]; then
CONFIG_LDFLAGS="-L$VCPKG_DIR/lib"
CONFIG_FLAGS="--with-libcurl=$VCPKG_DIR --with-ssl=$VCPKG_DIR --enable-vcpkg"
else
CONFIG_FLAGS="--with-ssl=$TCINCLUDES"
CONFIG_LDFLAGS="-L$TCSYSROOT/usr/lib -L$TCINCLUDES/lib"
fi
export PATH="$TCBINARIES:$TCINCLUDES/bin:$PATH" export PATH="$TCBINARIES:$TCINCLUDES/bin:$PATH"
export CC=armv7a-linux-androideabi16-clang export CC=armv7a-linux-androideabi16-clang
@ -30,7 +42,7 @@ export CXX=armv7a-linux-androideabi16-clang++
export LD=arm-linux-androideabi-ld export LD=arm-linux-androideabi-ld
export CFLAGS="--sysroot=$TCSYSROOT -DANDROID -DDECLARE_TIMEZONE -Wall -I$TCINCLUDES/include -O3 -fomit-frame-pointer -fPIE -march=armv7-a -mfloat-abi=softfp -mfpu=vfpv3-d16 -D__ANDROID_API__=16" export CFLAGS="--sysroot=$TCSYSROOT -DANDROID -DDECLARE_TIMEZONE -Wall -I$TCINCLUDES/include -O3 -fomit-frame-pointer -fPIE -march=armv7-a -mfloat-abi=softfp -mfpu=vfpv3-d16 -D__ANDROID_API__=16"
export CXXFLAGS="--sysroot=$TCSYSROOT -DANDROID -Wall -I$TCINCLUDES/include -funroll-loops -fexceptions -O3 -fomit-frame-pointer -fPIE -march=armv7-a -mfloat-abi=softfp -mfpu=vfpv3-d16 -D__ANDROID_API__=16" export CXXFLAGS="--sysroot=$TCSYSROOT -DANDROID -Wall -I$TCINCLUDES/include -funroll-loops -fexceptions -O3 -fomit-frame-pointer -fPIE -march=armv7-a -mfloat-abi=softfp -mfpu=vfpv3-d16 -D__ANDROID_API__=16"
export LDFLAGS="-L$TCSYSROOT/usr/lib -L$TCINCLUDES/lib -llog -fPIE -pie -latomic -static-libstdc++ -march=armv7-a -Wl,--fix-cortex-a8" export LDFLAGS="$CONFIG_LDFLAGS -llog -fPIE -pie -latomic -static-libstdc++ -march=armv7-a -Wl,--fix-cortex-a8"
export GDB_CFLAGS="--sysroot=$TCSYSROOT -Wall -g -I$TCINCLUDES/include" export GDB_CFLAGS="--sysroot=$TCSYSROOT -Wall -g -I$TCINCLUDES/include"
export PKG_CONFIG_SYSROOT_DIR="$TCSYSROOT" export PKG_CONFIG_SYSROOT_DIR="$TCSYSROOT"
@ -60,7 +72,11 @@ if [ -n "$COMPILEBOINC" ]; then
fi fi
if [ -n "$CONFIGURE" ]; then if [ -n "$CONFIGURE" ]; then
./_autosetup ./_autosetup
./configure --host=arm-linux --with-boinc-platform="arm-android-linux-gnu" --with-ssl="$TCINCLUDES" --disable-server --disable-manager --disable-shared --enable-static --disable-largefile if [ $BUILD_WITH_VCPKG = "yes" ]; then
chmod +x "$VCPKG_DIR/share/curl/curl-config"
export _libcurl_config="$VCPKG_DIR/share/curl/curl-config"
fi
./configure --host=arm-linux --with-boinc-platform="arm-android-linux-gnu" $CONFIG_FLAGS --disable-server --disable-manager --disable-shared --enable-static --disable-largefile
fi fi
echo MAKE_FLAGS=$MAKE_FLAGS echo MAKE_FLAGS=$MAKE_FLAGS
make $MAKE_FLAGS make $MAKE_FLAGS

View File

@ -23,6 +23,18 @@ export TOOLCHAINROOT="$NDK_ROOT/toolchains/llvm/prebuilt/linux-x86_64/"
export TCBINARIES="$TOOLCHAINROOT/bin" export TCBINARIES="$TOOLCHAINROOT/bin"
export TCINCLUDES="$ANDROIDTC/aarch64-linux-android" export TCINCLUDES="$ANDROIDTC/aarch64-linux-android"
export TCSYSROOT="$TOOLCHAINROOT/sysroot" export TCSYSROOT="$TOOLCHAINROOT/sysroot"
export VCPKG_DIR=$VCPKG_ROOT/installed/arm64-android
CONFIG_FLAGS=""
CONFIG_LDFLAGS=""
if [ $BUILD_WITH_VCPKG = "yes" ]; then
CONFIG_LDFLAGS="-L$VCPKG_DIR/lib"
CONFIG_FLAGS="--with-libcurl=$VCPKG_DIR --with-ssl=$VCPKG_DIR --enable-vcpkg"
else
CONFIG_FLAGS="--with-ssl=$TCINCLUDES"
CONFIG_LDFLAGS="-L$TCSYSROOT/usr/lib -L$TCINCLUDES/lib"
fi
export PATH="$TCBINARIES:$TCINCLUDES/bin:$PATH" export PATH="$TCBINARIES:$TCINCLUDES/bin:$PATH"
export CC=aarch64-linux-android21-clang export CC=aarch64-linux-android21-clang
@ -30,7 +42,7 @@ export CXX=aarch64-linux-android21-clang++
export LD=aarch64-linux-android-ld export LD=aarch64-linux-android-ld
export CFLAGS="--sysroot=$TCSYSROOT -DANDROID -DANDROID_64 -DDECLARE_TIMEZONE -Wall -I$TCINCLUDES/include -O3 -fomit-frame-pointer -fPIE -D__ANDROID_API__=21" export CFLAGS="--sysroot=$TCSYSROOT -DANDROID -DANDROID_64 -DDECLARE_TIMEZONE -Wall -I$TCINCLUDES/include -O3 -fomit-frame-pointer -fPIE -D__ANDROID_API__=21"
export CXXFLAGS="--sysroot=$TCSYSROOT -DANDROID -DANDROID_64 -Wall -I$TCINCLUDES/include -funroll-loops -fexceptions -O3 -fomit-frame-pointer -fPIE -D__ANDROID_API__=21" export CXXFLAGS="--sysroot=$TCSYSROOT -DANDROID -DANDROID_64 -Wall -I$TCINCLUDES/include -funroll-loops -fexceptions -O3 -fomit-frame-pointer -fPIE -D__ANDROID_API__=21"
export LDFLAGS="-L$TCSYSROOT/usr/lib -L$TCINCLUDES/lib -llog -fPIE -pie -latomic -static-libstdc++" export LDFLAGS="$CONFIG_LDFLAGS -llog -fPIE -pie -latomic -static-libstdc++"
export GDB_CFLAGS="--sysroot=$TCSYSROOT -Wall -g -I$TCINCLUDES/include" export GDB_CFLAGS="--sysroot=$TCSYSROOT -Wall -g -I$TCINCLUDES/include"
export PKG_CONFIG_SYSROOT_DIR="$TCSYSROOT" export PKG_CONFIG_SYSROOT_DIR="$TCSYSROOT"
@ -60,7 +72,11 @@ if [ -n "$COMPILEBOINC" ]; then
fi fi
if [ -n "$CONFIGURE" ]; then if [ -n "$CONFIGURE" ]; then
./_autosetup ./_autosetup
./configure --host=aarch64-linux --with-boinc-platform="aarch64-android-linux-gnu" --with-boinc-alt-platform="arm-android-linux-gnu" --with-ssl="$TCINCLUDES" --disable-server --disable-manager --disable-shared --enable-static if [ $BUILD_WITH_VCPKG = "yes" ]; then
chmod +x "$VCPKG_DIR/share/curl/curl-config"
export _libcurl_config="$VCPKG_DIR/share/curl/curl-config"
fi
./configure --host=aarch64-linux --with-boinc-platform="aarch64-android-linux-gnu" --with-boinc-alt-platform="arm-android-linux-gnu" $CONFIG_FLAGS --disable-server --disable-manager --disable-shared --enable-static
fi fi
echo MAKE_FLAGS=$MAKE_FLAGS echo MAKE_FLAGS=$MAKE_FLAGS
make $MAKE_FLAGS make $MAKE_FLAGS

View File

@ -6,7 +6,7 @@ set -e
# #
# Script to compile BOINC for Android # Script to compile BOINC for Android
BUILD_WITH_VCPKG="no"
STDOUT_TARGET="${STDOUT_TARGET:-/dev/stdout}" STDOUT_TARGET="${STDOUT_TARGET:-/dev/stdout}"
COMPILEBOINC="yes" COMPILEBOINC="yes"
CONFIGURE="yes" CONFIGURE="yes"
@ -22,6 +22,18 @@ export TCBINARIES="$ANDROIDTC/bin"
export TCINCLUDES="$ANDROIDTC/arm-linux-androideabi" export TCINCLUDES="$ANDROIDTC/arm-linux-androideabi"
export TCSYSROOT="$ANDROIDTC/sysroot" export TCSYSROOT="$ANDROIDTC/sysroot"
export STDCPPTC="$TCINCLUDES/lib/libstdc++.a" export STDCPPTC="$TCINCLUDES/lib/libstdc++.a"
export VCPKG_DIR=$VCPKG_ROOT/installed/armv6-android
CONFIG_FLAGS=""
CONFIG_LDFLAGS=""
if [ $BUILD_WITH_VCPKG = "yes" ]; then
CONFIG_LDFLAGS="-L$VCPKG_DIR/lib"
CONFIG_FLAGS="--with-libcurl=$VCPKG_DIR --with-ssl=$VCPKG_DIR --enable-vcpkg"
else
CONFIG_FLAGS="--with-ssl=$TCINCLUDES"
CONFIG_LDFLAGS="-L$TCSYSROOT/usr/lib -L$TCINCLUDES/lib"
fi
export PATH="$TCBINARIES:$TCINCLUDES/bin:$PATH" export PATH="$TCBINARIES:$TCINCLUDES/bin:$PATH"
export CC=arm-linux-androideabi-clang export CC=arm-linux-androideabi-clang
@ -29,7 +41,7 @@ export CXX=arm-linux-androideabi-clang++
export LD=arm-linux-androideabi-ld export LD=arm-linux-androideabi-ld
export CFLAGS="--sysroot=$TCSYSROOT -DANDROID -DDECLARE_TIMEZONE -Wall -I$TCINCLUDES/include -O3 -fomit-frame-pointer -fPIE -march=armv6 -mfloat-abi=softfp -mfpu=vfp -D__ANDROID_API__=16 -DARMV6" export CFLAGS="--sysroot=$TCSYSROOT -DANDROID -DDECLARE_TIMEZONE -Wall -I$TCINCLUDES/include -O3 -fomit-frame-pointer -fPIE -march=armv6 -mfloat-abi=softfp -mfpu=vfp -D__ANDROID_API__=16 -DARMV6"
export CXXFLAGS="--sysroot=$TCSYSROOT -DANDROID -Wall -I$TCINCLUDES/include -funroll-loops -fexceptions -O3 -fomit-frame-pointer -fPIE -march=armv6 -mfloat-abi=softfp -mfpu=vfp -D__ANDROID_API__=16 -DARMV6" export CXXFLAGS="--sysroot=$TCSYSROOT -DANDROID -Wall -I$TCINCLUDES/include -funroll-loops -fexceptions -O3 -fomit-frame-pointer -fPIE -march=armv6 -mfloat-abi=softfp -mfpu=vfp -D__ANDROID_API__=16 -DARMV6"
export LDFLAGS="-L$TCSYSROOT/usr/lib -L$TCINCLUDES/lib -llog -fPIE -pie -latomic -static-libstdc++ -march=armv6" export LDFLAGS="$CONFIG_LDFLAGS -L$TCSYSROOT/usr/lib -L$TCINCLUDES/lib -llog -fPIE -pie -latomic -static-libstdc++ -march=armv6"
export GDB_CFLAGS="--sysroot=$TCSYSROOT -Wall -g -I$TCINCLUDES/include" export GDB_CFLAGS="--sysroot=$TCSYSROOT -Wall -g -I$TCINCLUDES/include"
export PKG_CONFIG_SYSROOT_DIR="$TCSYSROOT" export PKG_CONFIG_SYSROOT_DIR="$TCSYSROOT"
@ -62,7 +74,11 @@ if [ -n "$COMPILEBOINC" ]; then
fi fi
if [ -n "$CONFIGURE" ]; then if [ -n "$CONFIGURE" ]; then
./_autosetup ./_autosetup
./configure --host=armv6-linux --with-boinc-platform="arm-android-linux-gnu" --with-ssl="$TCINCLUDES" --disable-server --disable-manager --disable-shared --enable-static --disable-largefile if [ $BUILD_WITH_VCPKG = "yes" ]; then
chmod +x "$VCPKG_DIR/share/curl/curl-config"
export _libcurl_config="$VCPKG_DIR/share/curl/curl-config"
fi
./configure --host=armv6-linux --with-boinc-platform="arm-android-linux-gnu" $CONFIG_FLAGS --disable-server --disable-manager --disable-shared --enable-static --disable-largefile
sed -e "s%^CLIENTLIBS *= *.*$%CLIENTLIBS = -lm $STDCPPTC%g" client/Makefile > client/Makefile.out sed -e "s%^CLIENTLIBS *= *.*$%CLIENTLIBS = -lm $STDCPPTC%g" client/Makefile > client/Makefile.out
mv client/Makefile.out client/Makefile mv client/Makefile.out client/Makefile
fi fi

View File

@ -23,6 +23,18 @@ export TOOLCHAINROOT="$NDK_ROOT/toolchains/llvm/prebuilt/linux-x86_64/"
export TCBINARIES="$TOOLCHAINROOT/bin" export TCBINARIES="$TOOLCHAINROOT/bin"
export TCINCLUDES="$ANDROIDTC/i686-linux-android" export TCINCLUDES="$ANDROIDTC/i686-linux-android"
export TCSYSROOT="$TOOLCHAINROOT/sysroot" export TCSYSROOT="$TOOLCHAINROOT/sysroot"
export VCPKG_DIR=$VCPKG_ROOT/installed/x86-android
CONFIG_FLAGS=""
CONFIG_LDFLAGS=""
if [ $BUILD_WITH_VCPKG = "yes" ]; then
CONFIG_LDFLAGS="-L$VCPKG_DIR/lib"
CONFIG_FLAGS="--with-libcurl=$VCPKG_DIR --with-ssl=$VCPKG_DIR --enable-vcpkg"
else
CONFIG_FLAGS="--with-ssl=$TCINCLUDES"
CONFIG_LDFLAGS="-L$TCSYSROOT/usr/lib -L$TCINCLUDES/lib"
fi
export PATH="$TCBINARIES:$TCINCLUDES/bin:$PATH" export PATH="$TCBINARIES:$TCINCLUDES/bin:$PATH"
export CC=i686-linux-android16-clang export CC=i686-linux-android16-clang
@ -30,7 +42,7 @@ export CXX=i686-linux-android16-clang++
export LD=i686-linux-android-ld export LD=i686-linux-android-ld
export CFLAGS="--sysroot=$TCSYSROOT -DANDROID -DDECLARE_TIMEZONE -Wall -I$TCINCLUDES/include -O3 -fomit-frame-pointer -fPIE -D__ANDROID_API__=16" export CFLAGS="--sysroot=$TCSYSROOT -DANDROID -DDECLARE_TIMEZONE -Wall -I$TCINCLUDES/include -O3 -fomit-frame-pointer -fPIE -D__ANDROID_API__=16"
export CXXFLAGS="--sysroot=$TCSYSROOT -DANDROID -Wall -I$TCINCLUDES/include -funroll-loops -fexceptions -O3 -fomit-frame-pointer -fPIE -D__ANDROID_API__=16" export CXXFLAGS="--sysroot=$TCSYSROOT -DANDROID -Wall -I$TCINCLUDES/include -funroll-loops -fexceptions -O3 -fomit-frame-pointer -fPIE -D__ANDROID_API__=16"
export LDFLAGS="-L$TCSYSROOT/usr/lib -L$TCINCLUDES/lib -llog -fPIE -pie -latomic -static-libstdc++" export LDFLAGS="$CONFIG_LDFLAGS -llog -fPIE -pie -latomic -static-libstdc++"
export GDB_CFLAGS="--sysroot=$TCSYSROOT -Wall -g -I$TCINCLUDES/include" export GDB_CFLAGS="--sysroot=$TCSYSROOT -Wall -g -I$TCINCLUDES/include"
export PKG_CONFIG_SYSROOT_DIR="$TCSYSROOT" export PKG_CONFIG_SYSROOT_DIR="$TCSYSROOT"
@ -60,7 +72,11 @@ if [ -n "$COMPILEBOINC" ]; then
fi fi
if [ -n "$CONFIGURE" ]; then if [ -n "$CONFIGURE" ]; then
./_autosetup ./_autosetup
./configure --host=i686-linux --with-boinc-platform="x86-android-linux-gnu" --with-ssl="$TCINCLUDES" --disable-server --disable-manager --disable-shared --enable-static --disable-largefile if [ $BUILD_WITH_VCPKG = "yes" ]; then
chmod +x "$VCPKG_DIR/share/curl/curl-config"
export _libcurl_config="$VCPKG_DIR/share/curl/curl-config"
fi
./configure --host=i686-linux --with-boinc-platform="x86-android-linux-gnu" $CONFIG_FLAGS --disable-server --disable-manager --disable-shared --enable-static --disable-largefile
fi fi
echo MAKE_FLAGS=$MAKE_FLAGS echo MAKE_FLAGS=$MAKE_FLAGS
make $MAKE_FLAGS make $MAKE_FLAGS

View File

@ -23,6 +23,18 @@ export TOOLCHAINROOT="$NDK_ROOT/toolchains/llvm/prebuilt/linux-x86_64/"
export TCBINARIES="$TOOLCHAINROOT/bin" export TCBINARIES="$TOOLCHAINROOT/bin"
export TCINCLUDES="$ANDROIDTC/x86_64-linux-android" export TCINCLUDES="$ANDROIDTC/x86_64-linux-android"
export TCSYSROOT="$TOOLCHAINROOT/sysroot" export TCSYSROOT="$TOOLCHAINROOT/sysroot"
export VCPKG_DIR=$VCPKG_ROOT/installed/x64-android
CONFIG_FLAGS=""
CONFIG_LDFLAGS=""
if [ $BUILD_WITH_VCPKG = "yes" ]; then
CONFIG_LDFLAGS="-L$VCPKG_DIR/lib"
CONFIG_FLAGS="--with-libcurl=$VCPKG_DIR --with-ssl=$VCPKG_DIR --enable-vcpkg"
else
CONFIG_FLAGS="--with-ssl=$TCINCLUDES"
CONFIG_LDFLAGS="-L$TCSYSROOT/usr/lib -L$TCINCLUDES/lib"
fi
export PATH="$TCBINARIES:$TCINCLUDES/bin:$PATH" export PATH="$TCBINARIES:$TCINCLUDES/bin:$PATH"
export CC=x86_64-linux-android21-clang export CC=x86_64-linux-android21-clang
@ -30,7 +42,7 @@ export CXX=x86_64-linux-android21-clang++
export LD=x86_64-linux-android-ld export LD=x86_64-linux-android-ld
export CFLAGS="--sysroot=$TCSYSROOT -DANDROID -DANDROID_64 -DDECLARE_TIMEZONE -Wall -I$TCINCLUDES/include -O3 -fomit-frame-pointer -fPIE -D__ANDROID_API__=21" export CFLAGS="--sysroot=$TCSYSROOT -DANDROID -DANDROID_64 -DDECLARE_TIMEZONE -Wall -I$TCINCLUDES/include -O3 -fomit-frame-pointer -fPIE -D__ANDROID_API__=21"
export CXXFLAGS="--sysroot=$TCSYSROOT -DANDROID -DANDROID_64 -Wall -I$TCINCLUDES/include -funroll-loops -fexceptions -O3 -fomit-frame-pointer -fPIE -D__ANDROID_API__=21" export CXXFLAGS="--sysroot=$TCSYSROOT -DANDROID -DANDROID_64 -Wall -I$TCINCLUDES/include -funroll-loops -fexceptions -O3 -fomit-frame-pointer -fPIE -D__ANDROID_API__=21"
export LDFLAGS="-L$TCSYSROOT/usr/lib64 -L$TCINCLUDES/lib64 -llog -fPIE -pie -latomic -static-libstdc++" export LDFLAGS="$CONFIG_LDFLAGS -llog -fPIE -pie -latomic -static-libstdc++"
export GDB_CFLAGS="--sysroot=$TCSYSROOT -Wall -g -I$TCINCLUDES/include" export GDB_CFLAGS="--sysroot=$TCSYSROOT -Wall -g -I$TCINCLUDES/include"
export PKG_CONFIG_SYSROOT_DIR="$TCSYSROOT" export PKG_CONFIG_SYSROOT_DIR="$TCSYSROOT"
@ -60,7 +72,11 @@ if [ -n "$COMPILEBOINC" ]; then
fi fi
if [ -n "$CONFIGURE" ]; then if [ -n "$CONFIGURE" ]; then
./_autosetup ./_autosetup
./configure --host=x86_64-linux --with-boinc-platform="x86_64-android-linux-gnu" --with-boinc-alt-platform="x86-android-linux-gnu" --with-ssl="$TCINCLUDES" --disable-server --disable-manager --disable-shared --enable-static if [ $BUILD_WITH_VCPKG = "yes" ]; then
chmod +x "$VCPKG_DIR/share/curl/curl-config"
export _libcurl_config="$VCPKG_DIR/share/curl/curl-config"
fi
./configure --host=x86_64-linux --with-boinc-platform="x86_64-android-linux-gnu" --with-boinc-alt-platform="x86-android-linux-gnu" $CONFIG_FLAGS --disable-server --disable-manager --disable-shared --enable-static
fi fi
echo MAKE_FLAGS=$MAKE_FLAGS echo MAKE_FLAGS=$MAKE_FLAGS
make $MAKE_FLAGS make $MAKE_FLAGS

View File

@ -46,7 +46,7 @@ else
MAKE_FLAGS="$MAKE_FLAGS -j $NPROC_USER" MAKE_FLAGS="$MAKE_FLAGS -j $NPROC_USER"
fi fi
if [ ! -e "${CURL_FLAGFILE}" ]; then if [ ! -e "${CURL_FLAGFILE}" -a $BUILD_WITH_VCPKG = "no" ]; then
cd "$CURL" cd "$CURL"
echo "===== building curl for arm from $PWD =====" echo "===== building curl for arm from $PWD ====="
if [ -n "$MAKECLEAN" ] && $(grep -q "^distclean:" "${CURL}/Makefile"); then if [ -n "$MAKECLEAN" ] && $(grep -q "^distclean:" "${CURL}/Makefile"); then

View File

@ -46,7 +46,7 @@ else
MAKE_FLAGS="$MAKE_FLAGS -j $NPROC_USER" MAKE_FLAGS="$MAKE_FLAGS -j $NPROC_USER"
fi fi
if [ ! -e "${CURL_FLAGFILE}" ]; then if [ ! -e "${CURL_FLAGFILE}" -a $BUILD_WITH_VCPKG = "no" ]; then
cd "$CURL" cd "$CURL"
echo "===== building curl for arm64 from $PWD =====" echo "===== building curl for arm64 from $PWD ====="
if [ -n "$MAKECLEAN" ] && $(grep -q "^distclean:" "${CURL}/Makefile"); then if [ -n "$MAKECLEAN" ] && $(grep -q "^distclean:" "${CURL}/Makefile"); then

View File

@ -6,7 +6,7 @@ set -e
# #
# Script to compile Libcurl for Android # Script to compile Libcurl for Android
BUILD_WITH_VCPKG="no"
STDOUT_TARGET="${STDOUT_TARGET:-/dev/stdout}" STDOUT_TARGET="${STDOUT_TARGET:-/dev/stdout}"
CONFIGURE="yes" CONFIGURE="yes"
MAKECLEAN="yes" MAKECLEAN="yes"
@ -48,7 +48,7 @@ else
MAKE_FLAGS="$MAKE_FLAGS -j $NPROC_USER" MAKE_FLAGS="$MAKE_FLAGS -j $NPROC_USER"
fi fi
if [ ! -e "${CURL_FLAGFILE}" ]; then if [ ! -e "${CURL_FLAGFILE}" -a $BUILD_WITH_VCPKG = "no" ]; then
cd "$CURL" cd "$CURL"
echo "===== building curl for armv6 from $PWD =====" echo "===== building curl for armv6 from $PWD ====="
if [ -n "$MAKECLEAN" ] && $(grep -q "^distclean:" "${CURL}/Makefile"); then if [ -n "$MAKECLEAN" ] && $(grep -q "^distclean:" "${CURL}/Makefile"); then

View File

@ -46,7 +46,7 @@ else
MAKE_FLAGS="$MAKE_FLAGS -j $NPROC_USER" MAKE_FLAGS="$MAKE_FLAGS -j $NPROC_USER"
fi fi
if [ ! -e "${CURL_FLAGFILE}" ]; then if [ ! -e "${CURL_FLAGFILE}" -a $BUILD_WITH_VCPKG = "no" ]; then
cd "$CURL" cd "$CURL"
echo "===== building curl for x86 from $PWD =====" echo "===== building curl for x86 from $PWD ====="
if [ -n "$MAKECLEAN" ] && $(grep -q "^distclean:" "${CURL}/Makefile"); then if [ -n "$MAKECLEAN" ] && $(grep -q "^distclean:" "${CURL}/Makefile"); then

View File

@ -46,7 +46,7 @@ else
MAKE_FLAGS="$MAKE_FLAGS -j $NPROC_USER" MAKE_FLAGS="$MAKE_FLAGS -j $NPROC_USER"
fi fi
if [ ! -e "${CURL_FLAGFILE}" ]; then if [ ! -e "${CURL_FLAGFILE}" -a $BUILD_WITH_VCPKG = "no" ]; then
cd "$CURL" cd "$CURL"
echo "===== building curl for x86-64 from $PWD =====" echo "===== building curl for x86-64 from $PWD ====="
if [ -n "$MAKECLEAN" ] && $(grep -q "^distclean:" "${CURL}/Makefile"); then if [ -n "$MAKECLEAN" ] && $(grep -q "^distclean:" "${CURL}/Makefile"); then

View File

@ -21,8 +21,19 @@ export TCSYSROOT="$TOOLCHAINROOT/sysroot"
export BOINC_API_DIR="$BOINC/api" export BOINC_API_DIR="$BOINC/api"
export BOINC_LIB_DIR="$BOINC/lib" export BOINC_LIB_DIR="$BOINC/lib"
export BOINC_ZIP_DIR="$BOINC/zip" export BOINC_ZIP_DIR="$BOINC/zip"
export VCPKG_DIR=$VCPKG_ROOT/installed/arm-android export VCPKG_DIR=$VCPKG_ROOT/installed/arm-android
CONFIG_FLAGS=""
CONFIG_LDFLAGS=""
if [ $BUILD_WITH_VCPKG = "yes" ]; then
CONFIG_LDFLAGS="-L$VCPKG_DIR/lib"
CONFIG_FLAGS="--with-libcurl=$VCPKG_DIR --with-ssl=$VCPKG_DIR --enable-vcpkg"
else
CONFIG_FLAGS="--with-ssl=$TCINCLUDES"
CONFIG_LDFLAGS="-L$TCSYSROOT/usr/lib -L$TCINCLUDES/lib"
fi
export ANDROID="yes" export ANDROID="yes"
export PATH="$TCBINARIES:$TCINCLUDES/bin:$PATH" export PATH="$TCBINARIES:$TCINCLUDES/bin:$PATH"
export CC=armv7a-linux-androideabi16-clang export CC=armv7a-linux-androideabi16-clang
@ -30,15 +41,9 @@ export CXX=armv7a-linux-androideabi16-clang++
export LD=arm-linux-androideabi-ld export LD=arm-linux-androideabi-ld
export CFLAGS="--sysroot=$TCSYSROOT -DANDROID -DDECLARE_TIMEZONE -Wall -I$TCINCLUDES/include -O3 -fomit-frame-pointer -fPIE -march=armv7-a -mfloat-abi=softfp -mfpu=vfpv3-d16 -D__ANDROID_API__=16 -I$TCINCLUDES/include -I$BOINC -I$BOINC_LIB_DIR -I$BOINC_API_DIR -I$BOINC_ZIP_DIR" export CFLAGS="--sysroot=$TCSYSROOT -DANDROID -DDECLARE_TIMEZONE -Wall -I$TCINCLUDES/include -O3 -fomit-frame-pointer -fPIE -march=armv7-a -mfloat-abi=softfp -mfpu=vfpv3-d16 -D__ANDROID_API__=16 -I$TCINCLUDES/include -I$BOINC -I$BOINC_LIB_DIR -I$BOINC_API_DIR -I$BOINC_ZIP_DIR"
export CXXFLAGS="--sysroot=$TCSYSROOT -DANDROID -Wall -funroll-loops -fexceptions -O3 -fomit-frame-pointer -I$TCINCLUDES/include -fPIE -march=armv7-a -mfloat-abi=softfp -mfpu=vfpv3-d16 -D__ANDROID_API__=16 -I$BOINC -I$BOINC_LIB_DIR -I$BOINC_API_DIR -I$BOINC_ZIP_DIR" export CXXFLAGS="--sysroot=$TCSYSROOT -DANDROID -Wall -funroll-loops -fexceptions -O3 -fomit-frame-pointer -I$TCINCLUDES/include -fPIE -march=armv7-a -mfloat-abi=softfp -mfpu=vfpv3-d16 -D__ANDROID_API__=16 -I$BOINC -I$BOINC_LIB_DIR -I$BOINC_API_DIR -I$BOINC_ZIP_DIR"
export LDFLAGS="-L$TCSYSROOT/usr/lib -L$TCINCLUDES/lib -llog -fPIE -pie -latomic -static-libstdc++ -march=armv7-a -Wl,--fix-cortex-a8" export LDFLAGS="$CONFIG_LDFLAGS -L$TCSYSROOT/usr/lib -L$TCINCLUDES/lib -llog -fPIE -pie -latomic -static-libstdc++ -march=armv7-a -Wl,--fix-cortex-a8"
export GDB_CFLAGS="--sysroot=$TCSYSROOT -Wall -g -I$TCINCLUDES/include" export GDB_CFLAGS="--sysroot=$TCSYSROOT -Wall -g -I$TCINCLUDES/include"
VCPKG_FLAG=""
if [ $BUILD_WITH_VCPKG = "yes" ]; then
VCPKG_FLAG="--enable-vcpkg"
fi
MAKE_FLAGS="" MAKE_FLAGS=""
if [ $VERBOSE = "no" ]; then if [ $VERBOSE = "no" ]; then
@ -66,7 +71,7 @@ if [ -n "$COMPILEBOINC" ]; then
fi fi
if [ -n "$CONFIGURE" ]; then if [ -n "$CONFIGURE" ]; then
./_autosetup ./_autosetup
./configure --host=arm-linux --with-boinc-platform="arm-android-linux-gnu" --prefix="$TCINCLUDES" --libdir="$TCINCLUDES/lib" --with-ssl="$TCINCLUDES" --enable-apps $VCPKG_FLAG --disable-server --disable-manager --disable-client --disable-libraries --disable-shared --enable-static --disable-largefile --enable-boinczip ./configure --host=arm-linux --with-boinc-platform="arm-android-linux-gnu" --prefix="$TCINCLUDES" --libdir="$TCINCLUDES/lib" $CONFIG_FLAGS --enable-apps --disable-server --disable-manager --disable-client --disable-libraries --disable-shared --enable-static --disable-largefile --enable-boinczip
fi fi
echo MAKE_FLAGS=$MAKE_FLAGS echo MAKE_FLAGS=$MAKE_FLAGS
make $MAKE_FLAGS make $MAKE_FLAGS

View File

@ -21,8 +21,19 @@ export TCSYSROOT="$TOOLCHAINROOT/sysroot"
export BOINC_API_DIR="$BOINC/api" export BOINC_API_DIR="$BOINC/api"
export BOINC_LIB_DIR="$BOINC/lib" export BOINC_LIB_DIR="$BOINC/lib"
export BOINC_ZIP_DIR="$BOINC/zip" export BOINC_ZIP_DIR="$BOINC/zip"
export VCPKG_DIR=$VCPKG_ROOT/installed/arm64-android export VCPKG_DIR=$VCPKG_ROOT/installed/arm64-android
CONFIG_FLAGS=""
CONFIG_LDFLAGS=""
if [ $BUILD_WITH_VCPKG = "yes" ]; then
CONFIG_LDFLAGS="-L$VCPKG_DIR/lib"
CONFIG_FLAGS="--with-libcurl=$VCPKG_DIR --with-ssl=$VCPKG_DIR --enable-vcpkg"
else
CONFIG_FLAGS="--with-ssl=$TCINCLUDES"
CONFIG_LDFLAGS="-L$TCSYSROOT/usr/lib -L$TCINCLUDES/lib"
fi
export ANDROID="yes" export ANDROID="yes"
export PATH="$TCBINARIES:$TCINCLUDES/bin:$PATH" export PATH="$TCBINARIES:$TCINCLUDES/bin:$PATH"
export CC=aarch64-linux-android21-clang export CC=aarch64-linux-android21-clang
@ -30,13 +41,13 @@ export CXX=aarch64-linux-android21-clang++
export LD=aarch64-linux-android-ld export LD=aarch64-linux-android-ld
export CFLAGS="--sysroot=$TCSYSROOT -DANDROID -DANDROID_64 -DDECLARE_TIMEZONE -Wall -I$TCINCLUDES/include -O3 -fomit-frame-pointer -fPIE -D__ANDROID_API__=21 -I$TCINCLUDES/include -I$BOINC -I$BOINC_LIB_DIR -I$BOINC_API_DIR -I$BOINC_ZIP_DIR" export CFLAGS="--sysroot=$TCSYSROOT -DANDROID -DANDROID_64 -DDECLARE_TIMEZONE -Wall -I$TCINCLUDES/include -O3 -fomit-frame-pointer -fPIE -D__ANDROID_API__=21 -I$TCINCLUDES/include -I$BOINC -I$BOINC_LIB_DIR -I$BOINC_API_DIR -I$BOINC_ZIP_DIR"
export CXXFLAGS="--sysroot=$TCSYSROOT -DANDROID -DANDROID_64 -Wall -funroll-loops -fexceptions -O3 -fomit-frame-pointer -I$TCINCLUDES/include -fPIE -D__ANDROID_API__=21 -I$BOINC -I$BOINC_LIB_DIR -I$BOINC_API_DIR -I$BOINC_ZIP_DIR" export CXXFLAGS="--sysroot=$TCSYSROOT -DANDROID -DANDROID_64 -Wall -funroll-loops -fexceptions -O3 -fomit-frame-pointer -I$TCINCLUDES/include -fPIE -D__ANDROID_API__=21 -I$BOINC -I$BOINC_LIB_DIR -I$BOINC_API_DIR -I$BOINC_ZIP_DIR"
export LDFLAGS="-L$TCSYSROOT/usr/lib -L$TCINCLUDES/lib -llog -fPIE -pie -latomic -static-libstdc++ -lz" export LDFLAGS="$CONFIG_LDFLAGS -L$TCSYSROOT/usr/lib -L$TCINCLUDES/lib -llog -fPIE -pie -latomic -static-libstdc++ -lz"
export GDB_CFLAGS="--sysroot=$TCSYSROOT -Wall -g -I$TCINCLUDES/include" export GDB_CFLAGS="--sysroot=$TCSYSROOT -Wall -g -I$TCINCLUDES/include"
VCPKG_FLAG="" ENABLE_VCPKG_FLAG=""
if [ $BUILD_WITH_VCPKG = "yes" ]; then if [ $BUILD_WITH_VCPKG = "yes" ]; then
VCPKG_FLAG="--enable-vcpkg" ENABLE_VCPKG_FLAG="--enable-vcpkg"
fi fi
MAKE_FLAGS="" MAKE_FLAGS=""
@ -66,7 +77,7 @@ if [ -n "$COMPILEBOINC" ]; then
fi fi
if [ -n "$CONFIGURE" ]; then if [ -n "$CONFIGURE" ]; then
./_autosetup ./_autosetup
./configure --host=aarch64-linux --with-boinc-platform="aarch64-android-linux-gnu" --with-boinc-alt-platform="arm-android-linux-gnu" --prefix="$TCINCLUDES" --libdir="$TCINCLUDES/lib" --with-ssl="$TCINCLUDES" --enable-apps $VCPKG_FLAG --disable-server --disable-manager --disable-client --disable-libraries --disable-shared --enable-static --enable-boinczip ./configure --host=aarch64-linux --with-boinc-platform="aarch64-android-linux-gnu" --with-boinc-alt-platform="arm-android-linux-gnu" --prefix="$TCINCLUDES" --libdir="$TCINCLUDES/lib" $CONFIG_FLAGS --enable-apps --disable-server --disable-manager --disable-client --disable-libraries --disable-shared --enable-static --enable-boinczip
fi fi
echo MAKE_FLAGS=$MAKE_FLAGS echo MAKE_FLAGS=$MAKE_FLAGS
make $MAKE_FLAGS make $MAKE_FLAGS

View File

@ -2,7 +2,7 @@
set -e set -e
#script to compile Example for Android #script to compile Example for Android
BUILD_WITH_VCPKG="no"
STDOUT_TARGET="${STDOUT_TARGET:-/dev/stdout}" STDOUT_TARGET="${STDOUT_TARGET:-/dev/stdout}"
COMPILEBOINC="yes" COMPILEBOINC="yes"
CONFIGURE="yes" CONFIGURE="yes"
@ -20,8 +20,19 @@ export STDCPPTC="$TCINCLUDES/lib/libstdc++.a"
export BOINC_API_DIR="$BOINC/api" export BOINC_API_DIR="$BOINC/api"
export BOINC_LIB_DIR="$BOINC/lib" export BOINC_LIB_DIR="$BOINC/lib"
export BOINC_ZIP_DIR="$BOINC/zip" export BOINC_ZIP_DIR="$BOINC/zip"
export VCPKG_DIR=$VCPKG_ROOT/installed/armv6-android export VCPKG_DIR=$VCPKG_ROOT/installed/armv6-android
CONFIG_FLAGS=""
CONFIG_LDFLAGS=""
if [ $BUILD_WITH_VCPKG = "yes" ]; then
CONFIG_LDFLAGS="-L$VCPKG_DIR/lib"
CONFIG_FLAGS="--with-libcurl=$VCPKG_DIR --with-ssl=$VCPKG_DIR --enable-vcpkg"
else
CONFIG_FLAGS="--with-ssl=$TCINCLUDES"
CONFIG_LDFLAGS="-L$TCSYSROOT/usr/lib -L$TCINCLUDES/lib"
fi
export ANDROID="yes" export ANDROID="yes"
export PATH="$TCBINARIES:$TCINCLUDES/bin:$PATH" export PATH="$TCBINARIES:$TCINCLUDES/bin:$PATH"
export CC=arm-linux-androideabi-clang export CC=arm-linux-androideabi-clang
@ -29,13 +40,13 @@ export CXX=arm-linux-androideabi-clang++
export LD=arm-linux-androideabi-ld export LD=arm-linux-androideabi-ld
export CFLAGS="--sysroot=$TCSYSROOT -DANDROID -DDECLARE_TIMEZONE -Wall -I$TCINCLUDES/include -O3 -fomit-frame-pointer -fPIE -march=armv6 -mfloat-abi=softfp -mfpu=vfp -D__ANDROID_API__=16 -DARMV6 -I$TCINCLUDES/include -I$BOINC -I$BOINC_LIB_DIR -I$BOINC_API_DIR -I$BOINC_ZIP_DIR" export CFLAGS="--sysroot=$TCSYSROOT -DANDROID -DDECLARE_TIMEZONE -Wall -I$TCINCLUDES/include -O3 -fomit-frame-pointer -fPIE -march=armv6 -mfloat-abi=softfp -mfpu=vfp -D__ANDROID_API__=16 -DARMV6 -I$TCINCLUDES/include -I$BOINC -I$BOINC_LIB_DIR -I$BOINC_API_DIR -I$BOINC_ZIP_DIR"
export CXXFLAGS="--sysroot=$TCSYSROOT -DANDROID -Wall -funroll-loops -fexceptions -O3 -fomit-frame-pointer -I$TCINCLUDES/include -fPIE -march=armv6 -mfloat-abi=softfp -mfpu=vfp -D__ANDROID_API__=16 -DARMV6 -I$BOINC -I$BOINC_LIB_DIR -I$BOINC_API_DIR -I$BOINC_ZIP_DIR" export CXXFLAGS="--sysroot=$TCSYSROOT -DANDROID -Wall -funroll-loops -fexceptions -O3 -fomit-frame-pointer -I$TCINCLUDES/include -fPIE -march=armv6 -mfloat-abi=softfp -mfpu=vfp -D__ANDROID_API__=16 -DARMV6 -I$BOINC -I$BOINC_LIB_DIR -I$BOINC_API_DIR -I$BOINC_ZIP_DIR"
export LDFLAGS="-L$TCSYSROOT/usr/lib -L$TCINCLUDES/lib -llog -fPIE -pie -latomic -static-libstdc++ -march=armv6" export LDFLAGS="$CONFIG_LDFLAGS -L$TCSYSROOT/usr/lib -L$TCINCLUDES/lib -llog -fPIE -pie -latomic -static-libstdc++ -march=armv6"
export GDB_CFLAGS="--sysroot=$TCSYSROOT -Wall -g -I$TCINCLUDES/include" export GDB_CFLAGS="--sysroot=$TCSYSROOT -Wall -g -I$TCINCLUDES/include"
VCPKG_FLAG="" ENABLE_VCPKG_FLAG=""
if [ $BUILD_WITH_VCPKG = "yes" ]; then if [ $BUILD_WITH_VCPKG = "yes" ]; then
VCPKG_FLAG="--enable-vcpkg" ENABLE_VCPKG_FLAG="--enable-vcpkg"
fi fi
MAKE_FLAGS="" MAKE_FLAGS=""
@ -65,7 +76,7 @@ if [ -n "$COMPILEBOINC" ]; then
fi fi
if [ -n "$CONFIGURE" ]; then if [ -n "$CONFIGURE" ]; then
./_autosetup ./_autosetup
./configure --host=armv6-linux --with-boinc-platform="armv-android-linux-gnu" --prefix="$TCINCLUDES" --libdir="$TCINCLUDES/lib" --with-ssl="$TCINCLUDES" --enable-apps $VCPKG_FLAG --disable-server --disable-manager --disable-client --disable-libraries --disable-shared --enable-static --disable-largefile --enable-boinczip ./configure --host=armv6-linux --with-boinc-platform="armv-android-linux-gnu" --prefix="$TCINCLUDES" --libdir="$TCINCLUDES/lib" $CONFIG_FLAGS --enable-apps --disable-server --disable-manager --disable-client --disable-libraries --disable-shared --enable-static --disable-largefile --enable-boinczip
fi fi
echo MAKE_FLAGS=$MAKE_FLAGS echo MAKE_FLAGS=$MAKE_FLAGS
make $MAKE_FLAGS make $MAKE_FLAGS

View File

@ -21,8 +21,19 @@ export TCSYSROOT="$TOOLCHAINROOT/sysroot"
export BOINC_API_DIR="$BOINC/api" export BOINC_API_DIR="$BOINC/api"
export BOINC_LIB_DIR="$BOINC/lib" export BOINC_LIB_DIR="$BOINC/lib"
export BOINC_ZIP_DIR="$BOINC/zip" export BOINC_ZIP_DIR="$BOINC/zip"
export VCPKG_DIR=$VCPKG_ROOT/installed/x86-android export VCPKG_DIR=$VCPKG_ROOT/installed/x86-android
CONFIG_FLAGS=""
CONFIG_LDFLAGS=""
if [ $BUILD_WITH_VCPKG = "yes" ]; then
CONFIG_LDFLAGS="-L$VCPKG_DIR/lib"
CONFIG_FLAGS="--with-libcurl=$VCPKG_DIR --with-ssl=$VCPKG_DIR --enable-vcpkg"
else
CONFIG_FLAGS="--with-ssl=$TCINCLUDES"
CONFIG_LDFLAGS="-L$TCSYSROOT/usr/lib -L$TCINCLUDES/lib"
fi
export ANDROID="yes" export ANDROID="yes"
export PATH="$TCBINARIES:$TCINCLUDES/bin:$PATH" export PATH="$TCBINARIES:$TCINCLUDES/bin:$PATH"
export CC=i686-linux-android16-clang export CC=i686-linux-android16-clang
@ -30,15 +41,9 @@ export CXX=i686-linux-android16-clang++
export LD=i686-linux-android-ld export LD=i686-linux-android-ld
export CFLAGS="--sysroot=$TCSYSROOT -DANDROID -DDECLARE_TIMEZONE -Wall -I$TCINCLUDES/include -O3 -fomit-frame-pointer -fPIE -D__ANDROID_API__=16 -I$TCINCLUDES/include -I$BOINC -I$BOINC_LIB_DIR -I$BOINC_API_DIR -I$BOINC_ZIP_DIR" export CFLAGS="--sysroot=$TCSYSROOT -DANDROID -DDECLARE_TIMEZONE -Wall -I$TCINCLUDES/include -O3 -fomit-frame-pointer -fPIE -D__ANDROID_API__=16 -I$TCINCLUDES/include -I$BOINC -I$BOINC_LIB_DIR -I$BOINC_API_DIR -I$BOINC_ZIP_DIR"
export CXXFLAGS="--sysroot=$TCSYSROOT -DANDROID -Wall -funroll-loops -fexceptions -O3 -fomit-frame-pointer -I$TCINCLUDES/include -fPIE -D__ANDROID_API__=16 -I$BOINC -I$BOINC_LIB_DIR -I$BOINC_API_DIR -I$BOINC_ZIP_DIR" export CXXFLAGS="--sysroot=$TCSYSROOT -DANDROID -Wall -funroll-loops -fexceptions -O3 -fomit-frame-pointer -I$TCINCLUDES/include -fPIE -D__ANDROID_API__=16 -I$BOINC -I$BOINC_LIB_DIR -I$BOINC_API_DIR -I$BOINC_ZIP_DIR"
export LDFLAGS="-L$TCSYSROOT/usr/lib -L$TCINCLUDES/lib -llog -fPIE -pie -latomic -static-libstdc++ -lz" export LDFLAGS="$CONFIG_LDFLAGS -L$TCSYSROOT/usr/lib -L$TCINCLUDES/lib -llog -fPIE -pie -latomic -static-libstdc++ -lz"
export GDB_CFLAGS="--sysroot=$TCSYSROOT -Wall -g -I$TCINCLUDES/include" export GDB_CFLAGS="--sysroot=$TCSYSROOT -Wall -g -I$TCINCLUDES/include"
VCPKG_FLAG=""
if [ $BUILD_WITH_VCPKG = "yes" ]; then
VCPKG_FLAG="--enable-vcpkg"
fi
MAKE_FLAGS="" MAKE_FLAGS=""
if [ $VERBOSE = "no" ]; then if [ $VERBOSE = "no" ]; then
@ -66,7 +71,7 @@ if [ -n "$COMPILEBOINC" ]; then
fi fi
if [ -n "$CONFIGURE" ]; then if [ -n "$CONFIGURE" ]; then
./_autosetup ./_autosetup
./configure --host=i686-linux --with-boinc-platform="x86-android-linux-gnu" --prefix="$TCINCLUDES" --libdir="$TCINCLUDES/lib" --with-ssl="$TCINCLUDES" --enable-apps $VCPKG_FLAG --disable-server --disable-manager --disable-client --disable-libraries --disable-shared --enable-static --disable-largefile --enable-boinczip ./configure --host=i686-linux --with-boinc-platform="x86-android-linux-gnu" --prefix="$TCINCLUDES" --libdir="$TCINCLUDES/lib" $CONFIG_FLAGS --enable-apps --disable-server --disable-manager --disable-client --disable-libraries --disable-shared --enable-static --disable-largefile --enable-boinczip
fi fi
echo MAKE_FLAGS=$MAKE_FLAGS echo MAKE_FLAGS=$MAKE_FLAGS
make $MAKE_FLAGS make $MAKE_FLAGS

View File

@ -21,8 +21,19 @@ export TCSYSROOT="$TOOLCHAINROOT/sysroot"
export BOINC_API_DIR="$BOINC/api" export BOINC_API_DIR="$BOINC/api"
export BOINC_LIB_DIR="$BOINC/lib" export BOINC_LIB_DIR="$BOINC/lib"
export BOINC_ZIP_DIR="$BOINC/zip" export BOINC_ZIP_DIR="$BOINC/zip"
export VCPKG_DIR=$VCPKG_ROOT/installed/x64-android export VCPKG_DIR=$VCPKG_ROOT/installed/x64-android
CONFIG_FLAGS=""
CONFIG_LDFLAGS=""
if [ $BUILD_WITH_VCPKG = "yes" ]; then
CONFIG_LDFLAGS="-L$VCPKG_DIR/lib"
CONFIG_FLAGS="--with-libcurl=$VCPKG_DIR --with-ssl=$VCPKG_DIR --enable-vcpkg"
else
CONFIG_FLAGS="--with-ssl=$TCINCLUDES"
CONFIG_LDFLAGS="-L$TCSYSROOT/usr/lib -L$TCINCLUDES/lib"
fi
export ANDROID="yes" export ANDROID="yes"
export PATH="$TCBINARIES:$TCINCLUDES/bin:$PATH" export PATH="$TCBINARIES:$TCINCLUDES/bin:$PATH"
export CC=x86_64-linux-android21-clang export CC=x86_64-linux-android21-clang
@ -30,13 +41,13 @@ export CXX=x86_64-linux-android21-clang++
export LD=x86_64-linux-android-ld export LD=x86_64-linux-android-ld
export CFLAGS="--sysroot=$TCSYSROOT -DANDROID -DANDROID_64 -DDECLARE_TIMEZONE -Wall -I$TCINCLUDES/include -O3 -fomit-frame-pointer -fPIE -D__ANDROID_API__=21 -I$TCINCLUDES/include -I$BOINC -I$BOINC_LIB_DIR -I$BOINC_API_DIR -I$BOINC_ZIP_DIR" export CFLAGS="--sysroot=$TCSYSROOT -DANDROID -DANDROID_64 -DDECLARE_TIMEZONE -Wall -I$TCINCLUDES/include -O3 -fomit-frame-pointer -fPIE -D__ANDROID_API__=21 -I$TCINCLUDES/include -I$BOINC -I$BOINC_LIB_DIR -I$BOINC_API_DIR -I$BOINC_ZIP_DIR"
export CXXFLAGS="--sysroot=$TCSYSROOT -DANDROID -DANDROID_64 -Wall -funroll-loops -fexceptions -O3 -fomit-frame-pointer -I$TCINCLUDES/include -fPIE -D__ANDROID_API__=21 -I$BOINC -I$BOINC_LIB_DIR -I$BOINC_API_DIR -I$BOINC_ZIP_DIR" export CXXFLAGS="--sysroot=$TCSYSROOT -DANDROID -DANDROID_64 -Wall -funroll-loops -fexceptions -O3 -fomit-frame-pointer -I$TCINCLUDES/include -fPIE -D__ANDROID_API__=21 -I$BOINC -I$BOINC_LIB_DIR -I$BOINC_API_DIR -I$BOINC_ZIP_DIR"
export LDFLAGS="-L$TCSYSROOT/usr/lib -L$TCINCLUDES/lib -llog -fPIE -pie -latomic -static-libstdc++ -lz" export LDFLAGS="$CONFIG_LDFLAGS -L$TCSYSROOT/usr/lib -L$TCINCLUDES/lib -llog -fPIE -pie -latomic -static-libstdc++ -lz"
export GDB_CFLAGS="--sysroot=$TCSYSROOT -Wall -g -I$TCINCLUDES/include" export GDB_CFLAGS="--sysroot=$TCSYSROOT -Wall -g -I$TCINCLUDES/include"
VCPKG_FLAG="" ENABLE_VCPKG_FLAG=""
if [ $BUILD_WITH_VCPKG = "yes" ]; then if [ $BUILD_WITH_VCPKG = "yes" ]; then
VCPKG_FLAG="--enable-vcpkg" ENABLE_VCPKG_FLAG="--enable-vcpkg"
fi fi
MAKE_FLAGS="" MAKE_FLAGS=""
@ -66,7 +77,7 @@ if [ -n "$COMPILEBOINC" ]; then
fi fi
if [ -n "$CONFIGURE" ]; then if [ -n "$CONFIGURE" ]; then
./_autosetup ./_autosetup
./configure --host=x86_64-linux --with-boinc-platform="x86_64-android-linux-gnu" --with-boinc-alt-platform="x86-android-linux-gnu" --prefix="$TCINCLUDES" --libdir="$TCINCLUDES/lib" --with-ssl="$TCINCLUDES" --enable-apps $VCPKG_FLAG --disable-server --disable-manager --disable-client --disable-libraries --disable-shared --enable-boinczip ./configure --host=x86_64-linux --with-boinc-platform="x86_64-android-linux-gnu" --with-boinc-alt-platform="x86-android-linux-gnu" --prefix="$TCINCLUDES" --libdir="$TCINCLUDES/lib" $CONFIG_FLAGS --enable-apps --disable-server --disable-manager --disable-client --disable-libraries --disable-shared --enable-boinczip
fi fi
echo MAKE_FLAGS=$MAKE_FLAGS echo MAKE_FLAGS=$MAKE_FLAGS
make $MAKE_FLAGS make $MAKE_FLAGS

View File

@ -24,6 +24,18 @@ export TOOLCHAINROOT="$NDK_ROOT/toolchains/llvm/prebuilt/linux-x86_64/"
export TCBINARIES="$TOOLCHAINROOT/bin" export TCBINARIES="$TOOLCHAINROOT/bin"
export TCINCLUDES="$ANDROIDTC/arm-linux-androideabi" export TCINCLUDES="$ANDROIDTC/arm-linux-androideabi"
export TCSYSROOT="$TOOLCHAINROOT/sysroot" export TCSYSROOT="$TOOLCHAINROOT/sysroot"
export VCPKG_DIR=$VCPKG_ROOT/installed/arm-android
CONFIG_FLAGS=""
CONFIG_LDFLAGS=""
if [ $BUILD_WITH_VCPKG = "yes" ]; then
CONFIG_LDFLAGS="-L$VCPKG_DIR/lib"
CONFIG_FLAGS="--with-libcurl=$VCPKG_DIR --with-ssl=$VCPKG_DIR --enable-vcpkg"
else
CONFIG_FLAGS="--with-ssl=$TCINCLUDES"
CONFIG_LDFLAGS="-L$TCSYSROOT/usr/lib -L$TCINCLUDES/lib"
fi
export PATH="$TCBINARIES:$TCINCLUDES/bin:$PATH" export PATH="$TCBINARIES:$TCINCLUDES/bin:$PATH"
export CC=armv7a-linux-androideabi16-clang export CC=armv7a-linux-androideabi16-clang
@ -31,7 +43,7 @@ export CXX=armv7a-linux-androideabi16-clang++
export LD=arm-linux-androideabi-ld export LD=arm-linux-androideabi-ld
export CFLAGS="--sysroot=$TCSYSROOT -DANDROID -DDECLARE_TIMEZONE -Wall -I$TCINCLUDES/include -O3 -fomit-frame-pointer -fPIE -march=armv7-a -mfloat-abi=softfp -mfpu=vfpv3-d16 -D__ANDROID_API__=16" export CFLAGS="--sysroot=$TCSYSROOT -DANDROID -DDECLARE_TIMEZONE -Wall -I$TCINCLUDES/include -O3 -fomit-frame-pointer -fPIE -march=armv7-a -mfloat-abi=softfp -mfpu=vfpv3-d16 -D__ANDROID_API__=16"
export CXXFLAGS="--sysroot=$TCSYSROOT -DANDROID -Wall -I$TCINCLUDES/include -funroll-loops -fexceptions -O3 -fomit-frame-pointer -fPIE -march=armv7-a -mfloat-abi=softfp -mfpu=vfpv3-d16 -D__ANDROID_API__=16" export CXXFLAGS="--sysroot=$TCSYSROOT -DANDROID -Wall -I$TCINCLUDES/include -funroll-loops -fexceptions -O3 -fomit-frame-pointer -fPIE -march=armv7-a -mfloat-abi=softfp -mfpu=vfpv3-d16 -D__ANDROID_API__=16"
export LDFLAGS="-L$TCSYSROOT/usr/lib -L$TCINCLUDES/lib -llog -fPIE -pie -latomic -static-libstdc++ -march=armv7-a -Wl,--fix-cortex-a8" export LDFLAGS="$CONFIG_LDFLAGS -llog -fPIE -pie -latomic -static-libstdc++ -march=armv7-a -Wl,--fix-cortex-a8"
export GDB_CFLAGS="--sysroot=$TCSYSROOT -Wall -g -I$TCINCLUDES/include" export GDB_CFLAGS="--sysroot=$TCSYSROOT -Wall -g -I$TCINCLUDES/include"
export PKG_CONFIG_SYSROOT_DIR="$TCSYSROOT" export PKG_CONFIG_SYSROOT_DIR="$TCSYSROOT"
@ -62,7 +74,7 @@ if [ -n "$COMPILEBOINC" ]; then
fi fi
if [ -n "$CONFIGURE" ]; then if [ -n "$CONFIGURE" ]; then
./_autosetup ./_autosetup
./configure --host=arm-linux --with-boinc-platform="arm-android-linux-gnu" --prefix="$TCINCLUDES" --libdir="$TCINCLUDES/lib" --with-ssl="$TCINCLUDES" --disable-server --disable-manager --disable-client --disable-shared --enable-static --disable-largefile --enable-boinczip ./configure --host=arm-linux --with-boinc-platform="arm-android-linux-gnu" --prefix="$TCINCLUDES" --libdir="$TCINCLUDES/lib" $CONFIG_FLAGS --disable-server --disable-manager --disable-client --disable-shared --enable-static --disable-largefile --enable-boinczip
fi fi
echo MAKE_FLAGS=$MAKE_FLAGS echo MAKE_FLAGS=$MAKE_FLAGS
make $MAKE_FLAGS make $MAKE_FLAGS

View File

@ -24,6 +24,18 @@ export TOOLCHAINROOT="$NDK_ROOT/toolchains/llvm/prebuilt/linux-x86_64/"
export TCBINARIES="$TOOLCHAINROOT/bin" export TCBINARIES="$TOOLCHAINROOT/bin"
export TCINCLUDES="$ANDROIDTC/aarch64-linux-android" export TCINCLUDES="$ANDROIDTC/aarch64-linux-android"
export TCSYSROOT="$TOOLCHAINROOT/sysroot" export TCSYSROOT="$TOOLCHAINROOT/sysroot"
export VCPKG_DIR=$VCPKG_ROOT/installed/arm64-android
CONFIG_FLAGS=""
CONFIG_LDFLAGS=""
if [ $BUILD_WITH_VCPKG = "yes" ]; then
CONFIG_LDFLAGS="-L$VCPKG_DIR/lib"
CONFIG_FLAGS="--with-libcurl=$VCPKG_DIR --with-ssl=$VCPKG_DIR --enable-vcpkg"
else
CONFIG_FLAGS="--with-ssl=$TCINCLUDES"
CONFIG_LDFLAGS="-L$TCSYSROOT/usr/lib -L$TCINCLUDES/lib"
fi
export PATH="$TCBINARIES:$TCINCLUDES/bin:$PATH" export PATH="$TCBINARIES:$TCINCLUDES/bin:$PATH"
export CC=aarch64-linux-android21-clang export CC=aarch64-linux-android21-clang
@ -31,7 +43,7 @@ export CXX=aarch64-linux-android21-clang++
export LD=aarch64-linux-android-ld export LD=aarch64-linux-android-ld
export CFLAGS="--sysroot=$TCSYSROOT -DANDROID -DANDROID_64 -DDECLARE_TIMEZONE -Wall -I$TCINCLUDES/include -O3 -fomit-frame-pointer -fPIE -D__ANDROID_API__=21" export CFLAGS="--sysroot=$TCSYSROOT -DANDROID -DANDROID_64 -DDECLARE_TIMEZONE -Wall -I$TCINCLUDES/include -O3 -fomit-frame-pointer -fPIE -D__ANDROID_API__=21"
export CXXFLAGS="--sysroot=$TCSYSROOT -DANDROID -DANDROID_64 -Wall -I$TCINCLUDES/include -funroll-loops -fexceptions -O3 -fomit-frame-pointer -fPIE -D__ANDROID_API__=21" export CXXFLAGS="--sysroot=$TCSYSROOT -DANDROID -DANDROID_64 -Wall -I$TCINCLUDES/include -funroll-loops -fexceptions -O3 -fomit-frame-pointer -fPIE -D__ANDROID_API__=21"
export LDFLAGS="-L$TCSYSROOT/usr/lib -L$TCINCLUDES/lib -llog -fPIE -pie -latomic -static-libstdc++" export LDFLAGS="$CONFIG_LDFLAGS -llog -fPIE -pie -latomic -static-libstdc++"
export GDB_CFLAGS="--sysroot=$TCSYSROOT -Wall -g -I$TCINCLUDES/include" export GDB_CFLAGS="--sysroot=$TCSYSROOT -Wall -g -I$TCINCLUDES/include"
export PKG_CONFIG_SYSROOT_DIR="$TCSYSROOT" export PKG_CONFIG_SYSROOT_DIR="$TCSYSROOT"
@ -62,7 +74,7 @@ if [ -n "$COMPILEBOINC" ]; then
fi fi
if [ -n "$CONFIGURE" ]; then if [ -n "$CONFIGURE" ]; then
./_autosetup ./_autosetup
./configure --host=aarch64-linux --with-boinc-platform="aarch64-android-linux-gnu" --with-boinc-alt-platform="arm-android-linux-gnu" --prefix="$TCINCLUDES" --libdir="$TCINCLUDES/lib" --with-ssl="$TCINCLUDES" --disable-server --disable-manager --disable-client --disable-shared --enable-static --enable-boinczip ./configure --host=aarch64-linux --with-boinc-platform="aarch64-android-linux-gnu" --with-boinc-alt-platform="arm-android-linux-gnu" --prefix="$TCINCLUDES" --libdir="$TCINCLUDES/lib" $CONFIG_FLAGS --disable-server --disable-manager --disable-client --disable-shared --enable-static --enable-boinczip
fi fi
echo MAKE_FLAGS=$MAKE_FLAGS echo MAKE_FLAGS=$MAKE_FLAGS
make $MAKE_FLAGS make $MAKE_FLAGS

View File

@ -7,7 +7,7 @@ set -e
# Script to compile various BOINC libraries for Android to be used # Script to compile various BOINC libraries for Android to be used
# by science applications # by science applications
BUILD_WITH_VCPKG="no"
STDOUT_TARGET="${STDOUT_TARGET:-/dev/stdout}" STDOUT_TARGET="${STDOUT_TARGET:-/dev/stdout}"
COMPILEBOINC="yes" COMPILEBOINC="yes"
CONFIGURE="yes" CONFIGURE="yes"
@ -22,6 +22,18 @@ export ANDROIDTC="${ANDROID_TC_ARMV6:-$ANDROID_TC/armv6}"
export TCBINARIES="$ANDROIDTC/bin" export TCBINARIES="$ANDROIDTC/bin"
export TCINCLUDES="$ANDROIDTC/arm-linux-androideabi" export TCINCLUDES="$ANDROIDTC/arm-linux-androideabi"
export TCSYSROOT="$ANDROIDTC/sysroot" export TCSYSROOT="$ANDROIDTC/sysroot"
export VCPKG_DIR=$VCPKG_ROOT/installed/armv6-android
CONFIG_FLAGS=""
CONFIG_LDFLAGS=""
if [ $BUILD_WITH_VCPKG = "yes" ]; then
CONFIG_LDFLAGS="-L$VCPKG_DIR/lib"
CONFIG_FLAGS="--with-libcurl=$VCPKG_DIR --with-ssl=$VCPKG_DIR --enable-vcpkg"
else
CONFIG_FLAGS="--with-ssl=$TCINCLUDES"
CONFIG_LDFLAGS="-L$TCSYSROOT/usr/lib -L$TCINCLUDES/lib"
fi
export PATH="$TCBINARIES:$TCINCLUDES/bin:$PATH" export PATH="$TCBINARIES:$TCINCLUDES/bin:$PATH"
export CC=arm-linux-androideabi-clang export CC=arm-linux-androideabi-clang
@ -29,7 +41,7 @@ export CXX=arm-linux-androideabi-clang++
export LD=arm-linux-androideabi-ld export LD=arm-linux-androideabi-ld
export CFLAGS="--sysroot=$TCSYSROOT -DANDROID -DDECLARE_TIMEZONE -Wall -I$TCINCLUDES/include -O3 -fomit-frame-pointer -fPIE -march=armv6 -mfloat-abi=softfp -mfpu=vfp -D__ANDROID_API__=16 -DARMV6" export CFLAGS="--sysroot=$TCSYSROOT -DANDROID -DDECLARE_TIMEZONE -Wall -I$TCINCLUDES/include -O3 -fomit-frame-pointer -fPIE -march=armv6 -mfloat-abi=softfp -mfpu=vfp -D__ANDROID_API__=16 -DARMV6"
export CXXFLAGS="--sysroot=$TCSYSROOT -DANDROID -Wall -I$TCINCLUDES/include -funroll-loops -fexceptions -O3 -fomit-frame-pointer -fPIE -march=armv6 -mfloat-abi=softfp -mfpu=vfp -D__ANDROID_API__=16 -DARMV6" export CXXFLAGS="--sysroot=$TCSYSROOT -DANDROID -Wall -I$TCINCLUDES/include -funroll-loops -fexceptions -O3 -fomit-frame-pointer -fPIE -march=armv6 -mfloat-abi=softfp -mfpu=vfp -D__ANDROID_API__=16 -DARMV6"
export LDFLAGS="-L$TCSYSROOT/usr/lib -L$TCINCLUDES/lib -llog -fPIE -pie -latomic -static-libstdc++ -march=armv6" export LDFLAGS="$CONFIG_LDFLAGS -llog -fPIE -pie -latomic -static-libstdc++ -march=armv6"
export GDB_CFLAGS="--sysroot=$TCSYSROOT -Wall -g -I$TCINCLUDES/include" export GDB_CFLAGS="--sysroot=$TCSYSROOT -Wall -g -I$TCINCLUDES/include"
export PKG_CONFIG_SYSROOT_DIR="$TCSYSROOT" export PKG_CONFIG_SYSROOT_DIR="$TCSYSROOT"
@ -63,7 +75,7 @@ if [ -n "$COMPILEBOINC" ]; then
fi fi
if [ -n "$CONFIGURE" ]; then if [ -n "$CONFIGURE" ]; then
./_autosetup ./_autosetup
./configure --host=arm-linux --with-boinc-platform="arm-android-linux-gnu" --prefix="$TCINCLUDES" --libdir="$TCINCLUDES/lib" --with-ssl="$TCINCLUDES" --disable-server --disable-manager --disable-client --disable-shared --enable-static --disable-largefile --enable-boinczip ./configure --host=arm-linux --with-boinc-platform="arm-android-linux-gnu" --prefix="$TCINCLUDES" --libdir="$TCINCLUDES/lib" $CONFIG_FLAGS --disable-server --disable-manager --disable-client --disable-shared --enable-static --disable-largefile --enable-boinczip
sed -e "s%^CLIENTLIBS *= *.*$%CLIENTLIBS = -lm $STDCPPTC%g" client/Makefile > client/Makefile.out sed -e "s%^CLIENTLIBS *= *.*$%CLIENTLIBS = -lm $STDCPPTC%g" client/Makefile > client/Makefile.out
mv client/Makefile.out client/Makefile mv client/Makefile.out client/Makefile
fi fi

View File

@ -24,6 +24,18 @@ export TOOLCHAINROOT="$NDK_ROOT/toolchains/llvm/prebuilt/linux-x86_64/"
export TCBINARIES="$TOOLCHAINROOT/bin" export TCBINARIES="$TOOLCHAINROOT/bin"
export TCINCLUDES="$ANDROIDTC/i686-linux-android" export TCINCLUDES="$ANDROIDTC/i686-linux-android"
export TCSYSROOT="$TOOLCHAINROOT/sysroot" export TCSYSROOT="$TOOLCHAINROOT/sysroot"
export VCPKG_DIR=$VCPKG_ROOT/installed/x86-android
CONFIG_FLAGS=""
CONFIG_LDFLAGS=""
if [ $BUILD_WITH_VCPKG = "yes" ]; then
CONFIG_LDFLAGS="-L$VCPKG_DIR/lib"
CONFIG_FLAGS="--with-libcurl=$VCPKG_DIR --with-ssl=$VCPKG_DIR --enable-vcpkg"
else
CONFIG_FLAGS="--with-ssl=$TCINCLUDES"
CONFIG_LDFLAGS="-L$TCSYSROOT/usr/lib -L$TCINCLUDES/lib"
fi
export PATH="$TCBINARIES:$TCINCLUDES/bin:$PATH" export PATH="$TCBINARIES:$TCINCLUDES/bin:$PATH"
export CC=i686-linux-android16-clang export CC=i686-linux-android16-clang
@ -31,7 +43,7 @@ export CXX=i686-linux-android16-clang++
export LD=i686-linux-android-ld export LD=i686-linux-android-ld
export CFLAGS="--sysroot=$TCSYSROOT -DANDROID -DDECLARE_TIMEZONE -Wall -I$TCINCLUDES/include -O3 -fomit-frame-pointer -fPIE -D__ANDROID_API__=16" export CFLAGS="--sysroot=$TCSYSROOT -DANDROID -DDECLARE_TIMEZONE -Wall -I$TCINCLUDES/include -O3 -fomit-frame-pointer -fPIE -D__ANDROID_API__=16"
export CXXFLAGS="--sysroot=$TCSYSROOT -DANDROID -Wall -I$TCINCLUDES/include -funroll-loops -fexceptions -O3 -fomit-frame-pointer -fPIE -D__ANDROID_API__=16" export CXXFLAGS="--sysroot=$TCSYSROOT -DANDROID -Wall -I$TCINCLUDES/include -funroll-loops -fexceptions -O3 -fomit-frame-pointer -fPIE -D__ANDROID_API__=16"
export LDFLAGS="-L$TCSYSROOT/usr/lib -L$TCINCLUDES/lib -llog -fPIE -pie -latomic -static-libstdc++" export LDFLAGS="$CONFIG_LDFLAGS -llog -fPIE -pie -latomic -static-libstdc++"
export GDB_CFLAGS="--sysroot=$TCSYSROOT -Wall -g -I$TCINCLUDES/include" export GDB_CFLAGS="--sysroot=$TCSYSROOT -Wall -g -I$TCINCLUDES/include"
export PKG_CONFIG_SYSROOT_DIR="$TCSYSROOT" export PKG_CONFIG_SYSROOT_DIR="$TCSYSROOT"
@ -62,7 +74,7 @@ if [ -n "$COMPILEBOINC" ]; then
fi fi
if [ -n "$CONFIGURE" ]; then if [ -n "$CONFIGURE" ]; then
./_autosetup ./_autosetup
./configure --host=i686-linux --with-boinc-platform="x86-android-linux-gnu" --prefix="$TCINCLUDES" --libdir="$TCINCLUDES/lib" --with-ssl="$TCINCLUDES" --disable-server --disable-manager --disable-client --disable-shared --enable-static --disable-largefile --enable-boinczip ./configure --host=i686-linux --with-boinc-platform="x86-android-linux-gnu" --prefix="$TCINCLUDES" --libdir="$TCINCLUDES/lib" $CONFIG_FLAGS --disable-server --disable-manager --disable-client --disable-shared --enable-static --disable-largefile --enable-boinczip
fi fi
echo MAKE_FLAGS=$MAKE_FLAGS echo MAKE_FLAGS=$MAKE_FLAGS
make $MAKE_FLAGS make $MAKE_FLAGS

View File

@ -24,6 +24,18 @@ export TOOLCHAINROOT="$NDK_ROOT/toolchains/llvm/prebuilt/linux-x86_64/"
export TCBINARIES="$TOOLCHAINROOT/bin" export TCBINARIES="$TOOLCHAINROOT/bin"
export TCINCLUDES="$ANDROIDTC/x86_64-linux-android" export TCINCLUDES="$ANDROIDTC/x86_64-linux-android"
export TCSYSROOT="$TOOLCHAINROOT/sysroot" export TCSYSROOT="$TOOLCHAINROOT/sysroot"
export VCPKG_DIR=$VCPKG_ROOT/installed/x64-android
CONFIG_FLAGS=""
CONFIG_LDFLAGS=""
if [ $BUILD_WITH_VCPKG = "yes" ]; then
CONFIG_LDFLAGS="-L$VCPKG_DIR/lib"
CONFIG_FLAGS="--with-libcurl=$VCPKG_DIR --with-ssl=$VCPKG_DIR --enable-vcpkg"
else
CONFIG_FLAGS="--with-ssl=$TCINCLUDES"
CONFIG_LDFLAGS="-L$TCSYSROOT/usr/lib -L$TCINCLUDES/lib"
fi
export PATH="$TCBINARIES:$TCINCLUDES/bin:$PATH" export PATH="$TCBINARIES:$TCINCLUDES/bin:$PATH"
export CC=x86_64-linux-android21-clang export CC=x86_64-linux-android21-clang
@ -31,7 +43,7 @@ export CXX=x86_64-linux-android21-clang++
export LD=x86_64-linux-android-ld export LD=x86_64-linux-android-ld
export CFLAGS="--sysroot=$TCSYSROOT -DANDROID -DANDROID_64 -DDECLARE_TIMEZONE -Wall -I$TCINCLUDES/include -O3 -fomit-frame-pointer -fPIE -D__ANDROID_API__=21" export CFLAGS="--sysroot=$TCSYSROOT -DANDROID -DANDROID_64 -DDECLARE_TIMEZONE -Wall -I$TCINCLUDES/include -O3 -fomit-frame-pointer -fPIE -D__ANDROID_API__=21"
export CXXFLAGS="--sysroot=$TCSYSROOT -DANDROID -DANDROID_64 -Wall -I$TCINCLUDES/include -funroll-loops -fexceptions -O3 -fomit-frame-pointer -fPIE -D__ANDROID_API__=21" export CXXFLAGS="--sysroot=$TCSYSROOT -DANDROID -DANDROID_64 -Wall -I$TCINCLUDES/include -funroll-loops -fexceptions -O3 -fomit-frame-pointer -fPIE -D__ANDROID_API__=21"
export LDFLAGS="-L$TCSYSROOT/usr/lib64 -L$TCINCLUDES/lib64 -llog -fPIE -pie -latomic -static-libstdc++" export LDFLAGS="$CONFIG_LDFLAGS -llog -fPIE -pie -latomic -static-libstdc++"
export GDB_CFLAGS="--sysroot=$TCSYSROOT -Wall -g -I$TCINCLUDES/include" export GDB_CFLAGS="--sysroot=$TCSYSROOT -Wall -g -I$TCINCLUDES/include"
export PKG_CONFIG_SYSROOT_DIR="$TCSYSROOT" export PKG_CONFIG_SYSROOT_DIR="$TCSYSROOT"
@ -62,7 +74,7 @@ if [ -n "$COMPILEBOINC" ]; then
fi fi
if [ -n "$CONFIGURE" ]; then if [ -n "$CONFIGURE" ]; then
./_autosetup ./_autosetup
./configure --host=x86_64-linux --with-boinc-platform="x86_64-android-linux-gnu" --with-boinc-alt-platform="x86-android-linux-gnu" --prefix="$TCINCLUDES" --libdir="$TCINCLUDES/lib" --with-ssl="$TCINCLUDES" --disable-server --disable-manager --disable-client --disable-shared --enable-static --enable-boinczip ./configure --host=x86_64-linux --with-boinc-platform="x86_64-android-linux-gnu" --with-boinc-alt-platform="x86-android-linux-gnu" --prefix="$TCINCLUDES" --libdir="$TCINCLUDES/lib" $CONFIG_FLAGS --disable-server --disable-manager --disable-client --disable-shared --enable-static --enable-boinczip
fi fi
echo MAKE_FLAGS=$MAKE_FLAGS echo MAKE_FLAGS=$MAKE_FLAGS
make $MAKE_FLAGS make $MAKE_FLAGS

View File

@ -46,7 +46,7 @@ else
MAKE_FLAGS1="$MAKE_FLAGS -j $NPROC_USER" MAKE_FLAGS1="$MAKE_FLAGS -j $NPROC_USER"
fi fi
if [ ! -e "${OPENSSL_FLAGFILE}" ]; then if [ ! -e "${OPENSSL_FLAGFILE}" -a $BUILD_WITH_VCPKG = "no" ]; then
cd "$OPENSSL" cd "$OPENSSL"
echo "===== building openssl for arm from $PWD =====" echo "===== building openssl for arm from $PWD ====="
if [ -n "$MAKECLEAN" ]; then if [ -n "$MAKECLEAN" ]; then

View File

@ -46,7 +46,7 @@ else
MAKE_FLAGS1="$MAKE_FLAGS -j $NPROC_USER" MAKE_FLAGS1="$MAKE_FLAGS -j $NPROC_USER"
fi fi
if [ ! -e "${OPENSSL_FLAGFILE}" ]; then if [ ! -e "${OPENSSL_FLAGFILE}" -a $BUILD_WITH_VCPKG = "no" ]; then
cd "$OPENSSL" cd "$OPENSSL"
echo "===== building openssl for arm64 from $PWD =====" echo "===== building openssl for arm64 from $PWD ====="
if [ -n "$MAKECLEAN" ]; then if [ -n "$MAKECLEAN" ]; then

View File

@ -6,7 +6,7 @@ set -e
# #
# Script to compile OpenSSL for Android # Script to compile OpenSSL for Android
BUILD_WITH_VCPKG="no"
STDOUT_TARGET="${STDOUT_TARGET:-/dev/stdout}" STDOUT_TARGET="${STDOUT_TARGET:-/dev/stdout}"
CONFIGURE="yes" CONFIGURE="yes"
MAKECLEAN="yes" MAKECLEAN="yes"
@ -48,7 +48,7 @@ else
MAKE_FLAGS1="$MAKE_FLAGS -j $NPROC_USER" MAKE_FLAGS1="$MAKE_FLAGS -j $NPROC_USER"
fi fi
if [ ! -e "${OPENSSL_FLAGFILE}" ]; then if [ ! -e "${OPENSSL_FLAGFILE}" -a $BUILD_WITH_VCPKG = "no" ]; then
cd "$OPENSSL" cd "$OPENSSL"
echo "===== building openssl for armv6 from $PWD =====" echo "===== building openssl for armv6 from $PWD ====="
if [ -n "$MAKECLEAN" ]; then if [ -n "$MAKECLEAN" ]; then

View File

@ -46,7 +46,7 @@ else
MAKE_FLAGS1="$MAKE_FLAGS -j $NPROC_USER" MAKE_FLAGS1="$MAKE_FLAGS -j $NPROC_USER"
fi fi
if [ ! -e "${OPENSSL_FLAGFILE}" ]; then if [ ! -e "${OPENSSL_FLAGFILE}" -a $BUILD_WITH_VCPKG = "no" ]; then
cd "$OPENSSL" cd "$OPENSSL"
echo "===== building openssl for x86 from $PWD =====" echo "===== building openssl for x86 from $PWD ====="
if [ -n "$MAKECLEAN" ]; then if [ -n "$MAKECLEAN" ]; then

View File

@ -46,7 +46,7 @@ else
MAKE_FLAGS1="$MAKE_FLAGS -j $NPROC_USER" MAKE_FLAGS1="$MAKE_FLAGS -j $NPROC_USER"
fi fi
if [ ! -e "${OPENSSL_FLAGFILE}" ]; then if [ ! -e "${OPENSSL_FLAGFILE}" -a $BUILD_WITH_VCPKG = "no" ]; then
cd "$OPENSSL" cd "$OPENSSL"
echo "===== building openssl for x86-64 from $PWD =====" echo "===== building openssl for x86-64 from $PWD ====="
if [ -n "$MAKECLEAN" ]; then if [ -n "$MAKECLEAN" ]; then

View File

@ -14,6 +14,6 @@ if [ ! -d "android" ]; then
fi fi
echo '===== BOINC apps for all platforms build start =====' echo '===== BOINC apps for all platforms build start ====='
android/build_component.sh --ci --component apps --with-vcpkg android/build_component.sh --ci --component apps
echo '===== BOINC apps for all platforms build done =====' echo '===== BOINC apps for all platforms build done ====='

19
android/ci_build_vcpkg_apps.sh Executable file
View File

@ -0,0 +1,19 @@
#!/bin/sh
set -e
#
# See: https://boinc.berkeley.edu/trac/wiki/AndroidBuildClient
#
# Script to compile BOINC apps for Android
# check working directory because the script needs to be called like: ./android/ci_build_apps.sh
if [ ! -d "android" ]; then
echo "start this script in the source root directory"
exit 1
fi
echo '===== BOINC apps for all platforms build start ====='
android/build_component.sh --ci --component apps --with-vcpkg
echo '===== BOINC apps for all platforms build done ====='

View File

@ -0,0 +1,18 @@
#!/bin/sh
set -e
#
# See: https://boinc.berkeley.edu/trac/wiki/AndroidBuildClient
#
# Script to compile everything BOINC needs for Android
# check working directory because the script needs to be called like: ./android/ci_build_manager.sh
if [ ! -d "android" ]; then
echo "start this script in the source root directory"
exit 1
fi
echo '===== BOINC Client for all platforms build start ====='
android/build_component.sh --ci --component client --with-vcpkg
echo '===== BOINC Client for all platforms build done ====='

View File

@ -0,0 +1,18 @@
#!/bin/sh
set -e
#
# See: https://boinc.berkeley.edu/trac/wiki/AndroidBuildClient
#
# Script to compile BOINC libs for Android
# check working directory because the script needs to be called like: ./android/ci_build_libs.sh
if [ ! -d "android" ]; then
echo "start this script in the source root directory"
exit 1
fi
echo '===== BOINC libs for all platforms build start ====='
android/build_component.sh --ci --component libs --with-vcpkg
echo '===== BOINC libs for all platforms build done ====='

View File

@ -0,0 +1,26 @@
#!/bin/sh
set -e
#
# See: https://boinc.berkeley.edu/trac/wiki/AndroidBuildClient
#
# Script to compile everything BOINC needs for Android
# check working directory because the script needs to be called like: ./android/ci_build_manager.sh
if [ ! -d "android" ]; then
echo "start this script in the source root directory"
exit 1
fi
android/ci_build_vcpkg_client.sh
cd android/BOINC
echo '===== BOINC Manager build start ====='
./gradlew clean assemble jacocoTestReportDebug
echo '===== BOINC Manager build done ====='
cd ../../

View File

@ -210,6 +210,12 @@ case $TYPE in
android_apps) android_apps)
prepare_android_apps prepare_android_apps
;; ;;
android_manager-vcpkg)
prepare_android_manager
;;
android_apps-vcpkg)
prepare_android_apps
;;
*) *)
echo "unrecognized BOINC_TYPE $key" echo "unrecognized BOINC_TYPE $key"
exit 1 exit 1

View File

@ -73,36 +73,36 @@ AC_DEFUN([LIBCURL_CHECK_CONFIG],
AC_PATH_PROG([_libcurl_config],[curl-config]) AC_PATH_PROG([_libcurl_config],[curl-config])
if test x$_libcurl_config != "x" ; then if test x$_libcurl_config != "x" ; then
AC_CACHE_CHECK([for the version of libcurl], AC_CACHE_CHECK([for the version of libcurl],
[libcurl_cv_lib_curl_version], [libcurl_cv_lib_curl_version],
[libcurl_cv_lib_curl_version=`$_libcurl_config --version | $AWK '{print $[]2}'`]) [libcurl_cv_lib_curl_version=`$_libcurl_config --version | $AWK '{print $[]2}'`])
_libcurl_version=`echo $libcurl_cv_lib_curl_version | $_libcurl_version_parse` _libcurl_version=`echo $libcurl_cv_lib_curl_version | $_libcurl_version_parse`
_libcurl_wanted=`echo ifelse([$2],,[0],[$2]) | $_libcurl_version_parse` _libcurl_wanted=`echo ifelse([$2],,[0],[$2]) | $_libcurl_version_parse`
if test $_libcurl_wanted -gt 0 ; then if test $_libcurl_wanted -gt 0 ; then
AC_CACHE_CHECK([for libcurl >= version $2], AC_CACHE_CHECK([for libcurl >= version $2],
[libcurl_cv_lib_version_ok], [libcurl_cv_lib_version_ok],
[ [
if test $_libcurl_version -ge $_libcurl_wanted ; then if test $_libcurl_version -ge $_libcurl_wanted ; then
libcurl_cv_lib_version_ok=yes libcurl_cv_lib_version_ok=yes
else else
libcurl_cv_lib_version_ok=no libcurl_cv_lib_version_ok=no
fi fi
]) ])
fi fi
if test $_libcurl_wanted -eq 0 || test x$libcurl_cv_lib_version_ok = xyes ; then if test $_libcurl_wanted -eq 0 || test x$libcurl_cv_lib_version_ok = xyes ; then
if test x"$LIBCURL_CPPFLAGS" = "x" ; then if test x"$LIBCURL_CPPFLAGS" = "x" ; then
LIBCURL_CPPFLAGS=`$_libcurl_config --cflags` LIBCURL_CPPFLAGS=`$_libcurl_config --cflags`
fi fi
if test x"$LIBCURL" = "x" ; then if test x"$LIBCURL" = "x" ; then
if test "x${disable_static_linkage}" = "xno" ; then if test "x${disable_static_linkage}" = "xno" ; then
if $_libcurl_config --static-libs 2>&1 > /dev/null ; then if $_libcurl_config --static-libs 2>&1 > /dev/null ; then
LIBCURL="`$_libcurl_config --static-libs`" LIBCURL="`$_libcurl_config --static-libs`"
fi fi
fi fi
fi fi
if test x"$LIBCURL" = "x" ; then if test x"$LIBCURL" = "x" ; then
LIBCURL="`$_libcurl_config --libs`" LIBCURL="`$_libcurl_config --libs`"
@ -117,27 +117,30 @@ AC_DEFUN([LIBCURL_CHECK_CONFIG],
fi fi
# This is so silly, but Apple actually has a bug in their # This is so silly, but Apple actually has a bug in their
# curl-config script. Fixed in Tiger, but there are still # curl-config script. Fixed in Tiger, but there are still
# lots of Panther installs around. # lots of Panther installs around.
case "${host}" in case "${host}" in
powerpc-apple-darwin7*) powerpc-apple-darwin7*)
LIBCURL=`echo $LIBCURL | sed -e 's|-arch i386||g'` LIBCURL=`echo $LIBCURL | sed -e 's|-arch i386||g'`
;; ;;
armv6-*)
LIBCURL="-lcurl -lssl -lcrypto -lz -latomic"
;;
esac esac
fi fi
# All curl-config scripts support --feature # All curl-config scripts support --feature
_libcurl_features=`$_libcurl_config --feature` _libcurl_features=`$_libcurl_config --feature`
# Is it modern enough to have --protocols? (7.12.4) # Is it modern enough to have --protocols? (7.12.4)
if test $_libcurl_version -ge 461828 ; then if test $_libcurl_version -ge 461828 ; then
_libcurl_protocols=`$_libcurl_config --protocols` _libcurl_protocols=`$_libcurl_config --protocols`
fi fi
else else
_libcurl_try_link=no _libcurl_try_link=no
fi fi
unset _libcurl_wanted unset _libcurl_wanted
fi fi
# do we need the ldap libraries? # do we need the ldap libraries?
@ -152,7 +155,7 @@ AC_DEFUN([LIBCURL_CHECK_CONFIG],
# some curl configs have the ber and ldap libraries in the wrong order, # some curl configs have the ber and ldap libraries in the wrong order,
# so lets add -lber after -lldap. # so lets add -lber after -lldap.
if test "x`echo $LIBCURL | grep ldap`" != "x" -a \ if test "x`echo $LIBCURL | grep ldap`" != "x" -a \
"x`echo $LIBCURL | grep lber`" != "x" ; then "x`echo $LIBCURL | grep lber`" != "x" ; then
AC_CHECK_LIB([lber],[ber_scanf], AC_CHECK_LIB([lber],[ber_scanf],
LIBCURL="`echo $LIBCURL | sed -e 's/ldap /ldap -llber /'`" LIBCURL="`echo $LIBCURL | sed -e 's/ldap /ldap -llber /'`"
) )
@ -209,8 +212,8 @@ x=CURLOPT_VERBOSE;
if test $libcurl_cv_lib_curl_usable = yes ; then if test $libcurl_cv_lib_curl_usable = yes ; then
# Does curl_free() exist in this version of libcurl? # Does curl_free() exist in this version of libcurl?
# If not, fake it with free() # If not, fake it with free()
_libcurl_save_cppflags=$CPPFLAGS _libcurl_save_cppflags=$CPPFLAGS
CPPFLAGS="$CPPFLAGS $LIBCURL_CPPFLAGS" CPPFLAGS="$CPPFLAGS $LIBCURL_CPPFLAGS"
@ -218,8 +221,8 @@ x=CURLOPT_VERBOSE;
LIBS="$LIBS $LIBCURL" LIBS="$LIBS $LIBCURL"
AC_CHECK_FUNC(curl_free,, AC_CHECK_FUNC(curl_free,,
AC_DEFINE(curl_free,free, AC_DEFINE(curl_free,free,
[Define curl_free() as free() if our version of curl lacks curl_free.])) [Define curl_free() as free() if our version of curl lacks curl_free.]))
CPPFLAGS=$_libcurl_save_cppflags CPPFLAGS=$_libcurl_save_cppflags
LIBS=$_libcurl_save_libs LIBS=$_libcurl_save_libs
@ -232,36 +235,36 @@ x=CURLOPT_VERBOSE;
AC_SUBST(LIBCURL) AC_SUBST(LIBCURL)
for _libcurl_feature in $_libcurl_features ; do for _libcurl_feature in $_libcurl_features ; do
AC_DEFINE_UNQUOTED(AS_TR_CPP(libcurl_feature_$_libcurl_feature),[1]) AC_DEFINE_UNQUOTED(AS_TR_CPP(libcurl_feature_$_libcurl_feature),[1])
eval AS_TR_SH(libcurl_feature_$_libcurl_feature)=yes eval AS_TR_SH(libcurl_feature_$_libcurl_feature)=yes
done done
if test x$libcurl_feature_SSL = xyes ; then if test x$libcurl_feature_SSL = xyes ; then
LIBCURL_CABUNDLE=`$_libcurl_config --ca 2>/dev/null` LIBCURL_CABUNDLE=`$_libcurl_config --ca 2>/dev/null`
AC_DEFINE_UNQUOTED(LIBCURL_CABUNDLE,"${LIBCURL_CABUNDLE}",[Define to the name of libcurl's certification file]) AC_DEFINE_UNQUOTED(LIBCURL_CABUNDLE,"${LIBCURL_CABUNDLE}",[Define to the name of libcurl's certification file])
fi fi
if test "x$_libcurl_protocols" = "x" ; then if test "x$_libcurl_protocols" = "x" ; then
# We don't have --protocols, so just assume that all # We don't have --protocols, so just assume that all
# protocols are available # protocols are available
_libcurl_protocols="HTTP FTP GOPHER FILE TELNET LDAP DICT" _libcurl_protocols="HTTP FTP GOPHER FILE TELNET LDAP DICT"
if test x$libcurl_feature_SSL = xyes ; then if test x$libcurl_feature_SSL = xyes ; then
_libcurl_protocols="$_libcurl_protocols HTTPS" _libcurl_protocols="$_libcurl_protocols HTTPS"
# FTPS wasn't standards-compliant until version # FTPS wasn't standards-compliant until version
# 7.11.0 # 7.11.0
if test $_libcurl_version -ge 461568; then if test $_libcurl_version -ge 461568; then
_libcurl_protocols="$_libcurl_protocols FTPS" _libcurl_protocols="$_libcurl_protocols FTPS"
fi fi
fi fi
fi fi
for _libcurl_protocol in $_libcurl_protocols ; do for _libcurl_protocol in $_libcurl_protocols ; do
AC_DEFINE_UNQUOTED(AS_TR_CPP(libcurl_protocol_$_libcurl_protocol),[1]) AC_DEFINE_UNQUOTED(AS_TR_CPP(libcurl_protocol_$_libcurl_protocol),[1])
eval AS_TR_SH(libcurl_protocol_$_libcurl_protocol)=yes eval AS_TR_SH(libcurl_protocol_$_libcurl_protocol)=yes
done done
fi fi
fi fi

View File

@ -15,7 +15,7 @@ else
BOINC_LIB_DIR = $(TCINCLUDES)/lib BOINC_LIB_DIR = $(TCINCLUDES)/lib
BOINC_ZIP_DIR = $(TCINCLUDES)/lib BOINC_ZIP_DIR = $(TCINCLUDES)/lib
LINUX_LDFLAGS = LINUX_LDFLAGS = -lz
endif endif
PROGS = boinc_gahp PROGS = boinc_gahp
@ -31,5 +31,5 @@ distclean-recursive: clean
boinc_gahp: boinc_gahp.cpp $(BOINC_SOURCE_LIB_DIR)/remote_submit.h $(BOINC_SOURCE_LIB_DIR)/remote_submit.cpp $(BOINC_DIR)/svn_version.h $(BOINC_DIR)/version.h boinc_gahp: boinc_gahp.cpp $(BOINC_SOURCE_LIB_DIR)/remote_submit.h $(BOINC_SOURCE_LIB_DIR)/remote_submit.cpp $(BOINC_DIR)/svn_version.h $(BOINC_DIR)/version.h
$(CXX) $(CXXFLAGS) $(CPPFLAGS) $(LDFLAGS) -g -O2 -I$(BOINC_DIR) -I$(BOINC_SOURCE_LIB_DIR) \ $(CXX) $(CXXFLAGS) $(CPPFLAGS) $(LDFLAGS) -g -O2 -I$(BOINC_DIR) -I$(BOINC_SOURCE_LIB_DIR) \
-o boinc_gahp boinc_gahp.cpp $(BOINC_SOURCE_LIB_DIR)/remote_submit.cpp \ -I$(VCPKG_DIR)/include -o boinc_gahp boinc_gahp.cpp $(BOINC_SOURCE_LIB_DIR)/remote_submit.cpp \
-L$(BOINC_LIB_DIR) -lcurl -lssl -lcrypto -lboinc $(LINUX_LDFLAGS) $(STDCPPTC) -L$(BOINC_LIB_DIR) -L$(VCPKG_DIR)/lib -lcurl -lssl -lcrypto -lboinc $(LINUX_LDFLAGS) $(STDCPPTC)