diff options
Diffstat (limited to 'build/autoconf/android.m4')
-rw-r--r-- | build/autoconf/android.m4 | 376 |
1 files changed, 376 insertions, 0 deletions
diff --git a/build/autoconf/android.m4 b/build/autoconf/android.m4 new file mode 100644 index 0000000000..4ab6d5a821 --- /dev/null +++ b/build/autoconf/android.m4 @@ -0,0 +1,376 @@ +dnl This Source Code Form is subject to the terms of the Mozilla Public +dnl License, v. 2.0. If a copy of the MPL was not distributed with this +dnl file, You can obtain one at http://mozilla.org/MPL/2.0/. + +AC_DEFUN([MOZ_ANDROID_NDK], +[ + +MOZ_ARG_WITH_STRING(android-cxx-stl, +[ --with-android-cxx-stl=VALUE + use the specified C++ STL (libstdc++, libc++)], + android_cxx_stl=$withval, + android_cxx_stl=libc++) + +case "$target" in +*-android*|*-linuxandroid*) + dnl $android_platform will be set for us by Python configure. + CPPFLAGS="-idirafter $android_platform/usr/include $CPPFLAGS" + CFLAGS="-fno-short-enums -fno-exceptions $CFLAGS" + CXXFLAGS="-fno-short-enums -fno-exceptions $CXXFLAGS" + ASFLAGS="-idirafter $android_platform/usr/include -DANDROID $ASFLAGS" + + dnl Add --allow-shlib-undefined, because libGLESv2 links to an + dnl undefined symbol (present on the hardware, just not in the + dnl NDK.) + LDFLAGS="-L$android_platform/usr/lib -Wl,-rpath-link=$android_platform/usr/lib --sysroot=$android_platform -Wl,--allow-shlib-undefined $LDFLAGS" + dnl Add -llog by default, since we use it all over the place. + LIBS="-llog $LIBS" + ANDROID_PLATFORM="${android_platform}" + + AC_DEFINE(ANDROID) + AC_SUBST(ANDROID_PLATFORM) + + ;; +esac + +]) + +AC_DEFUN([MOZ_ANDROID_CPU_ARCH], +[ + +if test "$OS_TARGET" = "Android"; then + case "${CPU_ARCH}-${MOZ_ARCH}" in + arm-armv7*) + ANDROID_CPU_ARCH=armeabi-v7a + ;; + arm-*) + ANDROID_CPU_ARCH=armeabi + ;; + x86-*) + ANDROID_CPU_ARCH=x86 + ;; + mips32-*) # When target_cpu is mipsel, CPU_ARCH is mips32 + ANDROID_CPU_ARCH=mips + ;; + aarch64-*) + ANDROID_CPU_ARCH=arm64-v8a + ;; + esac + + AC_SUBST(ANDROID_CPU_ARCH) +fi +]) + +AC_DEFUN([MOZ_ANDROID_STLPORT], +[ + +if test "$OS_TARGET" = "Android"; then + cpu_arch_dir="$ANDROID_CPU_ARCH" + # NDK r12 removed the arm/thumb library split and just made everything + # thumb by default. Attempt to compensate. + if test "$MOZ_THUMB2" = 1 -a -d "$cpu_arch_dir/thumb"; then + cpu_arch_dir="$cpu_arch_dir/thumb" + fi + + if test -z "$STLPORT_CPPFLAGS$STLPORT_LIBS"; then + case "$android_cxx_stl" in + libstdc++) + # android-ndk-r8b and later + ndk_base="$android_ndk/sources/cxx-stl/gnu-libstdc++/$android_gnu_compiler_version" + ndk_libs_include="$ndk_base/libs/$ANDROID_CPU_ARCH" + ndk_libs="$ndk_base/libs/$cpu_arch_dir" + ndk_include="$ndk_base/include" + + if ! test -e "$ndk_libs/libgnustl_static.a"; then + AC_MSG_ERROR([Couldn't find path to gnu-libstdc++ in the android ndk]) + fi + + STLPORT_LIBS="-L$ndk_libs -lgnustl_static" + STLPORT_CPPFLAGS="-I$ndk_include -I$ndk_include/backward -I$ndk_libs_include/include" + ;; + libc++) + # android-ndk-r8b and later + ndk_base="$android_ndk/sources/cxx-stl" + cxx_base="$ndk_base/llvm-libc++" + cxx_libs="$cxx_base/libs/$cpu_arch_dir" + cxx_include="$cxx_base/libcxx/include" + cxxabi_base="$ndk_base/llvm-libc++abi" + cxxabi_include="$cxxabi_base/libcxxabi/include" + + if ! test -e "$cxx_libs/libc++_static.a"; then + AC_MSG_ERROR([Couldn't find path to llvm-libc++ in the android ndk]) + fi + + STLPORT_LIBS="-L$cxx_libs -lc++_static" + # NDK r12 split the libc++ runtime libraries into pieces. + for lib in c++abi unwind android_support; do + if test -e "$cxx_libs/lib${lib}.a"; then + STLPORT_LIBS="$STLPORT_LIBS -l${lib}" + fi + done + # Add android/support/include/ for prototyping long double math + # functions, locale-specific C library functions, multibyte support, + # etc. + STLPORT_CPPFLAGS="-I$android_ndk/sources/android/support/include -I$cxx_include -I$cxxabi_include" + ;; + *) + AC_MSG_ERROR([Bad value for --enable-android-cxx-stl]) + ;; + esac + fi + CXXFLAGS="$CXXFLAGS $STLPORT_CPPFLAGS" +fi +MOZ_ANDROID_CXX_STL=$android_cxx_stl +AC_SUBST([MOZ_ANDROID_CXX_STL]) +AC_SUBST([STLPORT_LIBS]) + +]) + + +AC_DEFUN([concat],[$1$2$3$4]) + +dnl Find a component of an AAR. +dnl Arg 1: variable name to expose, like ANDROID_SUPPORT_V4_LIB. +dnl Arg 2: path to component. +dnl Arg 3: if non-empty, expect and require component. +AC_DEFUN([MOZ_ANDROID_AAR_COMPONENT], [ + ifelse([$3], , + [ + if test -e "$$1" ; then + AC_MSG_ERROR([Found unexpected exploded $1!]) + fi + ], + [ + AC_MSG_CHECKING([for $1]) + $1="$2" + if ! test -e "$$1" ; then + AC_MSG_ERROR([Could not find required exploded $1!]) + fi + AC_MSG_RESULT([$$1]) + AC_SUBST($1) + ]) +]) + +dnl Find an AAR and expose variables representing its exploded components. +dnl AC_SUBSTs ANDROID_NAME_{AAR,AAR_RES,AAR_LIB,AAR_INTERNAL_LIB}. +dnl Arg 1: name, like play-services-base +dnl Arg 2: version, like 7.8.0 +dnl Arg 3: extras subdirectory, either android or google +dnl Arg 4: package subdirectory, like com/google/android/gms +dnl Arg 5: if non-empty, expect and require internal_impl JAR. +dnl Arg 6: if non-empty, expect and require assets/ directory. +AC_DEFUN([MOZ_ANDROID_AAR],[ + define([local_aar_var_base], translit($1, [-a-z], [_A-Z])) + define([local_aar_var], concat(ANDROID_, local_aar_var_base, _AAR)) + local_aar_var="$ANDROID_SDK_ROOT/extras/$3/m2repository/$4/$1/$2/$1-$2.aar" + AC_MSG_CHECKING([for $1 AAR]) + if ! test -e "$local_aar_var" ; then + AC_MSG_ERROR([You must download the $1 AAR. Run the Android SDK tool and install the Android and Google Support Repositories under Extras. See https://developer.android.com/tools/extras/support-library.html for more info. (Looked for $local_aar_var)]) + fi + AC_SUBST(local_aar_var) + AC_MSG_RESULT([$local_aar_var]) + + if ! $PYTHON -m mozbuild.action.explode_aar --destdir=$MOZ_BUILD_ROOT/dist/exploded-aar $local_aar_var ; then + AC_MSG_ERROR([Could not explode $local_aar_var!]) + fi + + define([root], $MOZ_BUILD_ROOT/dist/exploded-aar/$1-$2/) + MOZ_ANDROID_AAR_COMPONENT(concat(local_aar_var, _LIB), concat(root, $1-$2-classes.jar), REQUIRED) + MOZ_ANDROID_AAR_COMPONENT(concat(local_aar_var, _RES), concat(root, res), REQUIRED) + MOZ_ANDROID_AAR_COMPONENT(concat(local_aar_var, _INTERNAL_LIB), concat(root, libs/$1-$2-internal_impl-$2.jar), $5) + MOZ_ANDROID_AAR_COMPONENT(concat(local_aar_var, _ASSETS), concat(root, assets), $6) +]) + +AC_DEFUN([MOZ_ANDROID_GOOGLE_PLAY_SERVICES], +[ + +if test -n "$MOZ_NATIVE_DEVICES" ; then + AC_SUBST(MOZ_NATIVE_DEVICES) + + MOZ_ANDROID_AAR(play-services-base, $ANDROID_GOOGLE_PLAY_SERVICES_VERSION, google, com/google/android/gms) + MOZ_ANDROID_AAR(play-services-basement, $ANDROID_GOOGLE_PLAY_SERVICES_VERSION, google, com/google/android/gms) + MOZ_ANDROID_AAR(play-services-cast, $ANDROID_GOOGLE_PLAY_SERVICES_VERSION, google, com/google/android/gms) + MOZ_ANDROID_AAR(mediarouter-v7, $ANDROID_SUPPORT_LIBRARY_VERSION, android, com/android/support, REQUIRED_INTERNAL_IMPL) +fi + +]) + +AC_DEFUN([MOZ_ANDROID_GOOGLE_CLOUD_MESSAGING], +[ + +if test -n "$MOZ_ANDROID_GCM" ; then + MOZ_ANDROID_AAR(play-services-base, $ANDROID_GOOGLE_PLAY_SERVICES_VERSION, google, com/google/android/gms) + MOZ_ANDROID_AAR(play-services-basement, $ANDROID_GOOGLE_PLAY_SERVICES_VERSION, google, com/google/android/gms) + MOZ_ANDROID_AAR(play-services-gcm, $ANDROID_GOOGLE_PLAY_SERVICES_VERSION, google, com/google/android/gms) + MOZ_ANDROID_AAR(play-services-measurement, $ANDROID_GOOGLE_PLAY_SERVICES_VERSION, google, com/google/android/gms) +fi + +]) + +AC_DEFUN([MOZ_ANDROID_INSTALL_TRACKING], +[ + +if test -n "$MOZ_INSTALL_TRACKING"; then + AC_SUBST(MOZ_INSTALL_TRACKING) + MOZ_ANDROID_AAR(play-services-ads, $ANDROID_GOOGLE_PLAY_SERVICES_VERSION, google, com/google/android/gms) + MOZ_ANDROID_AAR(play-services-basement, $ANDROID_GOOGLE_PLAY_SERVICES_VERSION, google, com/google/android/gms) +fi + +]) + +dnl Configure an Android SDK. +dnl Arg 1: target SDK version, like 23. +dnl Arg 2: list of build-tools versions, like "23.0.3 23.0.1". +AC_DEFUN([MOZ_ANDROID_SDK], +[ + +MOZ_ARG_WITH_STRING(android-sdk, +[ --with-android-sdk=DIR + location where the Android SDK can be found (like ~/.mozbuild/android-sdk-linux)], + android_sdk_root=$withval) + +android_sdk_root=${withval%/platforms/android-*} + +case "$target" in +*-android*|*-linuxandroid*) + if test -z "$android_sdk_root" ; then + AC_MSG_ERROR([You must specify --with-android-sdk=/path/to/sdk when targeting Android.]) + fi + + # We were given an old-style + # --with-android-sdk=/path/to/sdk/platforms/android-*. We could warn, but + # we'll get compliance by forcing the issue. + if test -e "$withval"/source.properties ; then + AC_MSG_ERROR([Including platforms/android-* in --with-android-sdk arguments is deprecated. Use --with-android-sdk=$android_sdk_root.]) + fi + + android_target_sdk=$1 + AC_MSG_CHECKING([for Android SDK platform version $android_target_sdk]) + android_sdk=$android_sdk_root/platforms/android-$android_target_sdk + if ! test -e "$android_sdk/source.properties" ; then + AC_MSG_ERROR([You must download Android SDK platform version $android_target_sdk. Try |mach bootstrap|. (Looked for $android_sdk)]) + fi + AC_MSG_RESULT([$android_sdk]) + + AC_MSG_CHECKING([for Android build-tools]) + android_build_tools_base="$android_sdk_root"/build-tools + android_build_tools_version="" + for version in $2; do + android_build_tools="$android_build_tools_base"/$version + if test -d "$android_build_tools" -a -f "$android_build_tools/aapt"; then + android_build_tools_version=$version + AC_MSG_RESULT([$android_build_tools]) + break + fi + done + if test "$android_build_tools_version" = ""; then + version=$(echo $2 | cut -d" " -f1) + AC_MSG_ERROR([You must install the Android build-tools version $version. Try |mach bootstrap|. (Looked for "$android_build_tools_base"/$version)]) + fi + + MOZ_PATH_PROG(ZIPALIGN, zipalign, :, [$android_build_tools]) + MOZ_PATH_PROG(DX, dx, :, [$android_build_tools]) + MOZ_PATH_PROG(AAPT, aapt, :, [$android_build_tools]) + MOZ_PATH_PROG(AIDL, aidl, :, [$android_build_tools]) + if test -z "$ZIPALIGN" -o "$ZIPALIGN" = ":"; then + AC_MSG_ERROR([The program zipalign was not found. Try |mach bootstrap|.]) + fi + if test -z "$DX" -o "$DX" = ":"; then + AC_MSG_ERROR([The program dx was not found. Try |mach bootstrap|.]) + fi + if test -z "$AAPT" -o "$AAPT" = ":"; then + AC_MSG_ERROR([The program aapt was not found. Try |mach bootstrap|.]) + fi + if test -z "$AIDL" -o "$AIDL" = ":"; then + AC_MSG_ERROR([The program aidl was not found. Try |mach bootstrap|.]) + fi + + android_platform_tools="$android_sdk_root"/platform-tools + AC_MSG_CHECKING([for Android platform-tools]) + if test -d "$android_platform_tools" -a -f "$android_platform_tools/adb"; then + AC_MSG_RESULT([$android_platform_tools]) + else + AC_MSG_ERROR([You must install the Android platform-tools. Try |mach bootstrap|. (Looked for $android_platform_tools)]) + fi + + MOZ_PATH_PROG(ADB, adb, :, [$android_platform_tools]) + if test -z "$ADB" -o "$ADB" = ":"; then + AC_MSG_ERROR([The program adb was not found. Try |mach bootstrap|.]) + fi + + android_tools="$android_sdk_root"/tools + AC_MSG_CHECKING([for Android tools]) + if test -d "$android_tools" -a -f "$android_tools/emulator"; then + AC_MSG_RESULT([$android_tools]) + else + AC_MSG_ERROR([You must install the Android tools. Try |mach bootstrap|. (Looked for $android_tools)]) + fi + + MOZ_PATH_PROG(EMULATOR, emulator, :, [$android_tools]) + if test -z "$EMULATOR" -o "$EMULATOR" = ":"; then + AC_MSG_ERROR([The program emulator was not found. Try |mach bootstrap|.]) + fi + + ANDROID_TARGET_SDK="${android_target_sdk}" + ANDROID_SDK="${android_sdk}" + ANDROID_SDK_ROOT="${android_sdk_root}" + ANDROID_TOOLS="${android_tools}" + ANDROID_BUILD_TOOLS_VERSION="$android_build_tools_version" + AC_DEFINE_UNQUOTED(ANDROID_TARGET_SDK,$ANDROID_TARGET_SDK) + AC_SUBST(ANDROID_TARGET_SDK) + AC_SUBST(ANDROID_SDK_ROOT) + AC_SUBST(ANDROID_SDK) + AC_SUBST(ANDROID_TOOLS) + AC_SUBST(ANDROID_BUILD_TOOLS_VERSION) + + MOZ_ANDROID_AAR(customtabs, $ANDROID_SUPPORT_LIBRARY_VERSION, android, com/android/support) + MOZ_ANDROID_AAR(appcompat-v7, $ANDROID_SUPPORT_LIBRARY_VERSION, android, com/android/support) + MOZ_ANDROID_AAR(support-vector-drawable, $ANDROID_SUPPORT_LIBRARY_VERSION, android, com/android/support) + MOZ_ANDROID_AAR(animated-vector-drawable, $ANDROID_SUPPORT_LIBRARY_VERSION, android, com/android/support) + MOZ_ANDROID_AAR(cardview-v7, $ANDROID_SUPPORT_LIBRARY_VERSION, android, com/android/support) + MOZ_ANDROID_AAR(design, $ANDROID_SUPPORT_LIBRARY_VERSION, android, com/android/support) + MOZ_ANDROID_AAR(recyclerview-v7, $ANDROID_SUPPORT_LIBRARY_VERSION, android, com/android/support) + MOZ_ANDROID_AAR(support-v4, $ANDROID_SUPPORT_LIBRARY_VERSION, android, com/android/support, REQUIRED_INTERNAL_IMPL) + MOZ_ANDROID_AAR(palette-v7, $ANDROID_SUPPORT_LIBRARY_VERSION, android, com/android/support) + + ANDROID_SUPPORT_ANNOTATIONS_JAR="$ANDROID_SDK_ROOT/extras/android/m2repository/com/android/support/support-annotations/$ANDROID_SUPPORT_LIBRARY_VERSION/support-annotations-$ANDROID_SUPPORT_LIBRARY_VERSION.jar" + AC_MSG_CHECKING([for support-annotations JAR]) + if ! test -e $ANDROID_SUPPORT_ANNOTATIONS_JAR ; then + AC_MSG_ERROR([You must download the support-annotations lib. Run the Android SDK tool and install the Android Support Repository under Extras. See https://developer.android.com/tools/extras/support-library.html for more info. (looked for $ANDROID_SUPPORT_ANNOTATIONS_JAR)]) + fi + AC_MSG_RESULT([$ANDROID_SUPPORT_ANNOTATIONS_JAR]) + AC_SUBST(ANDROID_SUPPORT_ANNOTATIONS_JAR) + ANDROID_SUPPORT_ANNOTATIONS_JAR_LIB=$ANDROID_SUPPORT_ANNOTATIONS_JAR + AC_SUBST(ANDROID_SUPPORT_ANNOTATIONS_JAR_LIB) + ;; +esac + +MOZ_ARG_WITH_STRING(android-min-sdk, +[ --with-android-min-sdk=[VER] Impose a minimum Firefox for Android SDK version], +[ MOZ_ANDROID_MIN_SDK_VERSION=$withval ]) + +MOZ_ARG_WITH_STRING(android-max-sdk, +[ --with-android-max-sdk=[VER] Impose a maximum Firefox for Android SDK version], +[ MOZ_ANDROID_MAX_SDK_VERSION=$withval ]) + +if test -n "$MOZ_ANDROID_MIN_SDK_VERSION"; then + if test -n "$MOZ_ANDROID_MAX_SDK_VERSION"; then + if test $MOZ_ANDROID_MAX_SDK_VERSION -lt $MOZ_ANDROID_MIN_SDK_VERSION ; then + AC_MSG_ERROR([--with-android-max-sdk must be at least the value of --with-android-min-sdk.]) + fi + fi + + if test $MOZ_ANDROID_MIN_SDK_VERSION -gt $ANDROID_TARGET_SDK ; then + AC_MSG_ERROR([--with-android-min-sdk is expected to be less than $ANDROID_TARGET_SDK]) + fi + + AC_DEFINE_UNQUOTED(MOZ_ANDROID_MIN_SDK_VERSION, $MOZ_ANDROID_MIN_SDK_VERSION) + AC_SUBST(MOZ_ANDROID_MIN_SDK_VERSION) +fi + +if test -n "$MOZ_ANDROID_MAX_SDK_VERSION"; then + AC_DEFINE_UNQUOTED(MOZ_ANDROID_MAX_SDK_VERSION, $MOZ_ANDROID_MAX_SDK_VERSION) + AC_SUBST(MOZ_ANDROID_MAX_SDK_VERSION) +fi + +]) |