ffmpeg-kit/android.sh

287 lines
8.4 KiB
Bash
Raw Normal View History

2020-08-05 03:26:42 +03:00
#!/bin/bash
if [[ -z ${ANDROID_SDK_ROOT} ]]; then
2020-08-05 03:53:02 +03:00
echo -e "\n(*) ANDROID_SDK_ROOT not defined\n"
2020-08-05 03:26:42 +03:00
exit 1
fi
if [[ -z ${ANDROID_NDK_ROOT} ]]; then
2020-08-05 03:53:02 +03:00
echo -e "\n(*) ANDROID_NDK_ROOT not defined\n"
2020-08-05 03:26:42 +03:00
exit 1
fi
2020-08-05 03:53:02 +03:00
# LOAD INITIAL SETTINGS
export BASEDIR="$(pwd)"
export FFMPEG_KIT_BUILD_TYPE="android"
source "${BASEDIR}"/scripts/variable.sh
source "${BASEDIR}"/scripts/function-${FFMPEG_KIT_BUILD_TYPE}.sh
2020-08-05 03:26:42 +03:00
2020-08-05 03:53:02 +03:00
# SET DEFAULTS SETTINGS
enable_default_android_architectures
enable_default_android_libraries
enable_main_build
# DETECT ANDROID NDK VERSION
DETECTED_NDK_VERSION=$(grep -Eo "Revision.*" "${ANDROID_NDK_ROOT}"/source.properties | sed 's/Revision//g;s/=//g;s/ //g')
2020-08-05 03:26:42 +03:00
echo -e "\nINFO: Using Android NDK v${DETECTED_NDK_VERSION} provided at ${ANDROID_NDK_ROOT}\n" 1>>"${BASEDIR}"/build.log 2>&1
echo -e "INFO: Build options: $*\n" 1>>"${BASEDIR}"/build.log 2>&1
2020-08-05 03:53:02 +03:00
# SET DEFAULT BUILD OPTIONS
2020-08-05 03:26:42 +03:00
GPL_ENABLED="no"
DISPLAY_HELP=""
BUILD_FULL=""
BUILD_TYPE_ID=""
2020-08-05 03:53:02 +03:00
BUILD_VERSION=$(git describe --tags --always 2>>"${BASEDIR}"/build.log)
2020-08-05 03:26:42 +03:00
2020-08-05 03:53:02 +03:00
# PROCESS LTS BUILD OPTION FIRST AND SET BUILD TYPE: MAIN OR LTS
rm -f "${BASEDIR}"/android/app/build.gradle 1>>"${BASEDIR}"/build.log 2>&1
cp "${BASEDIR}"/tools/release/android/build.gradle "${BASEDIR}"/android/app/build.gradle 1>>"${BASEDIR}"/build.log 2>&1
for argument in "$@"; do
if [[ "$argument" == "-l" ]] || [[ "$argument" == "--lts" ]]; then
enable_lts_build
BUILD_TYPE_ID+="LTS "
rm -f "${BASEDIR}"/android/app/build.gradle 1>>"${BASEDIR}"/build.log 2>&1
cp "${BASEDIR}"/tools/release/android/build.lts.gradle "${BASEDIR}"/android/app/build.gradle 1>>"${BASEDIR}"/build.log 2>&1
fi
done
# PROCESS BUILD OPTIONS
2020-08-05 03:26:42 +03:00
while [ ! $# -eq 0 ]; do
case $1 in
-h | --help)
DISPLAY_HELP="1"
;;
-v | --version)
display_version
exit 0
;;
--skip-*)
SKIP_LIBRARY=$(echo $1 | sed -e 's/^--[A-Za-z]*-//g')
skip_library "${SKIP_LIBRARY}"
;;
--no-output-redirection)
no_output_redirection
;;
--no-workspace-cleanup-*)
NO_WORKSPACE_CLEANUP_LIBRARY=$(echo $1 | sed -e 's/^--[A-Za-z]*-[A-Za-z]*-[A-Za-z]*-//g')
no_workspace_cleanup_library "${NO_WORKSPACE_CLEANUP_LIBRARY}"
;;
--no-link-time-optimization)
no_link_time_optimization
;;
-d | --debug)
enable_debug
;;
-s | --speed)
optimize_for_speed
;;
2020-08-05 03:53:02 +03:00
-l | --lts) ;;
2020-08-05 03:26:42 +03:00
-f | --force)
2020-08-05 03:53:02 +03:00
export BUILD_FORCE="1"
2020-08-05 03:26:42 +03:00
;;
--reconf-*)
CONF_LIBRARY=$(echo $1 | sed -e 's/^--[A-Za-z]*-//g')
reconf_library "${CONF_LIBRARY}"
;;
--rebuild-*)
BUILD_LIBRARY=$(echo $1 | sed -e 's/^--[A-Za-z]*-//g')
rebuild_library "${BUILD_LIBRARY}"
;;
--redownload-*)
DOWNLOAD_LIBRARY=$(echo $1 | sed -e 's/^--[A-Za-z]*-//g')
redownload_library "${DOWNLOAD_LIBRARY}"
;;
--full)
BUILD_FULL="1"
;;
--enable-gpl)
GPL_ENABLED="yes"
;;
--enable-*)
ENABLED_LIBRARY=$(echo $1 | sed -e 's/^--[A-Za-z]*-//g')
enable_library "${ENABLED_LIBRARY}"
;;
--disable-*)
DISABLED_ARCH=$(echo $1 | sed -e 's/^--[A-Za-z]*-//g')
disable_arch "${DISABLED_ARCH}"
;;
--api-level=*)
API_LEVEL=$(echo $1 | sed -e 's/^--[A-Za-z]*-[A-Za-z]*=//g')
export API=${API_LEVEL}
;;
*)
print_unknown_option "$1"
;;
esac
shift
done
if [[ -z ${BUILD_VERSION} ]]; then
echo -e "\n(*) error: Can not run git commands in this folder. See build.log.\n"
exit 1
fi
2020-08-05 03:53:02 +03:00
# PROCESS FULL OPTION AS LAST OPTION
2020-08-05 03:26:42 +03:00
if [[ -n ${BUILD_FULL} ]]; then
2020-08-05 03:53:02 +03:00
for library in {0..57}; do
2020-08-05 03:26:42 +03:00
if [ ${GPL_ENABLED} == "yes" ]; then
2020-08-05 03:53:02 +03:00
enable_library "$(get_library_name $library)" 1
2020-08-05 03:26:42 +03:00
else
2020-08-05 03:53:02 +03:00
if [[ $(is_gpl_licensed $library) -eq 1 ]]; then
enable_library "$(get_library_name $library)" 1
2020-08-05 03:26:42 +03:00
fi
fi
done
fi
2020-08-05 03:53:02 +03:00
# IF HELP DISPLAYED EXIT
if [[ -n ${DISPLAY_HELP} ]]; then
display_help
exit 0
fi
2020-08-05 03:26:42 +03:00
echo -e "\nBuilding ffmpeg-kit ${BUILD_TYPE_ID}library for Android\n"
echo -e -n "INFO: Building ffmpeg-kit ${BUILD_VERSION} ${BUILD_TYPE_ID}library for Android: " 1>>"${BASEDIR}"/build.log 2>&1
2020-08-05 03:53:02 +03:00
echo -e "$(date)\n" 1>>"${BASEDIR}"/build.log 2>&1
2020-08-05 03:26:42 +03:00
# PRINT BUILD SUMMARY
print_enabled_architectures
print_enabled_libraries
print_reconfigure_requested_libraries
print_rebuild_requested_libraries
print_redownload_requested_libraries
2020-08-05 03:53:02 +03:00
# VALIDATE GPL FLAGS
2020-08-05 03:26:42 +03:00
for gpl_library in {$LIBRARY_X264,$LIBRARY_XVIDCORE,$LIBRARY_X265,$LIBRARY_LIBVIDSTAB,$LIBRARY_RUBBERBAND}; do
if [[ ${ENABLED_LIBRARIES[$gpl_library]} -eq 1 ]]; then
library_name=$(get_library_name ${gpl_library})
if [ ${GPL_ENABLED} != "yes" ]; then
echo -e "\n(*) Invalid configuration detected. GPL library ${library_name} enabled without --enable-gpl flag.\n"
echo -e "\n(*) Invalid configuration detected. GPL library ${library_name} enabled without --enable-gpl flag.\n" 1>>"${BASEDIR}"/build.log 2>&1
exit 1
fi
fi
done
2020-08-05 03:53:02 +03:00
echo -n -e "\nDownloading sources: "
echo -e "INFO: Downloading source code of ffmpeg and enabled external libraries.\n" 1>>"${BASEDIR}"/build.log 2>&1
# DOWNLOAD LIBRARY SOURCES
downloaded_enabled_library_sources "${ENABLED_LIBRARIES[@]}"
# SAVE ORIGINAL API LEVEL = NECESSARY TO BUILD 64bit ARCHITECTURES
2020-08-05 03:26:42 +03:00
export ORIGINAL_API=${API}
2020-08-05 03:53:02 +03:00
# BUILD ENABLED LIBRARIES ON ENABLED ARCHITECTURES
2020-08-05 03:26:42 +03:00
for run_arch in {0..10}; do
if [[ ${ENABLED_ARCHITECTURES[$run_arch]} -eq 1 ]]; then
if [[ (${run_arch} -eq ${ARCH_ARM64_V8A} || ${run_arch} -eq ${ARCH_X86_64}) && ${API} -lt 21 ]]; then
# 64 bit ABIs supported after API 21
export API=21
else
export API=${ORIGINAL_API}
fi
export ARCH=$(get_arch_name $run_arch)
export TOOLCHAIN=$(get_toolchain)
export TOOLCHAIN_ARCH=$(get_toolchain_arch)
2020-08-05 03:53:02 +03:00
# EXECUTE MAIN BUILD SCRIPT
2020-08-05 03:26:42 +03:00
. "${BASEDIR}"/scripts/main-android.sh "${ENABLED_LIBRARIES[@]}" || exit 1
# CLEAR FLAGS
2020-08-05 03:53:02 +03:00
for library in {0..57}; do
2020-08-05 03:26:42 +03:00
library_name=$(get_library_name ${library})
unset "$(echo "OK_${library_name}" | sed "s/\-/\_/g")"
unset "$(echo "DEPENDENCY_REBUILT_${library_name}" | sed "s/\-/\_/g")"
done
fi
done
2020-08-05 03:53:02 +03:00
# GET BACK THE ORIGINAL API LEVEL
2020-08-05 03:26:42 +03:00
export API=${ORIGINAL_API}
2020-08-05 03:53:02 +03:00
# SET ARCHITECTURES TO BUILD
2020-08-05 03:26:42 +03:00
rm -f "${BASEDIR}"/android/build/.armv7 1>>"${BASEDIR}"/build.log 2>&1
rm -f "${BASEDIR}"/android/build/.armv7neon 1>>"${BASEDIR}"/build.log 2>&1
ANDROID_ARCHITECTURES=""
2020-08-05 03:53:02 +03:00
if [[ ${ENABLED_ARCHITECTURES[ARCH_ARM_V7A]} -eq 1 ]] || [[ ${ENABLED_ARCHITECTURES[ARCH_ARM_V7A_NEON]} -eq 1 ]]; then
2020-08-05 03:26:42 +03:00
ANDROID_ARCHITECTURES+="$(get_android_arch 0) "
fi
2020-08-05 03:53:02 +03:00
if [[ ${ENABLED_ARCHITECTURES[ARCH_ARM_V7A]} -eq 1 ]]; then
2020-08-05 03:26:42 +03:00
mkdir -p "${BASEDIR}"/android/build 1>>"${BASEDIR}"/build.log 2>&1
cat >"${BASEDIR}"/android/build/.armv7 <<EOF
EOF
fi
2020-08-05 03:53:02 +03:00
if [[ ${ENABLED_ARCHITECTURES[ARCH_ARM_V7A_NEON]} -eq 1 ]]; then
2020-08-05 03:26:42 +03:00
mkdir -p "${BASEDIR}"/android/build 1>>"${BASEDIR}"/build.log 2>&1
cat >"${BASEDIR}"/android/build/.armv7neon <<EOF
EOF
fi
2020-08-05 03:53:02 +03:00
if [[ ${ENABLED_ARCHITECTURES[ARCH_ARM64_V8A]} -eq 1 ]]; then
2020-08-05 03:26:42 +03:00
ANDROID_ARCHITECTURES+="$(get_android_arch 2) "
fi
2020-08-05 03:53:02 +03:00
if [[ ${ENABLED_ARCHITECTURES[ARCH_X86]} -eq 1 ]]; then
2020-08-05 03:26:42 +03:00
ANDROID_ARCHITECTURES+="$(get_android_arch 3) "
fi
2020-08-05 03:53:02 +03:00
if [[ ${ENABLED_ARCHITECTURES[ARCH_X86_64]} -eq 1 ]]; then
2020-08-05 03:26:42 +03:00
ANDROID_ARCHITECTURES+="$(get_android_arch 4) "
fi
2020-08-05 03:53:02 +03:00
# BUILD FFMPEG-KIT
2020-08-05 03:26:42 +03:00
if [[ -n ${ANDROID_ARCHITECTURES} ]]; then
echo -n -e "\nffmpeg-kit: "
2020-08-05 03:53:02 +03:00
# CREATE Application.mk FILE BEFORE STARTING THE NATIVE BUILD
2020-08-05 03:26:42 +03:00
build_application_mk
2020-08-05 03:53:02 +03:00
# CLEAR OLD NATIVE LIBRARIES
2020-08-05 03:26:42 +03:00
rm -rf "${BASEDIR}"/android/libs 1>>"${BASEDIR}"/build.log 2>&1
2020-08-05 03:53:02 +03:00
rm -rf "${BASEDIR}"/android/obj 1>>"${BASEDIR}"/build.log 2>&1
2020-08-05 03:26:42 +03:00
cd "${BASEDIR}"/android 1>>"${BASEDIR}"/build.log 2>&1 || exit 1
2020-08-05 03:53:02 +03:00
# BUILD NATIVE LIBRARY
2020-08-05 03:26:42 +03:00
"${ANDROID_NDK_ROOT}"/ndk-build -B 1>>"${BASEDIR}"/build.log 2>&1
if [ $? -eq 0 ]; then
echo "ok"
else
echo "failed"
exit 1
fi
echo -e -n "\n\nCreating Android archive under prebuilt/android-aar: "
2020-08-05 03:53:02 +03:00
# BUILD ANDROID ARCHIVE
2020-08-05 03:26:42 +03:00
./gradlew app:clean app:assembleRelease app:testReleaseUnitTest 1>>"${BASEDIR}"/build.log 2>&1
if [ $? -ne 0 ]; then
echo -e "failed\n"
exit 1
fi
2020-08-05 03:53:02 +03:00
# COPY ANDROID ARCHIVE TO PREBUILT DIRECTORY
FFMPEG_KIT_AAR="${BASEDIR}"/prebuilt/android-aar/ffmpeg-kit
rm -rf "${FFMPEG_KIT_AAR}" 1>>"${BASEDIR}"/build.log 2>&1
mkdir -p "${FFMPEG_KIT_AAR}" 1>>"${BASEDIR}"/build.log 2>&1
2020-08-05 03:26:42 +03:00
cp "${BASEDIR}"/android/app/build/outputs/aar/ffmpeg-kit-release.aar "${FFMPEG_KIT_AAR}"/ffmpeg-kit.aar 1>>"${BASEDIR}"/build.log 2>&1
if [ $? -ne 0 ]; then
echo -e "failed\n"
exit 1
fi
echo -e "Created ffmpeg-kit Android archive successfully.\n" 1>>"${BASEDIR}"/build.log 2>&1
echo -e "ok\n"
fi