From 36333b9fb7234f2061062c718a0c23a351599f67 Mon Sep 17 00:00:00 2001 From: Steve Myers Date: Sun, 20 Jun 2021 18:48:48 -0700 Subject: [PATCH] Rename gradle modules to jvm and android --- build.sh | 76 ++++++++++++++++++++++++------------------------ local.properties | 8 +++++ test.sh | 2 +- 3 files changed, 47 insertions(+), 39 deletions(-) create mode 100644 local.properties diff --git a/build.sh b/build.sh index b8b5c01..831687a 100755 --- a/build.sh +++ b/build.sh @@ -10,43 +10,43 @@ export LD_LIBRARY_PATH=`pwd`/target/debug cc cc/bdk_ffi_test.c -o cc/bdk_ffi_test -L target/debug -l bdk_ffi -l pthread -l dl -l m # bdk-kotlin jar -mkdir -p bdk-kotlin/jar/libs/x86_64_linux -cp target/debug/libbdk_ffi.so bdk-kotlin/jar/libs/x86_64_linux +mkdir -p bdk-kotlin/jvm/libs/x86_64_linux +cp target/debug/libbdk_ffi.so bdk-kotlin/jvm/libs/x86_64_linux -(cd bdk-kotlin && gradle :jar:build) +(cd bdk-kotlin && gradle :jvm:build) -## rust android -# -## If ANDROID_NDK_HOME is not set then set it to github actions default -#[ -z "$ANDROID_NDK_HOME" ] && export ANDROID_NDK_HOME=$ANDROID_HOME/ndk-bundle -# -## Update this line accordingly if you are not building *from* darwin-x86_64 or linux-x86_64 -#export PATH=$PATH:$ANDROID_NDK_HOME/toolchains/llvm/prebuilt/`uname | tr '[:upper:]' '[:lower:]'`-x86_64/bin -# -## Required for 'ring' dependency to cross-compile to Android platform, must be at least 21 -#export CFLAGS="-D__ANDROID_API__=21" -# -## IMPORTANT: make sure every target is not a substring of a different one. We check for them with grep later on -#BUILD_TARGETS="${BUILD_TARGETS:-aarch64,armv7,x86_64,i686}" -# -#mkdir -p bdk-kotlin/aar/src/main/jniLibs/ bdk-kotlin/aar/src/main/jniLibs/arm64-v8a bdk-kotlin/aar/src/main/jniLibs/x86_64 bdk-kotlin/aar/src/main/jniLibs/armeabi-v7a bdk-kotlin/aar/src/main/jniLibs/x86 -# -#if echo $BUILD_TARGETS | grep "aarch64"; then -# CARGO_TARGET_AARCH64_LINUX_ANDROID_LINKER="aarch64-linux-android21-clang" CC="aarch64-linux-android21-clang" cargo build --target=aarch64-linux-android -# cp target/aarch64-linux-android/debug/libbdk_ffi.so bdk-kotlin/aar/src/main/jniLibs/arm64-v8a -#fi -#if echo $BUILD_TARGETS | grep "x86_64"; then -# CARGO_TARGET_X86_64_LINUX_ANDROID_LINKER="x86_64-linux-android21-clang" CC="x86_64-linux-android21-clang" cargo build --target=x86_64-linux-android -# cp target/x86_64-linux-android/debug/libbdk_ffi.so bdk-kotlin/aar/src/main/jniLibs/x86_64 -#fi -#if echo $BUILD_TARGETS | grep "armv7"; then -# CARGO_TARGET_ARMV7_LINUX_ANDROIDEABI_LINKER="armv7a-linux-androideabi21-clang" CC="armv7a-linux-androideabi21-clang" cargo build --target=armv7-linux-androideabi -# cp target/armv7-linux-androideabi/debug/libbdk_ffi.so bdk-kotlin/aar/src/main/jniLibs/armeabi-v7a -#fi -#if echo $BUILD_TARGETS | grep "i686"; then -# CARGO_TARGET_I686_LINUX_ANDROID_LINKER="i686-linux-android21-clang" CC="i686-linux-android21-clang" cargo build --target=i686-linux-android -# cp target/i686-linux-android/debug/libbdk_ffi.so bdk-kotlin/aar/src/main/jniLibs/x86 -#fi -# -## bdk-kotlin aar -#(cd bdk-kotlin && gradle :aar:build) +# rust android + +# If ANDROID_NDK_HOME is not set then set it to github actions default +[ -z "$ANDROID_NDK_HOME" ] && export ANDROID_NDK_HOME=$ANDROID_HOME/ndk-bundle + +# Update this line accordingly if you are not building *from* darwin-x86_64 or linux-x86_64 +export PATH=$PATH:$ANDROID_NDK_HOME/toolchains/llvm/prebuilt/`uname | tr '[:upper:]' '[:lower:]'`-x86_64/bin + +# Required for 'ring' dependency to cross-compile to Android platform, must be at least 21 +export CFLAGS="-D__ANDROID_API__=21" + +# IMPORTANT: make sure every target is not a substring of a different one. We check for them with grep later on +BUILD_TARGETS="${BUILD_TARGETS:-aarch64,armv7,x86_64,i686}" + +mkdir -p bdk-kotlin/android/src/main/jniLibs/ bdk-kotlin/android/src/main/jniLibs/arm64-v8a bdk-kotlin/android/src/main/jniLibs/x86_64 bdk-kotlin/android/src/main/jniLibs/armeabi-v7a bdk-kotlin/android/src/main/jniLibs/x86 + +if echo $BUILD_TARGETS | grep "aarch64"; then + CARGO_TARGET_AARCH64_LINUX_ANDROID_LINKER="aarch64-linux-android21-clang" CC="aarch64-linux-android21-clang" cargo build --target=aarch64-linux-android + cp target/aarch64-linux-android/debug/libbdk_ffi.so bdk-kotlin/android/src/main/jniLibs/arm64-v8a +fi +if echo $BUILD_TARGETS | grep "x86_64"; then + CARGO_TARGET_X86_64_LINUX_ANDROID_LINKER="x86_64-linux-android21-clang" CC="x86_64-linux-android21-clang" cargo build --target=x86_64-linux-android + cp target/x86_64-linux-android/debug/libbdk_ffi.so bdk-kotlin/android/src/main/jniLibs/x86_64 +fi +if echo $BUILD_TARGETS | grep "armv7"; then + CARGO_TARGET_ARMV7_LINUX_ANDROIDEABI_LINKER="armv7a-linux-androideabi21-clang" CC="armv7a-linux-androideabi21-clang" cargo build --target=armv7-linux-androideabi + cp target/armv7-linux-androideabi/debug/libbdk_ffi.so bdk-kotlin/android/src/main/jniLibs/armeabi-v7a +fi +if echo $BUILD_TARGETS | grep "i686"; then + CARGO_TARGET_I686_LINUX_ANDROID_LINKER="i686-linux-android21-clang" CC="i686-linux-android21-clang" cargo build --target=i686-linux-android + cp target/i686-linux-android/debug/libbdk_ffi.so bdk-kotlin/android/src/main/jniLibs/x86 +fi + +# bdk-kotlin aar +(cd bdk-kotlin && gradle :android:build) diff --git a/local.properties b/local.properties new file mode 100644 index 0000000..52889ad --- /dev/null +++ b/local.properties @@ -0,0 +1,8 @@ +## This file must *NOT* be checked into Version Control Systems, +# as it contains information specific to your local configuration. +# +# Location of the SDK. This is only used by Gradle. +# For customization when using a Version Control System, please read the +# header note. +#Sun Jun 20 18:41:16 PDT 2021 +sdk.dir=/home/steve/Android/Sdk diff --git a/test.sh b/test.sh index 145cdca..e44aad0 100755 --- a/test.sh +++ b/test.sh @@ -11,4 +11,4 @@ cc/bdk_ffi_test # bdk-kotlin (cd bdk-kotlin && gradle test) -#(cd bdk-kotlin && gradle :aar:connectedDebugAndroidTest) +#(cd bdk-kotlin && gradle :android:connectedDebugAndroidTest)