ffmpeg-kit/scripts/function.sh

1774 lines
45 KiB
Bash
Raw Normal View History

2020-08-05 03:26:42 +03:00
#!/bin/bash
2020-08-05 03:53:02 +03:00
source "${BASEDIR}"/scripts/source.sh
get_arch_name() {
case $1 in
0) echo "arm-v7a" ;; # android
1) echo "arm-v7a-neon" ;; # android
2) echo "armv7" ;; # ios
3) echo "armv7s" ;; # ios
4) echo "arm64-v8a" ;; # android
2020-11-23 00:51:45 +02:00
5) echo "arm64" ;; # ios, tvos, macos
2020-08-05 03:53:02 +03:00
6) echo "arm64e" ;; # ios
7) echo "i386" ;; # ios
8) echo "x86" ;; # android
9) echo "x86-64" ;; # android, ios, macos, tvos
10) echo "x86-64-mac-catalyst" ;; # ios
2020-11-23 00:51:45 +02:00
11) echo "arm64-mac-catalyst" ;; # ios
2021-02-27 14:33:12 +02:00
12) echo "arm64-simulator" ;; # ios, tvos
2020-11-23 00:51:45 +02:00
esac
}
get_full_arch_name() {
case $1 in
9) echo "x86_64" ;;
10) echo "x86_64-mac-catalyst" ;;
*) get_arch_name "$1" ;;
2020-08-05 03:53:02 +03:00
esac
}
from_arch_name() {
case $1 in
arm-v7a) echo 0 ;; # android
arm-v7a-neon) echo 1 ;; # android
armv7) echo 2 ;; # ios
armv7s) echo 3 ;; # ios
arm64-v8a) echo 4 ;; # android
2020-11-23 00:51:45 +02:00
arm64) echo 5 ;; # ios, tvos, macos
2020-08-05 03:53:02 +03:00
arm64e) echo 6 ;; # ios
i386) echo 7 ;; # ios
x86) echo 8 ;; # android
x86-64) echo 9 ;; # android, ios, macos, tvos
x86-64-mac-catalyst) echo 10 ;; # ios
2020-11-23 00:51:45 +02:00
arm64-mac-catalyst) echo 11 ;; # ios
arm64-simulator) echo 12 ;; # ios
2020-08-05 03:53:02 +03:00
esac
}
2020-08-05 03:26:42 +03:00
get_library_name() {
case $1 in
0) echo "fontconfig" ;;
1) echo "freetype" ;;
2) echo "fribidi" ;;
3) echo "gmp" ;;
4) echo "gnutls" ;;
5) echo "lame" ;;
6) echo "libass" ;;
7) echo "libiconv" ;;
8) echo "libtheora" ;;
9) echo "libvorbis" ;;
10) echo "libvpx" ;;
11) echo "libwebp" ;;
12) echo "libxml2" ;;
13) echo "opencore-amr" ;;
14) echo "shine" ;;
15) echo "speex" ;;
2021-01-30 01:35:05 +02:00
16) echo "dav1d" ;;
2020-08-05 03:26:42 +03:00
17) echo "kvazaar" ;;
18) echo "x264" ;;
19) echo "xvidcore" ;;
20) echo "x265" ;;
21) echo "libvidstab" ;;
22) echo "rubberband" ;;
23) echo "libilbc" ;;
24) echo "opus" ;;
25) echo "snappy" ;;
26) echo "soxr" ;;
27) echo "libaom" ;;
28) echo "chromaprint" ;;
29) echo "twolame" ;;
30) echo "sdl" ;;
31) echo "tesseract" ;;
32) echo "openh264" ;;
33) echo "vo-amrwbenc" ;;
34) echo "giflib" ;;
35) echo "jpeg" ;;
36) echo "libogg" ;;
37) echo "libpng" ;;
38) echo "libuuid" ;;
39) echo "nettle" ;;
40) echo "tiff" ;;
41) echo "expat" ;;
42) echo "libsndfile" ;;
43) echo "leptonica" ;;
44) echo "libsamplerate" ;;
2020-11-23 00:51:45 +02:00
45) echo "harfbuzz" ;;
46) echo "cpu-features" ;;
47) echo "android-zlib" ;;
48) echo "android-media-codec" ;;
49)
2020-08-05 03:53:02 +03:00
if [[ ${FFMPEG_KIT_BUILD_TYPE} == "ios" ]]; then
echo "ios-zlib"
elif [[ ${FFMPEG_KIT_BUILD_TYPE} == "macos" ]]; then
echo "macos-zlib"
elif [[ ${FFMPEG_KIT_BUILD_TYPE} == "tvos" ]]; then
echo "tvos-zlib"
fi
;;
2020-11-23 00:51:45 +02:00
50)
2020-08-05 03:53:02 +03:00
if [[ ${FFMPEG_KIT_BUILD_TYPE} == "ios" ]]; then
echo "ios-audiotoolbox"
elif [[ ${FFMPEG_KIT_BUILD_TYPE} == "macos" ]]; then
echo "macos-audiotoolbox"
elif [[ ${FFMPEG_KIT_BUILD_TYPE} == "tvos" ]]; then
echo "tvos-audiotoolbox"
fi
;;
2020-11-23 00:51:45 +02:00
51)
2020-08-05 03:53:02 +03:00
if [[ ${FFMPEG_KIT_BUILD_TYPE} == "ios" ]]; then
echo "ios-bzip2"
elif [[ ${FFMPEG_KIT_BUILD_TYPE} == "macos" ]]; then
echo "macos-bzip2"
elif [[ ${FFMPEG_KIT_BUILD_TYPE} == "tvos" ]]; then
echo "tvos-bzip2"
fi
;;
2020-11-23 00:51:45 +02:00
52)
2020-08-05 03:53:02 +03:00
if [[ ${FFMPEG_KIT_BUILD_TYPE} == "ios" ]]; then
echo "ios-videotoolbox"
elif [[ ${FFMPEG_KIT_BUILD_TYPE} == "macos" ]]; then
echo "macos-videotoolbox"
elif [[ ${FFMPEG_KIT_BUILD_TYPE} == "tvos" ]]; then
echo "tvos-videotoolbox"
fi
;;
2020-11-23 00:51:45 +02:00
53)
2020-08-05 03:53:02 +03:00
if [[ ${FFMPEG_KIT_BUILD_TYPE} == "ios" ]]; then
echo "ios-avfoundation"
elif [[ ${FFMPEG_KIT_BUILD_TYPE} == "macos" ]]; then
echo "macos-avfoundation"
fi
;;
2020-11-23 00:51:45 +02:00
54)
2020-08-05 03:53:02 +03:00
if [[ ${FFMPEG_KIT_BUILD_TYPE} == "ios" ]]; then
echo "ios-libiconv"
elif [[ ${FFMPEG_KIT_BUILD_TYPE} == "macos" ]]; then
echo "macos-libiconv"
elif [[ ${FFMPEG_KIT_BUILD_TYPE} == "tvos" ]]; then
echo "tvos-libiconv"
fi
;;
2020-11-23 00:51:45 +02:00
55)
2020-08-05 03:53:02 +03:00
if [[ ${FFMPEG_KIT_BUILD_TYPE} == "ios" ]]; then
echo "ios-libuuid"
elif [[ ${FFMPEG_KIT_BUILD_TYPE} == "macos" ]]; then
echo "macos-libuuid"
elif [[ ${FFMPEG_KIT_BUILD_TYPE} == "tvos" ]]; then
echo "tvos-libuuid"
fi
;;
2020-11-23 00:51:45 +02:00
56)
2020-08-05 03:53:02 +03:00
if [[ ${FFMPEG_KIT_BUILD_TYPE} == "macos" ]]; then
echo "macos-coreimage"
fi
;;
2020-11-23 00:51:45 +02:00
57)
2020-08-05 03:53:02 +03:00
if [[ ${FFMPEG_KIT_BUILD_TYPE} == "macos" ]]; then
echo "macos-opencl"
fi
;;
2020-11-23 00:51:45 +02:00
58)
2020-08-05 03:53:02 +03:00
if [[ ${FFMPEG_KIT_BUILD_TYPE} == "macos" ]]; then
echo "macos-opengl"
fi
;;
esac
}
from_library_name() {
case $1 in
fontconfig) echo 0 ;;
freetype) echo 1 ;;
fribidi) echo 2 ;;
gmp) echo 3 ;;
gnutls) echo 4 ;;
lame) echo 5 ;;
libass) echo 6 ;;
libiconv) echo 7 ;;
libtheora) echo 8 ;;
libvorbis) echo 9 ;;
libvpx) echo 10 ;;
libwebp) echo 11 ;;
libxml2) echo 12 ;;
opencore-amr) echo 13 ;;
shine) echo 14 ;;
speex) echo 15 ;;
2021-01-30 01:35:05 +02:00
dav1d) echo 16 ;;
2020-08-05 03:53:02 +03:00
kvazaar) echo 17 ;;
x264) echo 18 ;;
xvidcore) echo 19 ;;
x265) echo 20 ;;
libvidstab) echo 21 ;;
rubberband) echo 22 ;;
libilbc) echo 23 ;;
opus) echo 24 ;;
snappy) echo 25 ;;
soxr) echo 26 ;;
libaom) echo 27 ;;
chromaprint) echo 28 ;;
twolame) echo 29 ;;
sdl) echo 30 ;;
tesseract) echo 31 ;;
openh264) echo 32 ;;
vo-amrwbenc) echo 33 ;;
giflib) echo 34 ;;
jpeg) echo 35 ;;
libogg) echo 36 ;;
libpng) echo 37 ;;
libuuid) echo 38 ;;
nettle) echo 39 ;;
tiff) echo 40 ;;
expat) echo 41 ;;
libsndfile) echo 42 ;;
leptonica) echo 43 ;;
libsamplerate) echo 44 ;;
2020-11-23 00:51:45 +02:00
harfbuzz) echo 45 ;;
cpu-features) echo 46 ;;
android-zlib) echo 47 ;;
android-media-codec) echo 48 ;;
ios-zlib | macos-zlib | tvos-zlib) echo 49 ;;
ios-audiotoolbox | macos-audiotoolbox | tvos-audiotoolbox) echo 50 ;;
ios-bzip2 | macos-bzip2 | tvos-bzip2) echo 51 ;;
ios-videotoolbox | macos-videotoolbox | tvos-videotoolbox) echo 52 ;;
ios-avfoundation | macos-avfoundation) echo 53 ;;
ios-libiconv | macos-libiconv | tvos-libiconv) echo 54 ;;
ios-libuuid | macos-libuuid | tvos-libuuid) echo 55 ;;
macos-coreimage) echo 56 ;;
macos-opencl) echo 57 ;;
macos-opengl) echo 58 ;;
2020-08-05 03:26:42 +03:00
esac
}
#
2020-08-05 03:53:02 +03:00
# 1. <library name>
2020-08-05 03:26:42 +03:00
#
is_library_supported_on_platform() {
2020-08-05 03:53:02 +03:00
local library_index=$(from_library_name "$1")
case ${library_index} in
2021-01-30 01:35:05 +02:00
0 | 1 | 2 | 3 | 4 | 5 | 6 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20)
2020-08-05 03:53:02 +03:00
echo "0"
2020-08-05 03:26:42 +03:00
;;
21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 | 32 | 33 | 34 | 35 | 36 | 37 | 39 | 40)
2020-08-05 03:53:02 +03:00
echo "0"
2020-08-05 03:26:42 +03:00
;;
2020-11-23 00:51:45 +02:00
41 | 42 | 43 | 44 | 45)
2020-08-05 03:53:02 +03:00
echo "0"
2020-08-05 03:26:42 +03:00
;;
# ANDROID
2020-11-23 00:51:45 +02:00
7 | 38 | 46 | 47 | 48)
2020-08-05 03:26:42 +03:00
if [[ ${FFMPEG_KIT_BUILD_TYPE} == "android" ]]; then
echo "0"
2020-08-05 03:53:02 +03:00
else
echo "1"
2020-08-05 03:26:42 +03:00
fi
;;
2020-08-05 03:53:02 +03:00
# ONLY IOS, MACOS AND TVOS MAIN
2020-11-23 00:51:45 +02:00
52)
2020-08-05 03:53:02 +03:00
if [[ ${FFMPEG_KIT_BUILD_TYPE} == "ios" ]] && [[ $1 == "ios-videotoolbox" ]]; then
2020-08-05 03:26:42 +03:00
echo "0"
2020-08-05 03:53:02 +03:00
elif [[ ${FFMPEG_KIT_BUILD_TYPE} == "macos" ]] && [[ $1 == "macos-videotoolbox" ]]; then
echo "0"
elif [[ ${FFMPEG_KIT_BUILD_TYPE} == "tvos" ]] && [[ $1 == "tvos-videotoolbox" ]] && [[ -z ${FFMPEG_KIT_LTS_BUILD} ]]; then
echo "0"
else
echo "1"
2020-08-05 03:26:42 +03:00
fi
;;
2020-08-05 03:53:02 +03:00
# ONLY IOS AND MACOS
2020-11-23 00:51:45 +02:00
53)
2020-08-05 03:53:02 +03:00
if [[ ${FFMPEG_KIT_BUILD_TYPE} == "ios" ]] && [[ $1 == "ios-avfoundation" ]]; then
echo "0"
elif [[ ${FFMPEG_KIT_BUILD_TYPE} == "macos" ]] && [[ $1 == "macos-avfoundation" ]]; then
echo "0"
else
2020-08-05 03:26:42 +03:00
echo "1"
2020-08-05 03:53:02 +03:00
fi
;;
# IOS, MACOS AND TVOS
2020-11-23 00:51:45 +02:00
49 | 50 | 51 | 54 | 55)
2021-01-09 18:24:56 +02:00
if [[ ${FFMPEG_KIT_BUILD_TYPE} == "ios" ]] || [[ ${FFMPEG_KIT_BUILD_TYPE} == "tvos" ]] || [[ ${FFMPEG_KIT_BUILD_TYPE} == "macos" ]]; then
2020-08-05 03:53:02 +03:00
echo "0"
2020-08-05 03:26:42 +03:00
else
2020-08-05 03:53:02 +03:00
echo "1"
fi
;;
# ONLY MACOS
2020-11-23 00:51:45 +02:00
56 | 57 | 58)
2020-08-05 03:53:02 +03:00
if [[ ${FFMPEG_KIT_BUILD_TYPE} == "macos" ]]; then
2020-08-05 03:26:42 +03:00
echo "0"
2020-08-05 03:53:02 +03:00
else
echo "1"
2020-08-05 03:26:42 +03:00
fi
;;
*)
2020-08-05 03:53:02 +03:00
echo "1"
2020-08-05 03:26:42 +03:00
;;
esac
}
#
2020-08-05 03:53:02 +03:00
# 1. <library name>
2020-08-05 03:26:42 +03:00
#
is_arch_supported_on_platform() {
2020-08-05 03:53:02 +03:00
local arch_index=$(from_arch_name "$1")
case ${arch_index} in
$ARCH_X86_64)
echo 1
2020-08-05 03:26:42 +03:00
;;
2020-08-05 03:53:02 +03:00
# ANDROID
$ARCH_ARM_V7A | $ARCH_ARM_V7A_NEON | $ARCH_ARM64_V8A | $ARCH_X86)
2020-08-05 03:26:42 +03:00
if [[ ${FFMPEG_KIT_BUILD_TYPE} == "android" ]]; then
2020-08-05 03:53:02 +03:00
echo 1
2020-08-05 03:26:42 +03:00
else
2020-08-05 03:53:02 +03:00
echo 0
2020-08-05 03:26:42 +03:00
fi
;;
2020-08-05 03:53:02 +03:00
# IOS
2020-11-23 00:51:45 +02:00
$ARCH_ARMV7 | $ARCH_ARMV7S | $ARCH_ARM64E | $ARCH_I386 | $ARCH_X86_64_MAC_CATALYST | $ARCH_ARM64_MAC_CATALYST | $ARCH_ARM64_SIMULATOR)
2020-08-05 03:26:42 +03:00
if [[ ${FFMPEG_KIT_BUILD_TYPE} == "ios" ]]; then
2020-08-05 03:53:02 +03:00
echo 1
2020-08-05 03:26:42 +03:00
else
2020-08-05 03:53:02 +03:00
echo 0
2020-08-05 03:26:42 +03:00
fi
;;
2020-08-05 03:53:02 +03:00
# IOS, MACOS OR TVOS
$ARCH_ARM64)
2021-01-09 18:24:56 +02:00
if [[ ${FFMPEG_KIT_BUILD_TYPE} == "ios" ]] || [[ ${FFMPEG_KIT_BUILD_TYPE} == "tvos" ]] || [[ ${FFMPEG_KIT_BUILD_TYPE} == "macos" ]]; then
2020-08-05 03:53:02 +03:00
echo 1
2020-08-05 03:26:42 +03:00
else
2020-08-05 03:53:02 +03:00
echo 0
2020-08-05 03:26:42 +03:00
fi
;;
*)
2020-08-05 03:53:02 +03:00
echo 0
2020-08-05 03:26:42 +03:00
;;
esac
}
get_package_config_file_name() {
case $1 in
1) echo "freetype2" ;;
5) echo "libmp3lame" ;;
8) echo "theora" ;;
9) echo "vorbis" ;;
10) echo "vpx" ;;
12) echo "libxml-2.0" ;;
13) echo "opencore-amrnb" ;;
21) echo "vidstab" ;;
27) echo "aom" ;;
28) echo "libchromaprint" ;;
30) echo "sdl2" ;;
35) echo "libjpeg" ;;
36) echo "ogg" ;;
40) echo "libtiff-4" ;;
42) echo "sndfile" ;;
43) echo "lept" ;;
44) echo "samplerate" ;;
2020-11-23 00:51:45 +02:00
55) echo "uuid" ;;
2020-08-05 03:26:42 +03:00
*) echo "$(get_library_name "$1")" ;;
esac
}
2021-01-30 01:35:05 +02:00
get_meson_target_host_family() {
case ${FFMPEG_KIT_BUILD_TYPE} in
android)
echo "android"
;;
*)
echo "darwin"
;;
esac
}
get_meson_target_cpu_family() {
case ${ARCH} in
arm*)
echo "arm"
;;
x86-64*)
echo "x86_64"
;;
x86*)
echo "x86"
;;
*)
echo "${ARCH}"
;;
esac
}
2020-11-23 00:51:45 +02:00
get_target() {
case ${ARCH} in
*-mac-catalyst)
echo "$(get_target_cpu)-apple-ios$(get_min_sdk_version)-macabi"
;;
armv7 | armv7s | arm64e)
echo "$(get_target_cpu)-apple-ios$(get_min_sdk_version)"
;;
i386)
echo "$(get_target_cpu)-apple-ios$(get_min_sdk_version)-simulator"
;;
arm64)
if [[ ${FFMPEG_KIT_BUILD_TYPE} == "ios" ]]; then
echo "$(get_target_cpu)-apple-ios$(get_min_sdk_version)"
elif [[ ${FFMPEG_KIT_BUILD_TYPE} == "macos" ]]; then
echo "$(get_target_cpu)-apple-macos$(get_min_sdk_version)"
elif [[ ${FFMPEG_KIT_BUILD_TYPE} == "tvos" ]]; then
echo "$(get_target_cpu)-apple-tvos$(get_min_sdk_version)"
fi
;;
arm64-simulator)
2021-02-27 14:33:12 +02:00
if [[ ${FFMPEG_KIT_BUILD_TYPE} == "ios" ]]; then
echo "$(get_target_cpu)-apple-ios$(get_min_sdk_version)-simulator"
elif [[ ${FFMPEG_KIT_BUILD_TYPE} == "tvos" ]]; then
echo "$(get_target_cpu)-apple-tvos$(get_min_sdk_version)-simulator"
fi
2020-11-23 00:51:45 +02:00
;;
x86-64)
if [[ ${FFMPEG_KIT_BUILD_TYPE} == "android" ]]; then
echo "x86_64-linux-android"
elif [[ ${FFMPEG_KIT_BUILD_TYPE} == "ios" ]]; then
echo "$(get_target_cpu)-apple-ios$(get_min_sdk_version)-simulator"
elif [[ ${FFMPEG_KIT_BUILD_TYPE} == "macos" ]]; then
echo "$(get_target_cpu)-apple-darwin$(get_min_sdk_version)"
elif [[ ${FFMPEG_KIT_BUILD_TYPE} == "tvos" ]]; then
echo "$(get_target_cpu)-apple-tvos$(get_min_sdk_version)-simulator"
fi
;;
*)
get_host
;;
2020-08-05 03:26:42 +03:00
esac
}
2020-11-23 00:51:45 +02:00
get_host() {
2020-08-05 03:26:42 +03:00
case ${ARCH} in
arm-v7a | arm-v7a-neon)
echo "arm-linux-androideabi"
;;
2021-02-27 14:33:12 +02:00
armv7 | armv7s | arm64e | i386 | *-mac-catalyst)
2020-11-23 00:51:45 +02:00
echo "$(get_target_cpu)-ios-darwin"
2020-08-05 03:26:42 +03:00
;;
2021-02-27 14:33:12 +02:00
arm64-simulator)
if [[ ${FFMPEG_KIT_BUILD_TYPE} == "ios" ]]; then
echo "$(get_target_cpu)-ios-darwin"
elif [[ ${FFMPEG_KIT_BUILD_TYPE} == "tvos" ]]; then
echo "$(get_target_cpu)-tvos-darwin"
fi
;;
2020-08-05 03:26:42 +03:00
arm64-v8a)
echo "aarch64-linux-android"
;;
arm64)
if [[ ${FFMPEG_KIT_BUILD_TYPE} == "ios" ]]; then
2020-11-23 00:51:45 +02:00
echo "$(get_target_cpu)-ios-darwin"
elif [[ ${FFMPEG_KIT_BUILD_TYPE} == "macos" ]]; then
echo "$(get_target_cpu)-apple-darwin"
2020-08-05 03:26:42 +03:00
elif [[ ${FFMPEG_KIT_BUILD_TYPE} == "tvos" ]]; then
2020-11-23 00:51:45 +02:00
echo "$(get_target_cpu)-tvos-darwin"
2020-08-05 03:26:42 +03:00
fi
;;
x86)
echo "i686-linux-android"
;;
x86-64)
if [[ ${FFMPEG_KIT_BUILD_TYPE} == "android" ]]; then
echo "x86_64-linux-android"
elif [[ ${FFMPEG_KIT_BUILD_TYPE} == "ios" ]]; then
2020-11-23 00:51:45 +02:00
echo "$(get_target_cpu)-ios-darwin"
2020-08-05 03:53:02 +03:00
elif [[ ${FFMPEG_KIT_BUILD_TYPE} == "macos" ]]; then
2020-11-23 00:51:45 +02:00
echo "$(get_target_cpu)-apple-darwin"
2020-08-05 03:26:42 +03:00
elif [[ ${FFMPEG_KIT_BUILD_TYPE} == "tvos" ]]; then
2020-11-23 00:51:45 +02:00
echo "$(get_target_cpu)-tvos-darwin"
2020-08-05 03:26:42 +03:00
fi
;;
esac
}
skip_library() {
SKIP_VARIABLE=$(echo "SKIP_$1" | sed "s/\-/\_/g")
2020-08-05 03:53:02 +03:00
export "${SKIP_VARIABLE}"=1
2020-08-05 03:26:42 +03:00
}
no_output_redirection() {
export NO_OUTPUT_REDIRECTION=1
}
no_workspace_cleanup_library() {
NO_WORKSPACE_CLEANUP_VARIABLE=$(echo "NO_WORKSPACE_CLEANUP_$1" | sed "s/\-/\_/g")
2020-08-05 03:53:02 +03:00
export "${NO_WORKSPACE_CLEANUP_VARIABLE}"=1
2020-08-05 03:26:42 +03:00
}
no_link_time_optimization() {
export NO_LINK_TIME_OPTIMIZATION=1
}
enable_debug() {
export FFMPEG_KIT_DEBUG="-g"
BUILD_TYPE_ID+="debug "
}
optimize_for_speed() {
export FFMPEG_KIT_OPTIMIZED_FOR_SPEED="1"
}
print_unknown_option() {
2020-11-23 00:51:45 +02:00
echo -e "\n(*) Unknown option \"$1\".\n\nSee $0 --help for available options.\n"
2020-08-05 03:26:42 +03:00
exit 1
}
print_unknown_library() {
2020-11-23 00:51:45 +02:00
echo -e "\n(*) Unknown library \"$1\".\n\nSee $0 --help for available libraries.\n"
exit 1
}
print_unknown_virtual_library() {
echo -e "\n(*) Unknown virtual library \"$1\".\n\nThis is a bug and must be reported to project developers.\n"
2020-08-05 03:26:42 +03:00
exit 1
}
print_unknown_arch() {
2020-11-23 00:51:45 +02:00
echo -e "\n(*) Unknown architecture \"$1\".\n\nSee $0 --help for available architectures.\n"
2020-08-05 03:26:42 +03:00
exit 1
}
2021-01-09 18:24:56 +02:00
print_unknown_arch_variant() {
echo -e "\n(*) Unknown architecture variant \"$1\".\n\nSee $0 --help for available architecture variants.\n"
exit 1
}
2020-08-05 03:26:42 +03:00
display_version() {
2020-08-05 03:53:02 +03:00
COMMAND=$(echo "$0" | sed -e 's/\.\///g')
2020-08-05 03:26:42 +03:00
echo -e "\
2021-01-09 18:24:56 +02:00
$COMMAND v$(get_ffmpeg_kit_version)
Copyright (c) 2018-2021 Taner Sener\n\
2020-08-05 03:26:42 +03:00
License LGPLv3.0: GNU LGPL version 3 or later\n\
<https://www.gnu.org/licenses/lgpl-3.0.en.html>\n\
This is free software: you can redistribute it and/or modify it under the terms of the \
GNU Lesser General Public License as published by the Free Software Foundation, \
either version 3 of the License, or (at your option) any later version."
}
display_help_options() {
echo -e "Options:"
echo -e " -h, --help\t\t\tdisplay this help and exit"
echo -e " -v, --version\t\t\tdisplay version information and exit"
echo -e " -d, --debug\t\t\tbuild with debug information"
echo -e " -s, --speed\t\t\toptimize for speed instead of size"
echo -e " -f, --force\t\t\tignore warnings"
if [ -n "$1" ]; then
echo -e "$1"
fi
2020-11-23 00:51:45 +02:00
if [ -n "$2" ]; then
echo -e "$2"
fi
2020-08-05 03:26:42 +03:00
echo -e ""
}
display_help_licensing() {
echo -e "Licensing options:"
2021-01-09 18:24:56 +02:00
echo -e " --enable-gpl\t\t\tallow building GPL libraries, created libs will be licensed under the GPLv3.0 [no]\n"
2020-08-05 03:26:42 +03:00
}
display_help_common_libraries() {
echo -e " --enable-chromaprint\t\tbuild with chromaprint [no]"
2021-01-30 01:35:05 +02:00
echo -e " --enable-dav1d\t\tbuild with dav1d [no]"
2020-08-05 03:26:42 +03:00
echo -e " --enable-fontconfig\t\tbuild with fontconfig [no]"
echo -e " --enable-freetype\t\tbuild with freetype [no]"
echo -e " --enable-fribidi\t\tbuild with fribidi [no]"
echo -e " --enable-gmp\t\t\tbuild with gmp [no]"
echo -e " --enable-gnutls\t\tbuild with gnutls [no]"
echo -e " --enable-kvazaar\t\tbuild with kvazaar [no]"
echo -e " --enable-lame\t\t\tbuild with lame [no]"
echo -e " --enable-libaom\t\tbuild with libaom [no]"
echo -e " --enable-libass\t\tbuild with libass [no]"
2020-11-23 00:51:45 +02:00
case ${FFMPEG_KIT_BUILD_TYPE} in
2021-01-09 18:24:56 +02:00
android)
2020-11-23 00:51:45 +02:00
echo -e " --enable-libiconv\t\tbuild with libiconv [no]"
;;
esac
2020-08-05 03:26:42 +03:00
echo -e " --enable-libilbc\t\tbuild with libilbc [no]"
echo -e " --enable-libtheora\t\tbuild with libtheora [no]"
echo -e " --enable-libvorbis\t\tbuild with libvorbis [no]"
echo -e " --enable-libvpx\t\tbuild with libvpx [no]"
echo -e " --enable-libwebp\t\tbuild with libwebp [no]"
echo -e " --enable-libxml2\t\tbuild with libxml2 [no]"
echo -e " --enable-opencore-amr\t\tbuild with opencore-amr [no]"
echo -e " --enable-openh264\t\tbuild with openh264 [no]"
echo -e " --enable-opus\t\t\tbuild with opus [no]"
echo -e " --enable-sdl\t\t\tbuild with sdl [no]"
echo -e " --enable-shine\t\tbuild with shine [no]"
echo -e " --enable-snappy\t\tbuild with snappy [no]"
echo -e " --enable-soxr\t\t\tbuild with soxr [no]"
echo -e " --enable-speex\t\tbuild with speex [no]"
echo -e " --enable-tesseract\t\tbuild with tesseract [no]"
echo -e " --enable-twolame\t\tbuild with twolame [no]"
2021-01-30 01:35:05 +02:00
echo -e " --enable-vo-amrwbenc\t\tbuild with vo-amrwbenc [no]\n"
2020-08-05 03:26:42 +03:00
}
display_help_gpl_libraries() {
echo -e "GPL libraries:"
echo -e " --enable-libvidstab\t\tbuild with libvidstab [no]"
echo -e " --enable-rubberband\t\tbuild with rubber band [no]"
echo -e " --enable-x264\t\t\tbuild with x264 [no]"
echo -e " --enable-x265\t\t\tbuild with x265 [no]"
echo -e " --enable-xvidcore\t\tbuild with xvidcore [no]\n"
}
display_help_advanced_options() {
echo -e "Advanced options:"
echo -e " --reconf-LIBRARY\t\trun autoreconf before building LIBRARY [no]"
echo -e " --redownload-LIBRARY\t\tdownload LIBRARY even if it is detected as already downloaded [no]"
echo -e " --rebuild-LIBRARY\t\tbuild LIBRARY even if it is detected as already built [no]"
if [ -n "$1" ]; then
echo -e "$1"
fi
echo -e ""
2020-08-05 03:26:42 +03:00
}
#
# 1. <library name>
#
reconf_library() {
local RECONF_VARIABLE=$(echo "RECONF_$1" | sed "s/\-/\_/g")
local library_supported=0
2020-11-23 00:51:45 +02:00
for library in {0..46}; do
2020-08-05 03:26:42 +03:00
library_name=$(get_library_name ${library})
2020-11-23 00:51:45 +02:00
local library_supported_on_platform=$(is_library_supported_on_platform "${library_name}")
2020-08-05 03:26:42 +03:00
2020-08-05 03:53:02 +03:00
if [[ $1 != "ffmpeg" ]] && [[ ${library_name} == "$1" ]] && [[ ${library_supported_on_platform} -eq 0 ]]; then
2020-08-05 03:26:42 +03:00
export ${RECONF_VARIABLE}=1
RECONF_LIBRARIES+=($1)
library_supported=1
fi
done
2020-11-23 00:51:45 +02:00
if [[ ${library_supported} -ne 1 ]]; then
2020-08-05 03:53:02 +03:00
echo -e "INFO: --reconf flag detected for library $1 is not supported.\n" 1>>"${BASEDIR}"/build.log 2>&1
2020-08-05 03:26:42 +03:00
fi
}
#
# 1. <library name>
#
rebuild_library() {
local REBUILD_VARIABLE=$(echo "REBUILD_$1" | sed "s/\-/\_/g")
local library_supported=0
2020-11-23 00:51:45 +02:00
for library in {0..46}; do
2020-08-05 03:26:42 +03:00
library_name=$(get_library_name ${library})
2020-11-23 00:51:45 +02:00
local library_supported_on_platform=$(is_library_supported_on_platform "${library_name}")
2020-08-05 03:26:42 +03:00
2020-08-05 03:53:02 +03:00
if [[ $1 != "ffmpeg" ]] && [[ ${library_name} == "$1" ]] && [[ ${library_supported_on_platform} -eq 0 ]]; then
2020-08-05 03:26:42 +03:00
export ${REBUILD_VARIABLE}=1
REBUILD_LIBRARIES+=($1)
library_supported=1
fi
done
2020-11-23 00:51:45 +02:00
if [[ ${library_supported} -ne 1 ]]; then
2020-08-05 03:53:02 +03:00
echo -e "INFO: --rebuild flag detected for library $1 is not supported.\n" 1>>"${BASEDIR}"/build.log 2>&1
2020-08-05 03:26:42 +03:00
fi
}
#
# 1. <library name>
#
redownload_library() {
local REDOWNLOAD_VARIABLE=$(echo "REDOWNLOAD_$1" | sed "s/\-/\_/g")
local library_supported=0
2020-11-23 00:51:45 +02:00
for library in {0..46}; do
2020-08-05 03:26:42 +03:00
library_name=$(get_library_name ${library})
2020-11-23 00:51:45 +02:00
local library_supported_on_platform=$(is_library_supported_on_platform "${library_name}")
2020-08-05 03:26:42 +03:00
2020-08-05 03:53:02 +03:00
if [[ ${library_name} == "$1" ]] && [[ ${library_supported_on_platform} -eq 0 ]]; then
2020-08-05 03:26:42 +03:00
export ${REDOWNLOAD_VARIABLE}=1
REDOWNLOAD_LIBRARIES+=($1)
library_supported=1
fi
done
if [[ "ffmpeg" == $1 ]]; then
export ${REDOWNLOAD_VARIABLE}=1
REDOWNLOAD_LIBRARIES+=($1)
library_supported=1
fi
2020-11-23 00:51:45 +02:00
if [[ ${library_supported} -ne 1 ]]; then
2020-08-05 03:53:02 +03:00
echo -e "INFO: --redownload flag detected for library $1 is not supported.\n" 1>>"${BASEDIR}"/build.log 2>&1
2020-08-05 03:26:42 +03:00
fi
}
2020-08-05 03:53:02 +03:00
#
2020-11-23 00:51:45 +02:00
# 1. library name
2020-08-05 03:53:02 +03:00
# 2. ignore unknown libraries
#
2020-08-05 03:26:42 +03:00
enable_library() {
2020-08-05 03:53:02 +03:00
local library_supported_on_platform=$(is_library_supported_on_platform "$1")
if [[ $library_supported_on_platform == 0 ]]; then
set_library "$1" 1
elif [[ $2 -ne 1 ]]; then
print_unknown_library "$1"
2020-08-05 03:26:42 +03:00
fi
}
2020-11-23 00:51:45 +02:00
#
# 1. library name
# 2. enable/disable
#
2020-08-05 03:26:42 +03:00
set_library() {
2020-11-23 00:51:45 +02:00
local library_supported_on_platform=$(is_library_supported_on_platform "$1")
if [[ $library_supported_on_platform -ne 0 ]]; then
return
fi
2020-08-05 03:26:42 +03:00
case $1 in
android-zlib)
ENABLED_LIBRARIES[LIBRARY_ANDROID_ZLIB]=$2
;;
android-media-codec)
ENABLED_LIBRARIES[LIBRARY_ANDROID_MEDIA_CODEC]=$2
;;
2020-08-05 03:53:02 +03:00
ios-zlib | macos-zlib | tvos-zlib)
2020-11-23 00:51:45 +02:00
ENABLED_LIBRARIES[LIBRARY_APPLE_ZLIB]=$2
2020-08-05 03:26:42 +03:00
;;
2020-08-05 03:53:02 +03:00
ios-audiotoolbox | macos-audiotoolbox | tvos-audiotoolbox)
2020-11-23 00:51:45 +02:00
ENABLED_LIBRARIES[LIBRARY_APPLE_AUDIOTOOLBOX]=$2
2020-08-05 03:26:42 +03:00
;;
2020-08-05 03:53:02 +03:00
ios-bzip2 | macos-bzip2 | tvos-bzip2)
2020-11-23 00:51:45 +02:00
ENABLED_LIBRARIES[LIBRARY_APPLE_BZIP2]=$2
2020-08-05 03:26:42 +03:00
;;
2020-08-05 03:53:02 +03:00
ios-videotoolbox | macos-videotoolbox | tvos-videotoolbox)
2020-11-23 00:51:45 +02:00
ENABLED_LIBRARIES[LIBRARY_APPLE_VIDEOTOOLBOX]=$2
2020-08-05 03:26:42 +03:00
;;
2020-08-05 03:53:02 +03:00
ios-avfoundation | macos-avfoundation)
2020-11-23 00:51:45 +02:00
ENABLED_LIBRARIES[LIBRARY_APPLE_AVFOUNDATION]=$2
2020-08-05 03:26:42 +03:00
;;
2020-08-05 03:53:02 +03:00
ios-libiconv | macos-libiconv | tvos-libiconv)
2020-11-23 00:51:45 +02:00
ENABLED_LIBRARIES[LIBRARY_APPLE_LIBICONV]=$2
;;
ios-libuuid | macos-libuuid | tvos-libuuid)
ENABLED_LIBRARIES[LIBRARY_APPLE_LIBUUID]=$2
2020-08-05 03:26:42 +03:00
;;
2020-08-05 03:53:02 +03:00
macos-coreimage)
2020-11-23 00:51:45 +02:00
ENABLED_LIBRARIES[LIBRARY_APPLE_COREIMAGE]=$2
2020-08-05 03:26:42 +03:00
;;
2020-08-05 03:53:02 +03:00
macos-opencl)
2020-11-23 00:51:45 +02:00
ENABLED_LIBRARIES[LIBRARY_APPLE_OPENCL]=$2
2020-08-05 03:26:42 +03:00
;;
2020-08-05 03:53:02 +03:00
macos-opengl)
2020-11-23 00:51:45 +02:00
ENABLED_LIBRARIES[LIBRARY_APPLE_OPENGL]=$2
2020-08-05 03:26:42 +03:00
;;
chromaprint)
ENABLED_LIBRARIES[LIBRARY_CHROMAPRINT]=$2
;;
2020-08-05 03:53:02 +03:00
cpu-features)
# CPU-FEATURES IS ALWAYS ENABLED
ENABLED_LIBRARIES[LIBRARY_CPU_FEATURES]=1
;;
2021-01-30 01:35:05 +02:00
dav1d)
ENABLED_LIBRARIES[LIBRARY_DAV1D]=$2
;;
2020-08-05 03:26:42 +03:00
fontconfig)
ENABLED_LIBRARIES[LIBRARY_FONTCONFIG]=$2
ENABLED_LIBRARIES[LIBRARY_EXPAT]=$2
2020-11-23 00:51:45 +02:00
set_virtual_library "libiconv" $2
set_virtual_library "libuuid" $2
2020-08-05 03:26:42 +03:00
set_library "freetype" $2
;;
freetype)
ENABLED_LIBRARIES[LIBRARY_FREETYPE]=$2
2020-11-23 00:51:45 +02:00
set_virtual_library "zlib" $2
2020-08-05 03:26:42 +03:00
set_library "libpng" $2
;;
fribidi)
ENABLED_LIBRARIES[LIBRARY_FRIBIDI]=$2
;;
gmp)
ENABLED_LIBRARIES[LIBRARY_GMP]=$2
;;
gnutls)
ENABLED_LIBRARIES[LIBRARY_GNUTLS]=$2
2020-11-23 00:51:45 +02:00
set_virtual_library "zlib" $2
2020-08-05 03:26:42 +03:00
set_library "nettle" $2
set_library "gmp" $2
2020-11-23 00:51:45 +02:00
set_virtual_library "libiconv" $2
;;
harfbuzz)
ENABLED_LIBRARIES[LIBRARY_HARFBUZZ]=$2
set_library "fontconfig" $2
set_library "freetype" $2
2020-08-05 03:26:42 +03:00
;;
kvazaar)
ENABLED_LIBRARIES[LIBRARY_KVAZAAR]=$2
;;
lame)
ENABLED_LIBRARIES[LIBRARY_LAME]=$2
2020-11-23 00:51:45 +02:00
set_virtual_library "libiconv" $2
2020-08-05 03:26:42 +03:00
;;
libaom)
ENABLED_LIBRARIES[LIBRARY_LIBAOM]=$2
;;
libass)
ENABLED_LIBRARIES[LIBRARY_LIBASS]=$2
ENABLED_LIBRARIES[LIBRARY_EXPAT]=$2
2020-11-23 00:51:45 +02:00
set_virtual_library "libuuid" $2
2020-08-05 03:26:42 +03:00
set_library "freetype" $2
set_library "fribidi" $2
set_library "fontconfig" $2
2020-11-23 00:51:45 +02:00
set_library "harfbuzz" $2
set_virtual_library "libiconv" $2
2020-08-05 03:26:42 +03:00
;;
libiconv)
ENABLED_LIBRARIES[LIBRARY_LIBICONV]=$2
;;
libilbc)
ENABLED_LIBRARIES[LIBRARY_LIBILBC]=$2
;;
libpng)
ENABLED_LIBRARIES[LIBRARY_LIBPNG]=$2
2020-11-23 00:51:45 +02:00
set_virtual_library "zlib" $2
2020-08-05 03:26:42 +03:00
;;
libtheora)
ENABLED_LIBRARIES[LIBRARY_LIBTHEORA]=$2
ENABLED_LIBRARIES[LIBRARY_LIBOGG]=$2
set_library "libvorbis" $2
;;
2020-11-23 00:51:45 +02:00
libuuid)
ENABLED_LIBRARIES[LIBRARY_LIBUUID]=$2
;;
2020-08-05 03:26:42 +03:00
libvidstab)
ENABLED_LIBRARIES[LIBRARY_LIBVIDSTAB]=$2
;;
libvorbis)
ENABLED_LIBRARIES[LIBRARY_LIBVORBIS]=$2
ENABLED_LIBRARIES[LIBRARY_LIBOGG]=$2
;;
libvpx)
ENABLED_LIBRARIES[LIBRARY_LIBVPX]=$2
;;
libwebp)
ENABLED_LIBRARIES[LIBRARY_LIBWEBP]=$2
ENABLED_LIBRARIES[LIBRARY_GIFLIB]=$2
ENABLED_LIBRARIES[LIBRARY_JPEG]=$2
set_library "tiff" $2
set_library "libpng" $2
;;
libxml2)
ENABLED_LIBRARIES[LIBRARY_LIBXML2]=$2
2020-11-23 00:51:45 +02:00
set_virtual_library "libiconv" $2
2020-08-05 03:26:42 +03:00
;;
opencore-amr)
ENABLED_LIBRARIES[LIBRARY_OPENCOREAMR]=$2
;;
openh264)
ENABLED_LIBRARIES[LIBRARY_OPENH264]=$2
;;
opus)
ENABLED_LIBRARIES[LIBRARY_OPUS]=$2
;;
rubberband)
ENABLED_LIBRARIES[LIBRARY_RUBBERBAND]=$2
ENABLED_LIBRARIES[LIBRARY_SNDFILE]=$2
ENABLED_LIBRARIES[LIBRARY_LIBSAMPLERATE]=$2
;;
sdl)
ENABLED_LIBRARIES[LIBRARY_SDL]=$2
;;
shine)
ENABLED_LIBRARIES[LIBRARY_SHINE]=$2
;;
snappy)
ENABLED_LIBRARIES[LIBRARY_SNAPPY]=$2
2020-11-23 00:51:45 +02:00
set_virtual_library "zlib" $2
2020-08-05 03:26:42 +03:00
;;
soxr)
ENABLED_LIBRARIES[LIBRARY_SOXR]=$2
;;
speex)
ENABLED_LIBRARIES[LIBRARY_SPEEX]=$2
;;
tesseract)
ENABLED_LIBRARIES[LIBRARY_TESSERACT]=$2
ENABLED_LIBRARIES[LIBRARY_LEPTONICA]=$2
ENABLED_LIBRARIES[LIBRARY_LIBWEBP]=$2
ENABLED_LIBRARIES[LIBRARY_GIFLIB]=$2
ENABLED_LIBRARIES[LIBRARY_JPEG]=$2
2020-11-23 00:51:45 +02:00
set_virtual_library "zlib" $2
2020-08-05 03:26:42 +03:00
set_library "tiff" $2
set_library "libpng" $2
;;
twolame)
ENABLED_LIBRARIES[LIBRARY_TWOLAME]=$2
ENABLED_LIBRARIES[LIBRARY_SNDFILE]=$2
;;
vo-amrwbenc)
ENABLED_LIBRARIES[LIBRARY_VO_AMRWBENC]=$2
;;
x264)
ENABLED_LIBRARIES[LIBRARY_X264]=$2
;;
x265)
ENABLED_LIBRARIES[LIBRARY_X265]=$2
;;
xvidcore)
ENABLED_LIBRARIES[LIBRARY_XVIDCORE]=$2
;;
2020-11-23 00:51:45 +02:00
expat | giflib | jpeg | leptonica | libogg | libsamplerate | libsndfile)
2020-08-05 03:26:42 +03:00
# THESE LIBRARIES ARE NOT ENABLED DIRECTLY
;;
nettle)
ENABLED_LIBRARIES[LIBRARY_NETTLE]=$2
set_library "gmp" $2
;;
tiff)
ENABLED_LIBRARIES[LIBRARY_TIFF]=$2
ENABLED_LIBRARIES[LIBRARY_JPEG]=$2
;;
*)
print_unknown_library $1
;;
esac
}
2020-11-23 00:51:45 +02:00
#
# 1. library name
# 2. enable/disable
#
# These libraries are supported by all platforms.
#
set_virtual_library() {
case $1 in
libiconv)
2021-01-09 18:24:56 +02:00
if [[ ${FFMPEG_KIT_BUILD_TYPE} == "ios" ]] || [[ ${FFMPEG_KIT_BUILD_TYPE} == "tvos" ]] || [[ ${FFMPEG_KIT_BUILD_TYPE} == "macos" ]] || [[ ${FFMPEG_KIT_BUILD_TYPE} == "apple" ]]; then
2020-11-23 00:51:45 +02:00
ENABLED_LIBRARIES[LIBRARY_APPLE_LIBICONV]=$2
else
ENABLED_LIBRARIES[LIBRARY_LIBICONV]=$2
fi
;;
libuuid)
2021-01-09 18:24:56 +02:00
if [[ ${FFMPEG_KIT_BUILD_TYPE} == "ios" ]] || [[ ${FFMPEG_KIT_BUILD_TYPE} == "tvos" ]] || [[ ${FFMPEG_KIT_BUILD_TYPE} == "macos" ]] || [[ ${FFMPEG_KIT_BUILD_TYPE} == "apple" ]]; then
2020-11-23 00:51:45 +02:00
ENABLED_LIBRARIES[LIBRARY_APPLE_LIBUUID]=$2
else
ENABLED_LIBRARIES[LIBRARY_LIBUUID]=$2
fi
;;
zlib)
2021-01-09 18:24:56 +02:00
if [[ ${FFMPEG_KIT_BUILD_TYPE} == "ios" ]] || [[ ${FFMPEG_KIT_BUILD_TYPE} == "tvos" ]] || [[ ${FFMPEG_KIT_BUILD_TYPE} == "macos" ]] || [[ ${FFMPEG_KIT_BUILD_TYPE} == "apple" ]]; then
2020-11-23 00:51:45 +02:00
ENABLED_LIBRARIES[LIBRARY_APPLE_ZLIB]=$2
else
ENABLED_LIBRARIES[LIBRARY_ANDROID_ZLIB]=$2
fi
;;
*)
print_unknown_virtual_library $1
;;
esac
}
2020-08-05 03:26:42 +03:00
disable_arch() {
2020-08-05 03:53:02 +03:00
local arch_supported_on_platform=$(is_arch_supported_on_platform "$1")
if [[ $arch_supported_on_platform == 1 ]]; then
set_arch "$1" 0
2020-08-05 03:26:42 +03:00
else
2020-08-05 03:53:02 +03:00
print_unknown_arch "$1"
2020-08-05 03:26:42 +03:00
fi
}
set_arch() {
case $1 in
arm-v7a)
ENABLED_ARCHITECTURES[ARCH_ARM_V7A]=$2
;;
arm-v7a-neon)
ENABLED_ARCHITECTURES[ARCH_ARM_V7A_NEON]=$2
;;
armv7)
ENABLED_ARCHITECTURES[ARCH_ARMV7]=$2
;;
armv7s)
ENABLED_ARCHITECTURES[ARCH_ARMV7S]=$2
;;
arm64-v8a)
ENABLED_ARCHITECTURES[ARCH_ARM64_V8A]=$2
;;
arm64)
ENABLED_ARCHITECTURES[ARCH_ARM64]=$2
;;
2020-11-23 00:51:45 +02:00
arm64-mac-catalyst)
ENABLED_ARCHITECTURES[ARCH_ARM64_MAC_CATALYST]=$2
;;
arm64-simulator)
ENABLED_ARCHITECTURES[ARCH_ARM64_SIMULATOR]=$2
;;
2020-08-05 03:26:42 +03:00
arm64e)
ENABLED_ARCHITECTURES[ARCH_ARM64E]=$2
;;
i386)
ENABLED_ARCHITECTURES[ARCH_I386]=$2
;;
x86)
ENABLED_ARCHITECTURES[ARCH_X86]=$2
;;
x86-64)
ENABLED_ARCHITECTURES[ARCH_X86_64]=$2
;;
x86-64-mac-catalyst)
ENABLED_ARCHITECTURES[ARCH_X86_64_MAC_CATALYST]=$2
;;
*)
2020-08-05 03:53:02 +03:00
print_unknown_arch "$1"
;;
esac
}
check_if_dependency_rebuilt() {
case $1 in
2020-11-23 00:51:45 +02:00
cpu-features)
set_dependency_rebuilt_flag "libvpx"
set_dependency_rebuilt_flag "openh264"
;;
2020-08-05 03:53:02 +03:00
expat)
set_dependency_rebuilt_flag "fontconfig"
set_dependency_rebuilt_flag "libass"
;;
fontconfig)
set_dependency_rebuilt_flag "libass"
2020-11-23 00:51:45 +02:00
set_dependency_rebuilt_flag "harfbuzz"
2020-08-05 03:53:02 +03:00
;;
freetype)
set_dependency_rebuilt_flag "fontconfig"
set_dependency_rebuilt_flag "libass"
2020-11-23 00:51:45 +02:00
set_dependency_rebuilt_flag "harfbuzz"
2020-08-05 03:53:02 +03:00
;;
fribidi)
set_dependency_rebuilt_flag "libass"
;;
giflib)
set_dependency_rebuilt_flag "libwebp"
set_dependency_rebuilt_flag "leptonica"
set_dependency_rebuilt_flag "tesseract"
;;
gmp)
set_dependency_rebuilt_flag "gnutls"
set_dependency_rebuilt_flag "nettle"
;;
2020-11-23 00:51:45 +02:00
harfbuzz)
set_dependency_rebuilt_flag "libass"
;;
2020-08-05 03:53:02 +03:00
jpeg)
set_dependency_rebuilt_flag "tiff"
set_dependency_rebuilt_flag "libwebp"
set_dependency_rebuilt_flag "leptonica"
set_dependency_rebuilt_flag "tesseract"
;;
leptonica)
set_dependency_rebuilt_flag "tesseract"
;;
libiconv)
set_dependency_rebuilt_flag "fontconfig"
set_dependency_rebuilt_flag "gnutls"
set_dependency_rebuilt_flag "lame"
set_dependency_rebuilt_flag "libass"
set_dependency_rebuilt_flag "libxml2"
;;
libogg)
set_dependency_rebuilt_flag "libvorbis"
set_dependency_rebuilt_flag "libtheora"
;;
libpng)
set_dependency_rebuilt_flag "freetype"
set_dependency_rebuilt_flag "libwebp"
set_dependency_rebuilt_flag "libass"
set_dependency_rebuilt_flag "leptonica"
set_dependency_rebuilt_flag "tesseract"
;;
libsamplerate)
set_dependency_rebuilt_flag "rubberband"
;;
libsndfile)
set_dependency_rebuilt_flag "twolame"
set_dependency_rebuilt_flag "rubberband"
;;
libuuid)
set_dependency_rebuilt_flag "fontconfig"
set_dependency_rebuilt_flag "libass"
;;
libvorbis)
set_dependency_rebuilt_flag "libtheora"
;;
libwebp)
set_dependency_rebuilt_flag "leptonica"
set_dependency_rebuilt_flag "tesseract"
;;
nettle)
set_dependency_rebuilt_flag "gnutls"
;;
tiff)
set_dependency_rebuilt_flag "libwebp"
set_dependency_rebuilt_flag "leptonica"
set_dependency_rebuilt_flag "tesseract"
2020-08-05 03:26:42 +03:00
;;
esac
}
2020-08-05 03:53:02 +03:00
set_dependency_rebuilt_flag() {
DEPENDENCY_REBUILT_VARIABLE=$(echo "DEPENDENCY_REBUILT_$1" | sed "s/\-/\_/g")
export "${DEPENDENCY_REBUILT_VARIABLE}"=1
}
2020-08-05 03:26:42 +03:00
print_enabled_architectures() {
echo -n "Architectures: "
let enabled=0
2020-11-23 00:51:45 +02:00
for print_arch in {0..12}; do
2020-08-05 03:26:42 +03:00
if [[ ${ENABLED_ARCHITECTURES[$print_arch]} -eq 1 ]]; then
if [[ ${enabled} -ge 1 ]]; then
echo -n ", "
fi
2021-01-09 18:24:56 +02:00
echo -n "$(get_arch_name "${print_arch}")"
enabled=$((${enabled} + 1))
fi
done
if [ ${enabled} -gt 0 ]; then
echo ""
else
echo "none"
fi
}
print_enabled_architecture_variants() {
echo -n "Architecture variants: "
let enabled=0
for print_arch_var in {1..8}; do
if [[ ${ENABLED_ARCHITECTURE_VARIANTS[$print_arch_var]} -eq 1 ]]; then
if [[ ${enabled} -ge 1 ]]; then
echo -n ", "
fi
echo -n "$(get_apple_architecture_variant "${print_arch_var}")"
2020-08-05 03:26:42 +03:00
enabled=$((${enabled} + 1))
fi
done
if [ ${enabled} -gt 0 ]; then
echo ""
else
echo "none"
fi
}
print_enabled_libraries() {
echo -n "Libraries: "
let enabled=0
2020-11-23 00:51:45 +02:00
# SUPPLEMENTARY LIBRARIES NOT PRINTED
for library in {47..54} {56..58} {0..33}; do
2020-08-05 03:26:42 +03:00
if [[ ${ENABLED_LIBRARIES[$library]} -eq 1 ]]; then
if [[ ${enabled} -ge 1 ]]; then
echo -n ", "
fi
2021-01-09 18:24:56 +02:00
echo -n "$(get_library_name "${library}")"
2020-08-05 03:26:42 +03:00
enabled=$((${enabled} + 1))
fi
done
if [ ${enabled} -gt 0 ]; then
echo ""
else
echo "none"
fi
}
2021-01-09 18:24:56 +02:00
print_enabled_xcframeworks() {
echo -n "xcframeworks: "
let enabled=0
# SUPPLEMENTARY LIBRARIES NOT PRINTED
for library in {0..46}; do
if [[ ${ENABLED_LIBRARIES[$library]} -eq 1 ]]; then
if [[ ${enabled} -ge 1 ]]; then
echo -n ", "
fi
echo -n "$(get_library_name "${library}")"
enabled=$((${enabled} + 1))
fi
done
if [[ ${enabled} -ge 1 ]]; then
echo -n ", "
fi
for FFMPEG_LIB in "${FFMPEG_LIBS[@]}"; do
echo -n "${FFMPEG_LIB}, "
done
echo "ffmpeg-kit"
}
2020-08-05 03:26:42 +03:00
print_reconfigure_requested_libraries() {
local counter=0
for RECONF_LIBRARY in "${RECONF_LIBRARIES[@]}"; do
if [[ ${counter} -eq 0 ]]; then
echo -n "Reconfigure: "
else
echo -n ", "
fi
2020-08-05 03:53:02 +03:00
echo -n "${RECONF_LIBRARY}"
2020-08-05 03:26:42 +03:00
counter=$((${counter} + 1))
done
if [[ ${counter} -gt 0 ]]; then
echo ""
fi
}
print_rebuild_requested_libraries() {
local counter=0
for REBUILD_LIBRARY in "${REBUILD_LIBRARIES[@]}"; do
if [[ ${counter} -eq 0 ]]; then
echo -n "Rebuild: "
else
echo -n ", "
fi
2020-08-05 03:53:02 +03:00
echo -n "${REBUILD_LIBRARY}"
2020-08-05 03:26:42 +03:00
counter=$((${counter} + 1))
done
if [[ ${counter} -gt 0 ]]; then
echo ""
fi
}
print_redownload_requested_libraries() {
local counter=0
for REDOWNLOAD_LIBRARY in "${REDOWNLOAD_LIBRARIES[@]}"; do
if [[ ${counter} -eq 0 ]]; then
echo -n "Redownload: "
else
echo -n ", "
fi
2020-08-05 03:53:02 +03:00
echo -n "${REDOWNLOAD_LIBRARY}"
2020-08-05 03:26:42 +03:00
counter=$((${counter} + 1))
done
if [[ ${counter} -gt 0 ]]; then
echo ""
fi
}
# 1 - library index
get_external_library_license_path() {
case $1 in
1) echo "${BASEDIR}/src/$(get_library_name "$1")/docs/LICENSE.TXT" ;;
2020-11-23 00:51:45 +02:00
3 | 39) echo "${BASEDIR}/src/$(get_library_name "$1")/COPYING.LESSERv3" ;;
5 | 41) echo "${BASEDIR}/src/$(get_library_name "$1")/$(get_library_name "$1")/COPYING" ;;
19) echo "${BASEDIR}/src/$(get_library_name "$1")/$(get_library_name "$1")/LICENSE" ;;
26) echo "${BASEDIR}/src/$(get_library_name "$1")/COPYING.LGPL" ;;
28 | 35) echo "${BASEDIR}/src/$(get_library_name "$1")/LICENSE.md " ;;
30) echo "${BASEDIR}/src/$(get_library_name "$1")/COPYING.txt" ;;
38 | 40) echo "${BASEDIR}/src/$(get_library_name "$1")/COPYRIGHT" ;;
43) echo "${BASEDIR}/src/$(get_library_name "$1")/leptonica-license.txt" ;;
4 | 10 | 13 | 21 | 27 | 31 | 32 | 37) echo "${BASEDIR}/src/$(get_library_name "$1")/LICENSE" ;;
2020-08-05 03:26:42 +03:00
*) echo "${BASEDIR}/src/$(get_library_name "$1")/COPYING" ;;
esac
}
2020-11-23 00:51:45 +02:00
get_cmake_build_directory() {
echo "${FFMPEG_KIT_TMPDIR}/cmake/build/$(get_build_directory)/${LIB_NAME}"
}
get_apple_cmake_system_name() {
case ${FFMPEG_KIT_BUILD_TYPE} in
macos)
echo "Darwin"
;;
tvos)
echo "tvOS"
;;
*)
case ${ARCH} in
*-mac-catalyst)
echo "Darwin"
;;
*)
echo "iOS"
;;
esac
;;
esac
}
2020-08-05 03:26:42 +03:00
#
# 1. <library name>
#
autoreconf_library() {
2020-08-05 03:53:02 +03:00
echo -e "\nINFO: Running full autoreconf for $1\n" 1>>"${BASEDIR}"/build.log 2>&1
2020-08-05 03:26:42 +03:00
# FORCE INSTALL
(autoreconf --force --install)
local EXTRACT_RC=$?
if [ ${EXTRACT_RC} -eq 0 ]; then
2020-11-23 00:51:45 +02:00
echo -e "\nDEBUG: autoreconf completed successfully for $1\n" 1>>"${BASEDIR}"/build.log 2>&1
2020-08-05 03:26:42 +03:00
return
fi
2020-08-05 03:53:02 +03:00
echo -e "\nDEBUG: Full autoreconf failed. Running full autoreconf with include for $1\n" 1>>"${BASEDIR}"/build.log 2>&1
2020-08-05 03:26:42 +03:00
# FORCE INSTALL WITH m4
(autoreconf --force --install -I m4)
EXTRACT_RC=$?
if [ ${EXTRACT_RC} -eq 0 ]; then
2020-11-23 00:51:45 +02:00
echo -e "\nDEBUG: autoreconf completed successfully for $1\n" 1>>"${BASEDIR}"/build.log 2>&1
2020-08-05 03:26:42 +03:00
return
fi
2020-08-05 03:53:02 +03:00
echo -e "\nDEBUG: Full autoreconf with include failed. Running autoreconf without force for $1\n" 1>>"${BASEDIR}"/build.log 2>&1
2020-08-05 03:26:42 +03:00
# INSTALL WITHOUT FORCE
(autoreconf --install)
EXTRACT_RC=$?
if [ ${EXTRACT_RC} -eq 0 ]; then
2020-11-23 00:51:45 +02:00
echo -e "\nDEBUG: autoreconf completed successfully for $1\n" 1>>"${BASEDIR}"/build.log 2>&1
2020-08-05 03:26:42 +03:00
return
fi
2020-08-05 03:53:02 +03:00
echo -e "\nDEBUG: Autoreconf without force failed. Running autoreconf without force with include for $1\n" 1>>"${BASEDIR}"/build.log 2>&1
2020-08-05 03:26:42 +03:00
# INSTALL WITHOUT FORCE WITH m4
(autoreconf --install -I m4)
EXTRACT_RC=$?
if [ ${EXTRACT_RC} -eq 0 ]; then
2020-11-23 00:51:45 +02:00
echo -e "\nDEBUG: autoreconf completed successfully for $1\n" 1>>"${BASEDIR}"/build.log 2>&1
2020-08-05 03:26:42 +03:00
return
fi
2020-08-05 03:53:02 +03:00
echo -e "\nDEBUG: Autoreconf without force with include failed. Running default autoreconf for $1\n" 1>>"${BASEDIR}"/build.log 2>&1
2020-08-05 03:26:42 +03:00
# INSTALL DEFAULT
(autoreconf)
EXTRACT_RC=$?
if [ ${EXTRACT_RC} -eq 0 ]; then
2020-11-23 00:51:45 +02:00
echo -e "\nDEBUG: autoreconf completed successfully for $1\n" 1>>"${BASEDIR}"/build.log 2>&1
2020-08-05 03:26:42 +03:00
return
fi
2020-08-05 03:53:02 +03:00
echo -e "\nDEBUG: Default autoreconf failed. Running default autoreconf with include for $1\n" 1>>"${BASEDIR}"/build.log 2>&1
2020-08-05 03:26:42 +03:00
# INSTALL DEFAULT WITH m4
(autoreconf -I m4)
EXTRACT_RC=$?
if [ ${EXTRACT_RC} -eq 0 ]; then
2020-11-23 00:51:45 +02:00
echo -e "\nDEBUG: autoreconf completed successfully for $1\n" 1>>"${BASEDIR}"/build.log 2>&1
else
echo -e "\nDEBUG: Default autoreconf with include for $1 failed\n" 1>>"${BASEDIR}"/build.log 2>&1
2020-08-05 03:26:42 +03:00
fi
}
#
# 1. <repo url>
# 2. <local folder path>
# 3. <commit id>
#
clone_git_repository_with_commit_id() {
local RC
2020-08-05 03:53:02 +03:00
(mkdir -p $2 1>>"${BASEDIR}"/build.log 2>&1)
2020-08-05 03:26:42 +03:00
RC=$?
if [ ${RC} -ne 0 ]; then
2020-08-05 03:53:02 +03:00
echo -e "\nINFO: Failed to create local directory $2\n" 1>>"${BASEDIR}"/build.log 2>&1
rm -rf $2 1>>"${BASEDIR}"/build.log 2>&1
2020-08-05 03:26:42 +03:00
echo ${RC}
return
fi
2020-08-05 03:53:02 +03:00
echo -e "INFO: Cloning commit id $3 from repository $1 into local directory $2\n" 1>>"${BASEDIR}"/build.log 2>&1
(git clone $1 $2 --depth 1 1>>"${BASEDIR}"/build.log 2>&1)
2020-08-05 03:26:42 +03:00
RC=$?
if [ ${RC} -ne 0 ]; then
2020-08-05 03:53:02 +03:00
echo -e "\nINFO: Failed to clone $1\n" 1>>"${BASEDIR}"/build.log 2>&1
rm -rf $2 1>>"${BASEDIR}"/build.log 2>&1
2020-08-05 03:26:42 +03:00
echo ${RC}
return
fi
2020-08-05 03:53:02 +03:00
cd $2 1>>"${BASEDIR}"/build.log 2>&1
2020-08-05 03:26:42 +03:00
RC=$?
if [ ${RC} -ne 0 ]; then
2020-08-05 03:53:02 +03:00
echo -e "\nINFO: Failed to cd into $2\n" 1>>"${BASEDIR}"/build.log 2>&1
rm -rf $2 1>>"${BASEDIR}"/build.log 2>&1
2020-08-05 03:26:42 +03:00
echo ${RC}
return
fi
2020-08-05 03:53:02 +03:00
(git fetch --depth 1 origin $3 1>>"${BASEDIR}"/build.log 2>&1)
2020-08-05 03:26:42 +03:00
RC=$?
if [ ${RC} -ne 0 ]; then
2020-08-05 03:53:02 +03:00
echo -e "\nINFO: Failed to fetch commit id $3 from $1\n" 1>>"${BASEDIR}"/build.log 2>&1
rm -rf $2 1>>"${BASEDIR}"/build.log 2>&1
2020-08-05 03:26:42 +03:00
echo ${RC}
return
fi
2020-08-05 03:53:02 +03:00
(git checkout $3 1>>"${BASEDIR}"/build.log 2>&1)
2020-08-05 03:26:42 +03:00
RC=$?
if [ ${RC} -ne 0 ]; then
2020-08-05 03:53:02 +03:00
echo -e "\nINFO: Failed to checkout commit id $3 from $1\n" 1>>"${BASEDIR}"/build.log 2>&1
2020-08-05 03:26:42 +03:00
echo ${RC}
return
fi
echo ${RC}
}
#
# 1. <repo url>
# 2. <tag name>
# 3. <local folder path>
#
clone_git_repository_with_tag() {
local RC
2020-08-05 03:53:02 +03:00
(mkdir -p $3 1>>"${BASEDIR}"/build.log 2>&1)
2020-08-05 03:26:42 +03:00
RC=$?
if [ ${RC} -ne 0 ]; then
2020-08-05 03:53:02 +03:00
echo -e "\nINFO: Failed to create local directory $3\n" 1>>"${BASEDIR}"/build.log 2>&1
rm -rf $3 1>>"${BASEDIR}"/build.log 2>&1
2020-08-05 03:26:42 +03:00
echo ${RC}
return
fi
2020-08-05 03:53:02 +03:00
echo -e "INFO: Cloning tag $2 from repository $1 into local directory $3\n" 1>>"${BASEDIR}"/build.log 2>&1
(git clone --depth 1 --branch $2 $1 $3 1>>"${BASEDIR}"/build.log 2>&1)
2020-08-05 03:26:42 +03:00
RC=$?
if [ ${RC} -ne 0 ]; then
2020-08-05 03:53:02 +03:00
echo -e "\nINFO: Failed to clone $1 -> $2\n" 1>>"${BASEDIR}"/build.log 2>&1
rm -rf $3 1>>"${BASEDIR}"/build.log 2>&1
2020-08-05 03:26:42 +03:00
echo ${RC}
return
fi
echo ${RC}
}
2020-08-05 03:53:02 +03:00
#
# 1. library index
#
is_gpl_licensed() {
for gpl_library in {$LIBRARY_X264,$LIBRARY_XVIDCORE,$LIBRARY_X265,$LIBRARY_LIBVIDSTAB,$LIBRARY_RUBBERBAND}; do
if [[ $gpl_library -eq $1 ]]; then
echo 0
return
fi
done
echo 1
}
downloaded_enabled_library_sources() {
# DOWNLOAD FFMPEG SOURCE CODE FIRST
DOWNLOAD_RESULT=$(download_library_source "ffmpeg")
if [[ ${DOWNLOAD_RESULT} -ne 0 ]]; then
echo -e "failed\n"
exit 1
fi
2020-11-23 00:51:45 +02:00
for library in {1..47}; do
2020-08-05 03:53:02 +03:00
if [[ ${!library} -eq 1 ]]; then
library_name=$(get_library_name $((library - 1)))
echo -e "\nDEBUG: Downloading library ${library_name}\n" 1>>"${BASEDIR}"/build.log 2>&1
DOWNLOAD_RESULT=$(download_library_source "${library_name}")
if [[ ${DOWNLOAD_RESULT} -ne 0 ]]; then
echo -e "failed\n"
exit 1
fi
fi
done
echo -e "ok"
}
2020-08-05 03:26:42 +03:00
#
# 1. <url>
# 2. <local file name>
# 3. <on error action>
#
download() {
if [ ! -d "${FFMPEG_KIT_TMPDIR}" ]; then
mkdir -p "${FFMPEG_KIT_TMPDIR}"
fi
2020-08-05 03:53:02 +03:00
(curl --fail --location "$1" -o "${FFMPEG_KIT_TMPDIR}"/"$2" 1>>"${BASEDIR}"/build.log 2>&1)
2020-08-05 03:26:42 +03:00
local RC=$?
if [ ${RC} -eq 0 ]; then
2020-08-05 03:53:02 +03:00
echo -e "\nDEBUG: Downloaded $1 to ${FFMPEG_KIT_TMPDIR}/$2\n" 1>>"${BASEDIR}"/build.log 2>&1
2020-08-05 03:26:42 +03:00
else
2020-08-05 03:53:02 +03:00
rm -f "${FFMPEG_KIT_TMPDIR}"/"$2" 1>>"${BASEDIR}"/build.log 2>&1
2020-08-05 03:26:42 +03:00
2020-08-05 03:53:02 +03:00
echo -e -n "\nINFO: Failed to download $1 to ${FFMPEG_KIT_TMPDIR}/$2, rc=${RC}. " 1>>"${BASEDIR}"/build.log 2>&1
2020-08-05 03:26:42 +03:00
if [ "$3" == "exit" ]; then
2020-08-05 03:53:02 +03:00
echo -e "DEBUG: Build will now exit.\n" 1>>"${BASEDIR}"/build.log 2>&1
2020-08-05 03:26:42 +03:00
exit 1
else
2020-08-05 03:53:02 +03:00
echo -e "DEBUG: Build will continue.\n" 1>>"${BASEDIR}"/build.log 2>&1
2020-08-05 03:26:42 +03:00
fi
fi
echo ${RC}
}
2020-08-05 03:53:02 +03:00
#
# 1. library name
#
2020-08-05 03:26:42 +03:00
download_library_source() {
2020-08-05 03:53:02 +03:00
local SOURCE_REPO_URL=""
2020-08-05 03:26:42 +03:00
local LIB_NAME="$1"
local LIB_LOCAL_PATH=${BASEDIR}/src/${LIB_NAME}
local SOURCE_ID=""
local LIBRARY_RC=""
local DOWNLOAD_RC=""
local SOURCE_TYPE=""
2020-08-05 03:53:02 +03:00
echo -e "DEBUG: Downloading library source: $1\n" 1>>"${BASEDIR}"/build.log 2>&1
2020-08-05 03:26:42 +03:00
2020-08-05 03:53:02 +03:00
SOURCE_REPO_URL=$(get_library_source "${LIB_NAME}" 1)
SOURCE_ID=$(get_library_source "${LIB_NAME}" 2)
SOURCE_TYPE=$(get_library_source "${LIB_NAME}" 3)
2020-08-05 03:26:42 +03:00
LIBRARY_RC=$(library_is_downloaded "${LIB_NAME}")
if [ ${LIBRARY_RC} -eq 0 ]; then
2020-08-05 03:53:02 +03:00
echo -e "INFO: $1 already downloaded. Source folder found at ${LIB_LOCAL_PATH}" 1>>"${BASEDIR}"/build.log 2>&1
2020-08-05 03:26:42 +03:00
echo 0
return
fi
2020-08-05 03:53:02 +03:00
if [ "${SOURCE_TYPE}" == "TAG" ]; then
DOWNLOAD_RC=$(clone_git_repository_with_tag "${SOURCE_REPO_URL}" "${SOURCE_ID}" "${LIB_LOCAL_PATH}")
2020-08-05 03:26:42 +03:00
else
2020-08-05 03:53:02 +03:00
DOWNLOAD_RC=$(clone_git_repository_with_commit_id "${SOURCE_REPO_URL}" "${LIB_LOCAL_PATH}" "${SOURCE_ID}")
2020-08-05 03:26:42 +03:00
fi
if [ ${DOWNLOAD_RC} -ne 0 ]; then
2020-08-05 03:53:02 +03:00
echo -e "INFO: Downloading library $1 failed. Can not get library from ${SOURCE_REPO_URL}\n" 1>>"${BASEDIR}"/build.log 2>&1
2020-08-05 03:26:42 +03:00
echo ${DOWNLOAD_RC}
else
2020-08-05 03:53:02 +03:00
echo -e "\nINFO: $1 library downloaded" 1>>"${BASEDIR}"/build.log 2>&1
2020-11-23 00:51:45 +02:00
echo 0
2020-08-05 03:26:42 +03:00
fi
}
2020-11-23 00:51:45 +02:00
download_gnu_config() {
local SOURCE_REPO_URL=""
local LIB_NAME="config"
local LIB_LOCAL_PATH="${FFMPEG_KIT_TMPDIR}/source/${LIB_NAME}"
local SOURCE_ID=""
2020-08-05 03:26:42 +03:00
local DOWNLOAD_RC=""
2020-11-23 00:51:45 +02:00
local SOURCE_TYPE=""
REDOWNLOAD_VARIABLE=$(echo "REDOWNLOAD_$LIB_NAME")
2020-08-05 03:26:42 +03:00
2020-11-23 00:51:45 +02:00
echo -e "DEBUG: Downloading gnu config source.\n" 1>>"${BASEDIR}"/build.log 2>&1
2020-08-05 03:26:42 +03:00
2020-11-23 00:51:45 +02:00
SOURCE_REPO_URL=$(get_library_source "${LIB_NAME}" 1)
SOURCE_ID=$(get_library_source "${LIB_NAME}" 2)
SOURCE_TYPE=$(get_library_source "${LIB_NAME}" 3)
2020-08-05 03:26:42 +03:00
2020-11-23 00:51:45 +02:00
if [[ -d "${LIB_LOCAL_PATH}" ]]; then
if [[ ${REDOWNLOAD_VARIABLE} -eq 1 ]]; then
echo -e "INFO: gnu config already downloaded but re-download requested\n" 1>>"${BASEDIR}"/build.log 2>&1
rm -rf "${LIB_LOCAL_PATH}" 1>>"${BASEDIR}"/build.log 2>&1
2020-08-05 03:26:42 +03:00
else
2020-11-23 00:51:45 +02:00
echo -e "INFO: gnu config already downloaded. Source folder found at ${LIB_LOCAL_PATH}\n" 1>>"${BASEDIR}"/build.log 2>&1
return
2020-08-05 03:26:42 +03:00
fi
fi
2020-11-23 00:51:45 +02:00
DOWNLOAD_RC=$(clone_git_repository_with_tag "${SOURCE_REPO_URL}" "${SOURCE_ID}" "${LIB_LOCAL_PATH}")
2020-08-05 03:26:42 +03:00
2020-11-23 00:51:45 +02:00
if [[ ${DOWNLOAD_RC} -ne 0 ]]; then
echo -e "INFO: Downloading gnu config failed. Can not get source from ${SOURCE_REPO_URL}\n" 1>>"${BASEDIR}"/build.log 2>&1
echo -e "failed\n"
exit 1
2020-08-05 03:26:42 +03:00
else
2020-11-23 00:51:45 +02:00
echo -e "\nINFO: gnu config downloaded successfully\n" 1>>"${BASEDIR}"/build.log 2>&1
2020-08-05 03:26:42 +03:00
fi
2020-11-23 00:51:45 +02:00
}
2020-08-05 03:26:42 +03:00
2020-11-23 00:51:45 +02:00
is_gnu_config_files_up_to_date() {
echo $(grep aarch64-apple-darwin config.guess | wc -l 2>>"${BASEDIR}"/build.log)
2020-08-05 03:26:42 +03:00
}
2021-01-28 01:52:32 +02:00
get_user_friendly_ffmpeg_version() {
local USER_FRIENDLY_NAME=$(get_library_source "ffmpeg" 4)
echo ${USER_FRIENDLY_NAME:1}
}
2020-08-05 03:26:42 +03:00
get_cpu_count() {
if [ "$(uname)" == "Darwin" ]; then
2020-11-23 00:51:45 +02:00
echo $(sysctl -n hw.logicalcpu)
2020-08-05 03:26:42 +03:00
else
echo $(nproc)
fi
}
#
# 1. <lib name>
#
library_is_downloaded() {
local LOCAL_PATH
local LIB_NAME=$1
local FILE_COUNT
local REDOWNLOAD_VARIABLE
REDOWNLOAD_VARIABLE=$(echo "REDOWNLOAD_$1" | sed "s/\-/\_/g")
LOCAL_PATH=${BASEDIR}/src/${LIB_NAME}
2020-08-05 03:53:02 +03:00
echo -e "DEBUG: Checking if ${LIB_NAME} is already downloaded at ${LOCAL_PATH}\n" 1>>"${BASEDIR}"/build.log 2>&1
2020-08-05 03:26:42 +03:00
2020-08-05 03:53:02 +03:00
if [ ! -d "${LOCAL_PATH}" ]; then
echo -e "INFO: ${LOCAL_PATH} directory not found\n" 1>>"${BASEDIR}"/build.log 2>&1
2020-08-05 03:26:42 +03:00
echo 1
return
fi
2020-08-05 03:53:02 +03:00
FILE_COUNT=$(ls -l "${LOCAL_PATH}" | wc -l)
2020-08-05 03:26:42 +03:00
if [[ ${FILE_COUNT} -eq 0 ]]; then
2020-08-05 03:53:02 +03:00
echo -e "INFO: No files found under ${LOCAL_PATH}\n" 1>>"${BASEDIR}"/build.log 2>&1
2020-08-05 03:26:42 +03:00
echo 1
return
fi
if [[ ${REDOWNLOAD_VARIABLE} -eq 1 ]]; then
2020-08-05 03:53:02 +03:00
echo -e "INFO: ${LIB_NAME} library already downloaded but re-download requested\n" 1>>"${BASEDIR}"/build.log 2>&1
rm -rf "${LOCAL_PATH}" 1>>"${BASEDIR}"/build.log 2>&1
2020-08-05 03:26:42 +03:00
echo 1
else
2020-08-05 03:53:02 +03:00
echo -e "INFO: ${LIB_NAME} library already downloaded\n" 1>>"${BASEDIR}"/build.log 2>&1
2020-08-05 03:26:42 +03:00
echo 0
fi
}
library_is_installed() {
local INSTALL_PATH=$1
local LIB_NAME=$2
local HEADER_COUNT
local LIB_COUNT
2020-08-05 03:53:02 +03:00
echo -e "DEBUG: Checking if ${LIB_NAME} is already built and installed at ${INSTALL_PATH}/${LIB_NAME}\n" 1>>"${BASEDIR}"/build.log 2>&1
2020-08-05 03:26:42 +03:00
2020-08-05 03:53:02 +03:00
if [ ! -d "${INSTALL_PATH}"/"${LIB_NAME}" ]; then
echo -e "INFO: ${INSTALL_PATH}/${LIB_NAME} directory not found\n" 1>>"${BASEDIR}"/build.log 2>&1
2020-11-23 00:51:45 +02:00
echo 0
2020-08-05 03:26:42 +03:00
return
fi
2020-08-05 03:53:02 +03:00
if [ ! -d "${INSTALL_PATH}"/"${LIB_NAME}"/lib ]; then
echo -e "INFO: ${INSTALL_PATH}/${LIB_NAME}/lib directory not found\n" 1>>"${BASEDIR}"/build.log 2>&1
2020-11-23 00:51:45 +02:00
echo 0
2020-08-05 03:26:42 +03:00
return
fi
2020-08-05 03:53:02 +03:00
if [ ! -d "${INSTALL_PATH}"/"${LIB_NAME}"/include ]; then
echo -e "INFO: ${INSTALL_PATH}/${LIB_NAME}/include directory not found\n" 1>>"${BASEDIR}"/build.log 2>&1
2020-11-23 00:51:45 +02:00
echo 0
2020-08-05 03:26:42 +03:00
return
fi
2020-08-05 03:53:02 +03:00
HEADER_COUNT=$(ls -l "${INSTALL_PATH}"/"${LIB_NAME}"/include | wc -l)
2020-08-05 03:26:42 +03:00
LIB_COUNT=$(ls -l ${INSTALL_PATH}/${LIB_NAME}/lib | wc -l)
if [[ ${HEADER_COUNT} -eq 0 ]]; then
2020-08-05 03:53:02 +03:00
echo -e "INFO: No headers found under ${INSTALL_PATH}/${LIB_NAME}/include\n" 1>>"${BASEDIR}"/build.log 2>&1
2020-11-23 00:51:45 +02:00
echo 0
2020-08-05 03:26:42 +03:00
return
fi
if [[ ${LIB_COUNT} -eq 0 ]]; then
2020-08-05 03:53:02 +03:00
echo -e "INFO: No libraries found under ${INSTALL_PATH}/${LIB_NAME}/lib\n" 1>>"${BASEDIR}"/build.log 2>&1
2020-11-23 00:51:45 +02:00
echo 0
2020-08-05 03:26:42 +03:00
return
fi
2020-08-05 03:53:02 +03:00
echo -e "INFO: ${LIB_NAME} library is already built and installed\n" 1>>"${BASEDIR}"/build.log 2>&1
2020-11-23 00:51:45 +02:00
echo 1
2020-08-05 03:26:42 +03:00
}
prepare_inline_sed() {
if [ "$(uname)" == "Darwin" ]; then
export SED_INLINE="sed -i .tmp"
else
export SED_INLINE="sed -i"
fi
}
to_capital_case() {
echo "$(echo ${1:0:1} | tr '[a-z]' '[A-Z]')${1:1}"
}
2020-11-23 00:51:45 +02:00
#
# 1. source file
# 2. destination file
#
overwrite_file() {
rm -f "$2"
cp "$1" "$2"
}