]> git.lizzy.rs Git - dragonfireclient.git/blobdiff - build/android/Makefile
Move touchscreen input handling to base GUIModalMenu class
[dragonfireclient.git] / build / android / Makefile
index df1b01ae95e8c2c4a017cb33f09e472137035259..c4110aadd39d3b35055fc1c909415145725fdb42 100644 (file)
@@ -31,11 +31,12 @@ TARGET_HOST = arm-linux
 TARGET_ABI = armeabi-v7a
 TARGET_LIBDIR = armeabi-v7a
 TARGET_TOOLCHAIN = arm-linux-androideabi-
-TARGET_CFLAGS_ADDON = -mfloat-abi=softfp -mfpu=vfpv3 -O3 -D__ANDROID_API__=$(API)
+TARGET_CFLAGS_ADDON = -mfloat-abi=softfp -mfpu=vfpv3 -O3
 TARGET_CXXFLAGS_ADDON = $(TARGET_CFLAGS_ADDON)
 TARGET_ARCH = armv7
-CROSS_PREFIX = arm-linux-androideabi-
-COMPILER_VERSION = 4.9
+CROSS_CC = clang
+CROSS_CXX = clang++
+COMPILER_VERSION = clang
 HAVE_LEVELDB = 0
 
 ################################################################################
@@ -46,7 +47,8 @@ HAVE_LEVELDB = 0
 #TARGET_LIBDIR = mips
 #TARGET_TOOLCHAIN = mipsel-linux-android-
 #TARGET_ARCH = mips32
-#CROSS_PREFIX = mipsel-linux-android-
+#CROSS_CC = mipsel-linux-android-gcc
+#CROSS_CXX = mipsel-linux-android-g++
 #COMPILER_VERSION = 4.9
 #HAVE_LEVELDB = 0
 
@@ -57,9 +59,10 @@ HAVE_LEVELDB = 0
 #TARGET_ABI = x86
 #TARGET_LIBDIR = x86
 #TARGET_TOOLCHAIN = x86-
-#CROSS_PREFIX = i686-linux-android-
 #TARGET_ARCH = x86
-#COMPILER_VERSION = 4.9
+#CROSS_CC = clang
+#CROSS_CXX = clang++
+#COMPILER_VERSION = clang
 #HAVE_LEVELDB = 0
 
 ################################################################################
@@ -83,24 +86,24 @@ OGG_LIB = $(OGG_DIR)libs/$(TARGET_ABI)/libogg.so
 VORBIS_LIB = $(OGG_DIR)libs/$(TARGET_ABI)/libogg.so
 OGG_TIMESTAMP = $(OGG_DIR)timestamp
 OGG_TIMESTAMP_INT = $(ANDR_ROOT)/deps/ogg_timestamp
-OGG_URL_GIT = https://github.com/vincentjames501/libvorbis-libogg-android
+OGG_URL_GIT = https://gitlab.com/minetest/libvorbis-libogg-android
 
-IRRLICHT_REVISION = 5145
+IRRLICHT_REVISION = 5150
 IRRLICHT_DIR = $(ANDR_ROOT)/deps/irrlicht/
 IRRLICHT_LIB = $(IRRLICHT_DIR)lib/Android/libIrrlicht.a
 IRRLICHT_TIMESTAMP = $(IRRLICHT_DIR)timestamp
 IRRLICHT_TIMESTAMP_INT = $(ANDR_ROOT)/deps/irrlicht_timestamp
 IRRLICHT_URL_SVN = https://svn.code.sf.net/p/irrlicht/code/branches/ogl-es@$(IRRLICHT_REVISION)
 
-OPENSSL_VERSION = 1.0.2k
+OPENSSL_VERSION = 1.0.2n
 OPENSSL_BASEDIR = openssl-$(OPENSSL_VERSION)
 OPENSSL_DIR = $(ANDR_ROOT)/deps/$(OPENSSL_BASEDIR)/
-OPENSSL_LIB = $(OPENSSL_DIR)/libssl.so.1.0.0
+OPENSSL_LIB = $(OPENSSL_DIR)/libssl.a
 OPENSSL_TIMESTAMP = $(OPENSSL_DIR)timestamp
 OPENSSL_TIMESTAMP_INT = $(ANDR_ROOT)/deps/openssl_timestamp
 OPENSSL_URL = https://www.openssl.org/source/openssl-$(OPENSSL_VERSION).tar.gz
 
-CURL_VERSION = 7.54.0
+CURL_VERSION = 7.60.0
 CURL_DIR = $(ANDR_ROOT)/deps/curl-$(CURL_VERSION)
 CURL_LIB = $(CURL_DIR)/lib/.libs/libcurl.a
 CURL_TIMESTAMP = $(CURL_DIR)/timestamp
@@ -127,8 +130,8 @@ ICONV_TIMESTAMP = $(ICONV_DIR)timestamp
 ICONV_TIMESTAMP_INT = $(ANDR_ROOT)/deps/iconv_timestamp
 ICONV_URL_HTTP = https://ftp.gnu.org/pub/gnu/libiconv/libiconv-$(ICONV_VERSION).tar.gz
 
-SQLITE3_FOLDER = sqlite-amalgamation-3180000
-SQLITE3_URL = https://www.sqlite.org/2017/$(SQLITE3_FOLDER).zip
+SQLITE3_FOLDER = sqlite-amalgamation-3240000
+SQLITE3_URL = https://www.sqlite.org/2018/$(SQLITE3_FOLDER).zip
 
 ANDROID_SDK = $(shell grep '^sdk\.dir' local.properties | sed 's/^.*=[[:space:]]*//')
 ANDROID_NDK = $(shell grep '^ndk\.dir' local.properties | sed 's/^.*=[[:space:]]*//')
@@ -173,7 +176,7 @@ delconfig:
 
 local.properties:
        @echo "Please specify path of ANDROID NDK";                                \
-       echo "e.g. $$HOME/Android/ndk-r11c/";                                  \
+       echo "e.g. $$HOME/Android/Sdk/ndk-bundle/";                                \
        read ANDROID_NDK ;                                                         \
        if [ ! -d $$ANDROID_NDK ] ; then                                           \
                echo "$$ANDROID_NDK is not a valid folder";                            \
@@ -181,7 +184,7 @@ local.properties:
        fi;                                                                        \
        echo "ndk.dir = $$ANDROID_NDK" > local.properties;                         \
        echo "Please specify path of ANDROID SDK";                                 \
-       echo "e.g. $$HOME/Android/sdk/";                                       \
+       echo "e.g. $$HOME/Android/Sdk/";                                           \
        read SDKFLDR ;                                                             \
        if [ ! -d $$SDKFLDR ] ; then                                               \
                echo "$$SDKFLDR is not a valid folder";                                \
@@ -219,7 +222,10 @@ $(OPENAL_LIB): $(OPENAL_TIMESTAMP)
        cd ${OPENAL_DIR};                                                          \
        export APP_PLATFORM=${APP_PLATFORM};                                       \
        export TARGET_ABI=${TARGET_ABI};                                           \
-       ${ANDROID_NDK}/ndk-build NDEBUG=${NDEBUG}                                  \
+       export TARGET_CFLAGS_ADDON="${TARGET_CFLAGS_ADDON}";                       \
+       export TARGET_CXXFLAGS_ADDON="${TARGET_CXXFLAGS_ADDON}";                   \
+       export COMPILER_VERSION=${COMPILER_VERSION};                               \
+       ${ANDROID_NDK}/ndk-build                                                   \
                NDK_APPLICATION_MK=${ANDR_ROOT}/jni/Deps.mk || exit 1;                 \
        touch ${OPENAL_TIMESTAMP};                                                 \
        touch ${OPENAL_TIMESTAMP_INT};                                             \
@@ -262,8 +268,10 @@ $(OGG_LIB): $(OGG_TIMESTAMP)
        cd ${OGG_DIR};                                                             \
        export APP_PLATFORM=${APP_PLATFORM};                                       \
        export TARGET_ABI=${TARGET_ABI};                                           \
-       ${ANDROID_NDK}/ndk-build NDEBUG=${NDEBUG}                                  \
-               NDK_APPLICATION_MK=${ANDR_ROOT}/jni/Deps.mk || exit 1;                 \
+       ${ANDROID_NDK}/build/tools/make-standalone-toolchain.sh                    \
+               --toolchain=${TARGET_TOOLCHAIN}${COMPILER_VERSION}                     \
+               --platform=${APP_PLATFORM}                                             \
+               --install-dir=$${TOOLCHAIN};                                           \
        touch ${OGG_TIMESTAMP};                                                    \
        touch ${OGG_TIMESTAMP_INT};                                                \
        else                                                                       \
@@ -288,6 +296,7 @@ openssl_download :
                tar -xzf ${OPENSSL_BASEDIR}.tar.gz;                                    \
                cd ${OPENSSL_BASEDIR};                                                 \
                patch -p1 < ${ANDR_ROOT}/patches/openssl_arch.patch;                   \
+               sed -i 's/-mandroid //g' Configure;                                    \
        fi
 
 openssl : $(OPENSSL_LIB)
@@ -309,11 +318,15 @@ $(OPENSSL_LIB): $(OPENSSL_TIMESTAMP) $(GMP_LIB)
        ${ANDROID_NDK}/build/tools/make-standalone-toolchain.sh                    \
                --toolchain=${TARGET_TOOLCHAIN}${COMPILER_VERSION}                     \
                --platform=${APP_PLATFORM}                                             \
+               --stl=libc++                                                           \
                --install-dir=$${TOOLCHAIN};                                           \
        export PATH="$${TOOLCHAIN}/bin:$${PATH}";                                  \
-       CC=${CROSS_PREFIX}gcc ./Configure enable-gmp -DL_ENDIAN -I${GMP_DIR} -L${GMP_DIR}/usr/lib android-${TARGET_ARCH};\
-       CC=${CROSS_PREFIX}gcc ANDROID_DEV=/tmp/ndk-${TARGET_HOST} make depend;     \
-       CC=${CROSS_PREFIX}gcc ANDROID_DEV=/tmp/ndk-${TARGET_HOST} make build_libs; \
+       export CFLAGS="$${CFLAGS} ${TARGET_CFLAGS_ADDON}";                         \
+       export LDFLAGS="$${LDFLAGS} ${TARGET_LDFLAGS_ADDON}";                      \
+       CC=${CROSS_CC} ./Configure enable-gmp no-asm -DL_ENDIAN -I${GMP_DIR}       \
+               -L${GMP_DIR}/usr/lib android-${TARGET_ARCH} -D__ANDROID_API__=$(API);  \
+       CC=${CROSS_CC} ANDROID_DEV=/tmp/ndk-${TARGET_HOST} make depend;            \
+       CC=${CROSS_CC} ANDROID_DEV=/tmp/ndk-${TARGET_HOST} make build_libs;        \
        touch ${OPENSSL_TIMESTAMP};                                                \
        touch ${OPENSSL_TIMESTAMP_INT};                                            \
        $(RM) -rf $${TOOLCHAIN};                                                   \
@@ -355,17 +368,18 @@ $(LEVELDB_LIB): $(LEVELDB_TIMESTAMP)
        if [ $$REFRESH -ne 0 ] ; then                                              \
        echo "changed timestamp for leveldb detected building...";                 \
        cd deps/leveldb;                                                           \
-       export CROSS_PREFIX=${CROSS_PREFIX};                                       \
+       export CROSS_PREFIX=${TARGET_TOOLCHAIN};                                   \
        export TOOLCHAIN=/tmp/ndk-${TARGET_HOST}-leveldb;                          \
        ${ANDROID_NDK}/build/tools/make-standalone-toolchain.sh                    \
                --toolchain=${TARGET_TOOLCHAIN}${COMPILER_VERSION}                     \
                --platform=${APP_PLATFORM}                                             \
+               --stl=libc++                                                           \
                --install-dir=$${TOOLCHAIN};                                           \
        export PATH="$${TOOLCHAIN}/bin:$${PATH}";                                  \
-       export CC=${CROSS_PREFIX}gcc;                                              \
-       export CXX=${CROSS_PREFIX}g++;                                             \
+       export CC=${CROSS_CC};                                                     \
+       export CXX=${CROSS_CXX};                                                   \
        export CFLAGS="$${CFLAGS} ${TARGET_CFLAGS_ADDON}";                         \
-       export CPPFLAGS="$${CPPFLAGS} ${TARGET_CXXFLAGS_ADDON}";                     \
+       export CPPFLAGS="$${CPPFLAGS} ${TARGET_CXXFLAGS_ADDON}";                   \
        export LDFLAGS="$${LDFLAGS} ${TARGET_LDFLAGS_ADDON}";                      \
        export TARGET_OS=OS_ANDROID_CROSSCOMPILE;                                  \
        $(MAKE) || exit 1;                                                      \
@@ -378,7 +392,7 @@ $(LEVELDB_LIB): $(LEVELDB_TIMESTAMP)
 endif
 
 clean_leveldb :
-       $(RM) -rf deps/leveldb
+       ./gradlew cleanLevelDB
 
 $(FREETYPE_TIMESTAMP) : freetype_download
        @LAST_MODIF=$$(find ${FREETYPE_DIR} -type f -printf '%T@ %p\n' | sort -n | tail -1 | cut -f2- -d" "); \
@@ -413,7 +427,10 @@ $(FREETYPE_LIB) : $(FREETYPE_TIMESTAMP)
        cd ${FREETYPE_DIR}/Android/jni;                                            \
        export APP_PLATFORM=${APP_PLATFORM};                                       \
        export TARGET_ABI=${TARGET_ABI};                                           \
-       ${ANDROID_NDK}/ndk-build NDEBUG=${NDEBUG}                                  \
+       export TARGET_CFLAGS_ADDON="${TARGET_CFLAGS_ADDON}";                       \
+       export TARGET_CXXFLAGS_ADDON="${TARGET_CXXFLAGS_ADDON}";                   \
+       export COMPILER_VERSION=${COMPILER_VERSION};                               \
+       ${ANDROID_NDK}/ndk-build                                                   \
                NDK_APPLICATION_MK=${ANDR_ROOT}/jni/Deps.mk || exit 1;                 \
        touch ${FREETYPE_TIMESTAMP};                                               \
        touch ${FREETYPE_TIMESTAMP_INT};                                           \
@@ -422,7 +439,7 @@ $(FREETYPE_LIB) : $(FREETYPE_TIMESTAMP)
        fi
 
 clean_freetype :
-       $(RM) -rf ${FREETYPE_DIR}
+       ./gradlew cleanFreetype
 
 $(ICONV_TIMESTAMP) : iconv_download
        @LAST_MODIF=$$(find ${ICONV_DIR} -type f -printf '%T@ %p\n' | sort -n | tail -1 | cut -f2- -d" "); \
@@ -461,16 +478,17 @@ $(ICONV_LIB) : $(ICONV_TIMESTAMP)
        mkdir -p ${ICONV_DIR};                                                     \
        echo "changed timestamp for iconv detected building...";                   \
        cd ${ICONV_DIR};                                                           \
-       \
        export TOOLCHAIN=/tmp/ndk-${TARGET_HOST}-iconv;                            \
        ${ANDROID_NDK}/build/tools/make-standalone-toolchain.sh                    \
                --toolchain=${TARGET_TOOLCHAIN}${COMPILER_VERSION}                     \
                --platform=${APP_PLATFORM}                                             \
+               --stl=libc++                                                           \
                --install-dir=$${TOOLCHAIN};                                           \
        export PATH="$${TOOLCHAIN}/bin:$${PATH}";                                  \
        export CFLAGS="$${CFLAGS} ${TARGET_CFLAGS_ADDON}";                         \
-       export CC=${CROSS_PREFIX}gcc;                                              \
-       export CXX=${CROSS_PREFIX}g++;                                             \
+       export LDFLAGS="$${LDFLAGS} ${TARGET_LDFLAGS_ADDON} -lstdc++";             \
+       export CC=${CROSS_CC};                                                     \
+       export CXX=${CROSS_CXX};                                                   \
        export TARGET_OS=OS_ANDROID_CROSSCOMPILE;                                  \
        ./configure --host=${TARGET_HOST} || exit 1;                               \
        sed -i 's/LIBICONV_VERSION_INFO) /LIBICONV_VERSION_INFO) -avoid-version /g' lib/Makefile; \
@@ -484,7 +502,7 @@ $(ICONV_LIB) : $(ICONV_TIMESTAMP)
        fi
 
 clean_iconv :
-       $(RM) -rf ${ICONV_DIR}
+       ./gradlew cleanIconv
 
 #Note: Texturehack patch is required for gpu's not supporting color format
 #      correctly. Known bad GPU:
@@ -529,8 +547,11 @@ $(IRRLICHT_LIB): $(IRRLICHT_TIMESTAMP) $(FREETYPE_LIB)
        cd deps/irrlicht/source/Irrlicht/Android;                                  \
        export APP_PLATFORM=${APP_PLATFORM};                                       \
        export TARGET_ABI=${TARGET_ABI};                                           \
-       ${ANDROID_NDK}/ndk-build NDEBUG=${NDEBUG}                                  \
-               NDK_APPLICATION_MK=${ANDR_ROOT}/jni/Irrlicht.mk || exit 1;             \
+       export TARGET_CFLAGS_ADDON="${TARGET_CFLAGS_ADDON}";                       \
+       export TARGET_CXXFLAGS_ADDON="${TARGET_CXXFLAGS_ADDON}";                   \
+       export COMPILER_VERSION=${COMPILER_VERSION};                               \
+       ${ANDROID_NDK}/ndk-build                                                   \
+               NDK_APPLICATION_MK=${ANDR_ROOT}/jni/Deps.mk || exit 1;                 \
        touch ${IRRLICHT_TIMESTAMP};                                               \
        touch ${IRRLICHT_TIMESTAMP_INT};                                           \
        else                                                                       \
@@ -538,7 +559,7 @@ $(IRRLICHT_LIB): $(IRRLICHT_TIMESTAMP) $(FREETYPE_LIB)
        fi
 
 clean_irrlicht :
-       $(RM) -rf deps/irrlicht
+       ./gradlew cleanIrrlicht
 
 $(CURL_TIMESTAMP) : curl_download
        @LAST_MODIF=$$(find ${CURL_DIR} -type f -printf '%T@ %p\n' | sort -n | tail -1 | cut -f2- -d" "); \
@@ -574,15 +595,16 @@ $(CURL_LIB): $(CURL_TIMESTAMP) $(OPENSSL_LIB)
        mkdir -p ${CURL_DIR};                                                      \
        echo "changed timestamp for curl detected building...";                    \
        cd deps/curl-${CURL_VERSION};                                              \
-       export CROSS_PREFIX=${CROSS_PREFIX};                                       \
+       export CROSS_PREFIX=${TARGET_TOOLCHAIN};                                   \
        export TOOLCHAIN=/tmp/ndk-${TARGET_HOST}-curl;                             \
        ${ANDROID_NDK}/build/tools/make-standalone-toolchain.sh                    \
                --toolchain=${TARGET_TOOLCHAIN}${COMPILER_VERSION}                     \
                --platform=${APP_PLATFORM}                                             \
+               --stl=libc++                                                           \
                --install-dir=$${TOOLCHAIN};                                           \
        export PATH="$${TOOLCHAIN}/bin:$${PATH}";                                  \
-       export CC=${CROSS_PREFIX}gcc;                                              \
-       export CXX=${CROSS_PREFIX}g++;                                             \
+       export CC=${CROSS_CC};                                                     \
+       export CXX=${CROSS_CXX};                                                   \
        export TARGET_OS=OS_ANDROID_CROSSCOMPILE;                                  \
        export CPPFLAGS="$${CPPFLAGS} -I${OPENSSL_DIR}/include ${TARGET_CFLAGS_ADDON}"; \
        export CFLAGS="$${CFLAGS} ${TARGET_CFLAGS_ADDON}";                         \
@@ -597,8 +619,7 @@ $(CURL_LIB): $(CURL_TIMESTAMP) $(OPENSSL_LIB)
        fi
 
 clean_curl :
-       $(RM) -rf deps/curl-${CURL_VERSION}                                        \
-       $(RM) -f deps/curl
+       ./gradlew cleanCURL
 
 $(GMP_TIMESTAMP) : gmp_download
        @LAST_MODIF=$$(find ${GMP_DIR} -type f -printf '%T@ %p\n' | sort -n | tail -1 | cut -f2- -d" "); \
@@ -634,15 +655,17 @@ $(GMP_LIB): $(GMP_TIMESTAMP)
        mkdir -p ${GMP_DIR};                                                       \
        echo "changed timestamp for gmp detected building...";                     \
        cd deps/gmp-${GMP_VERSION};                                                \
-       export CROSS_PREFIX=${CROSS_PREFIX};                                       \
+       export CROSS_PREFIX=${TARGET_TOOLCHAIN};                                   \
        export TOOLCHAIN=/tmp/ndk-${TARGET_HOST}-gmp;                              \
        ${ANDROID_NDK}/build/tools/make-standalone-toolchain.sh                    \
                --toolchain=${TARGET_TOOLCHAIN}${COMPILER_VERSION}                     \
                --platform=${APP_PLATFORM}                                             \
+               --stl=libc++                                                           \
                --install-dir=$${TOOLCHAIN};                                           \
        export PATH="$${TOOLCHAIN}/bin:$${PATH}";                                  \
-       export CC=${CROSS_PREFIX}gcc;                                              \
-       export CXX=${CROSS_PREFIX}g++;                                             \
+       export CC=${CROSS_CC};                                                     \
+       export CXX=${CROSS_CXX};                                                   \
+       export LDFLAGS="$${LDFLAGS} ${TARGET_LDFLAGS_ADDON}";                      \
        export LIBGMP_LDFLAGS="-avoid-version";                                    \
        export LIBGMPXX_LDFLAGS="-avoid-version";                                  \
        ./configure --disable-static --host=${TARGET_HOST} --prefix=/usr;          \
@@ -655,8 +678,7 @@ $(GMP_LIB): $(GMP_TIMESTAMP)
        fi
 
 clean_gmp:
-       $(RM) -rf deps/gmp-${GMP_VERSION}                                          \
-       $(RM) -f deps/gmp
+       ./gradlew cleanGMP
 
 sqlite3_download: deps/${SQLITE3_FOLDER}/sqlite3.c
 
@@ -668,8 +690,7 @@ deps/${SQLITE3_FOLDER}/sqlite3.c :
        cd ${SQLITE3_FOLDER};
 
 clean_sqlite3:
-       cd deps && $(RM) -rf ${SQLITE3_FOLDER} && $(RM) -f ${SQLITE3_FOLDER}.zip && \
-       $(RM) -f sqlite
+       ./gradlew cleanSQLite3
 
 $(ASSETS_TIMESTAMP) : $(IRRLICHT_LIB)
        @mkdir -p ${ANDR_ROOT}/deps;                                                \
@@ -713,7 +734,7 @@ assets : $(ASSETS_TIMESTAMP)
        $(MAKE) clean_assets;                                                      \
        mkdir -p ${APP_ROOT}/assets/Minetest;                                      \
        cp ${PROJ_ROOT}/minetest.conf.example ${APP_ROOT}/assets/Minetest;         \
-       cp ${PROJ_ROOT}/README.txt ${APP_ROOT}/assets/Minetest;                    \
+       cp ${PROJ_ROOT}/README.md ${APP_ROOT}/assets/Minetest;                     \
        cp -r ${PROJ_ROOT}/builtin ${APP_ROOT}/assets/Minetest;                    \
        mkdir -p ${APP_ROOT}/assets/Minetest/client;                                  \
        cp -r ${PROJ_ROOT}/client/shaders ${APP_ROOT}/assets/Minetest/client;      \
@@ -747,7 +768,7 @@ assets : $(ASSETS_TIMESTAMP)
        fi
 
 clean_assets :
-       @$(RM) -r assets
+       ./gradlew cleanAssets
 
 apk: local.properties assets $(ICONV_LIB) $(IRRLICHT_LIB) $(CURL_LIB) $(GMP_LIB) $(LEVELDB_TARGET)       \
        $(OPENAL_LIB) $(OGG_LIB) prep_srcdir $(ANDR_ROOT)/jni/src/android_version.h    \
@@ -756,44 +777,44 @@ apk: local.properties assets $(ICONV_LIB) $(IRRLICHT_LIB) $(CURL_LIB) $(GMP_LIB)
        export HAVE_LEVELDB=${HAVE_LEVELDB};                                       \
        export APP_PLATFORM=${APP_PLATFORM};                                       \
        export TARGET_ABI=${TARGET_ABI};                                           \
+       export TARGET_CFLAGS_ADDON="${TARGET_CFLAGS_ADDON}";                       \
+       export TARGET_CXXFLAGS_ADDON="${TARGET_CXXFLAGS_ADDON}";                   \
+       export COMPILER_VERSION=${COMPILER_VERSION};                               \
+       export GPROF=${GPROF};                                                     \
        ${ANDROID_NDK}/ndk-build || exit 1;                                        \
        if [ ! -e ${APP_ROOT}/jniLibs ]; then                                      \
-               ln -s ${ANDR_ROOT}/libs ${APP_ROOT}/jniLibs || exit 1;                 \
+               ln -s ${ANDR_ROOT}/libs ${APP_ROOT}/jniLibs || exit 1;             \
        fi;                                                                        \
        export VERSION_STR="${VERSION_MAJOR}.${VERSION_MINOR}.${VERSION_PATCH}" && \
        export BUILD_TYPE_C=$$(echo "$${BUILD_TYPE}" | sed 's/./\U&/') &&          \
        ./gradlew assemble$$BUILD_TYPE_C &&                                           \
-       echo "APK stored at: build/outputs/apk/Minetest-$$BUILD_TYPE.apk" &&       \
+       echo "APK stored at: build/outputs/apk/$$BUILD_TYPE/Minetest-$$BUILD_TYPE.apk" && \
        echo "You can install it with \`make install_$$BUILD_TYPE\`"
 
 # These Intentionally doesn't depend on their respective build steps,
 # because it takes a while to verify that everything's up-to-date.
 install_debug:
-       ${ANDROID_SDK}/platform-tools/adb install -r build/outputs/apk/Minetest-debug.apk
+       ${ANDROID_SDK}/platform-tools/adb install -r build/outputs/apk/debug/Minetest-debug.apk
 
 install_release:
-       ${ANDROID_SDK}/platform-tools/adb install -r build/outputs/apk/Minetest-release.apk
+       ${ANDROID_SDK}/platform-tools/adb install -r build/outputs/apk/release/Minetest-release.apk
 
 prep_srcdir :
        @if [ ! -e ${ANDR_ROOT}/jni/src ]; then                                    \
-               ln -s ${PROJ_ROOT}/src ${ANDR_ROOT}/jni/src;                       \
+               ln -s ${PROJ_ROOT}/src ${ANDR_ROOT}/jni/src;                           \
        fi;                                                                        \
        if [ ! -e ${ANDR_ROOT}/jni/lib ]; then                                     \
-               ln -s ${PROJ_ROOT}/lib ${ANDR_ROOT}/jni/lib;                       \
+               ln -s ${PROJ_ROOT}/lib ${ANDR_ROOT}/jni/lib;                           \
        fi
 
 clean_apk :
        ./gradlew clean
 
 clean_all :
-       @$(MAKE) clean_apk;                                                        \
-       $(MAKE) clean_assets clean_iconv clean_irrlicht clean_leveldb clean_curl   \
-       clean_openssl clean_openal clean_ogg clean_gmp;                            \
-       sleep 1;                                                                   \
-       $(RM) -r gen libs obj deps bin Debug and_env
+       ./gradlew cleanAll
 
 $(ANDR_ROOT)/jni/src/android_version_githash.h : prep_srcdir
-       @export VERSION_FILE=${ANDR_ROOT}/jni/src/android_version_githash.h;        \
+       @export VERSION_FILE=${ANDR_ROOT}/jni/src/android_version_githash.h;       \
        export VERSION_FILE_NEW=$${VERSION_FILE}.new;                              \
        {                                                                          \
        echo "#ifndef ANDROID_MT_VERSION_GITHASH_H";                               \