]> git.lizzy.rs Git - minetest.git/blobdiff - build/android/Makefile
Android build fixes for c++11
[minetest.git] / build / android / Makefile
index 50164d95f6e99ad53e9e76078a2b47cb7dcb9a96..1457a7efd42abcf26333959b759f8a32a0d0475b 100644 (file)
@@ -6,44 +6,24 @@ OS := $(shell uname)
 # GPROF = 1
 
 # build for build platform
-APP_PLATFORM = android-9
+API = 14
+APP_PLATFORM = android-$(API)
 
-# paths used for timestaps, dependencys, tree config and libs
-PATHCFGFILE = path.cfg
-
-ROOT = $(shell pwd)
+ANDR_ROOT = $(shell pwd)
+PROJ_ROOT = $(shell realpath $(ANDR_ROOT)/../..)
+APP_ROOT = $(ANDR_ROOT)/src/main
 
 GAMES_TO_COPY = minetest_game
 MODS_TO_COPY =
 
 
-VERSION_MAJOR := $(shell cat $(ROOT)/../../CMakeLists.txt | \
+VERSION_MAJOR := $(shell cat $(PROJ_ROOT)/CMakeLists.txt | \
        grep ^set\(VERSION_MAJOR\ | sed 's/)/ /' | cut -f2 -d' ')
-VERSION_MINOR := $(shell cat $(ROOT)/../../CMakeLists.txt | \
+VERSION_MINOR := $(shell cat $(PROJ_ROOT)/CMakeLists.txt | \
        grep ^set\(VERSION_MINOR\ | sed 's/)/ /' | cut -f2 -d' ')
-VERSION_PATCH := $(shell cat $(ROOT)/../../CMakeLists.txt | \
+VERSION_PATCH := $(shell cat $(PROJ_ROOT)/CMakeLists.txt | \
        grep ^set\(VERSION_PATCH\ | sed 's/)/ /' | cut -f2 -d' ')
 
-################################################################################
-# Android Version code
-# Increase for each build!
-################################################################################
-# Play Store actual version (16/03/15): 11
-ANDROID_VERSION_CODE = 13
-
-################################################################################
-# toolchain config for arm old processors
-################################################################################
-#TARGET_HOST = arm-linux
-#TARGET_ABI = armeabi
-#TARGET_LIBDIR = armeabi
-#TARGET_TOOLCHAIN = arm-linux-androideabi-
-#TARGET_CFLAGS_ADDON = -mfloat-abi=softfp -mfpu=vfp
-#TARGET_ARCH = arm
-#CROSS_PREFIX = arm-linux-androideabi-
-#COMPILER_VERSION = 4.8
-#HAVE_LEVELDB = 1
-
 ################################################################################
 # toolchain config for arm new processors
 ################################################################################
@@ -51,12 +31,13 @@ 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
+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.8
-HAVE_LEVELDB = 1
+CROSS_CC = clang
+CROSS_CXX = clang++
+COMPILER_VERSION = clang
+HAVE_LEVELDB = 0
 
 ################################################################################
 # toolchain config for little endian mips
@@ -66,8 +47,9 @@ HAVE_LEVELDB = 1
 #TARGET_LIBDIR = mips
 #TARGET_TOOLCHAIN = mipsel-linux-android-
 #TARGET_ARCH = mips32
-#CROSS_PREFIX = mipsel-linux-android-
-#COMPILER_VERSION = 4.8
+#CROSS_CC = mipsel-linux-android-gcc
+#CROSS_CXX = mipsel-linux-android-g++
+#COMPILER_VERSION = 4.9
 #HAVE_LEVELDB = 0
 
 ################################################################################
@@ -77,79 +59,82 @@ HAVE_LEVELDB = 1
 #TARGET_ABI = x86
 #TARGET_LIBDIR = x86
 #TARGET_TOOLCHAIN = x86-
-#CROSS_PREFIX = i686-linux-android-
 #TARGET_ARCH = x86
-#COMPILER_VERSION = 4.8
-#HAVE_LEVELDB = 1
+#CROSS_CC = clang
+#CROSS_CXX = clang++
+#COMPILER_VERSION = clang
+#HAVE_LEVELDB = 0
 
 ################################################################################
 ASSETS_TIMESTAMP = deps/assets_timestamp
 
-LEVELDB_DIR = $(ROOT)/deps/leveldb/
+LEVELDB_DIR = $(ANDR_ROOT)/deps/leveldb/
 LEVELDB_LIB = $(LEVELDB_DIR)libleveldb.a
 LEVELDB_TIMESTAMP = $(LEVELDB_DIR)/timestamp
-LEVELDB_TIMESTAMP_INT = $(ROOT)/deps/leveldb_timestamp
+LEVELDB_TIMESTAMP_INT = $(ANDR_ROOT)/deps/leveldb_timestamp
 LEVELDB_URL_GIT = https://github.com/google/leveldb
+LEVELDB_COMMIT = 2d0320a458d0e6a20fff46d5f80b18bfdcce7018
 
-OPENAL_DIR = $(ROOT)/deps/openal-soft/
+OPENAL_DIR = $(ANDR_ROOT)/deps/openal-soft/
 OPENAL_LIB = $(OPENAL_DIR)libs/$(TARGET_ABI)/libopenal.so
 OPENAL_TIMESTAMP = $(OPENAL_DIR)/timestamp
-OPENAL_TIMESTAMP_INT = $(ROOT)/deps/openal_timestamp
+OPENAL_TIMESTAMP_INT = $(ANDR_ROOT)/deps/openal_timestamp
 OPENAL_URL_GIT = https://github.com/apportable/openal-soft
 
-OGG_DIR = $(ROOT)/deps/libvorbis-libogg-android/
+OGG_DIR = $(ANDR_ROOT)/deps/libvorbis-libogg-android/
 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 = $(ROOT)/deps/ogg_timestamp
+OGG_TIMESTAMP_INT = $(ANDR_ROOT)/deps/ogg_timestamp
 OGG_URL_GIT = https://github.com/vincentjames501/libvorbis-libogg-android
 
-IRRLICHT_REVISION = 5122
-IRRLICHT_DIR = $(ROOT)/deps/irrlicht/
+IRRLICHT_REVISION = 5145
+IRRLICHT_DIR = $(ANDR_ROOT)/deps/irrlicht/
 IRRLICHT_LIB = $(IRRLICHT_DIR)lib/Android/libIrrlicht.a
 IRRLICHT_TIMESTAMP = $(IRRLICHT_DIR)timestamp
-IRRLICHT_TIMESTAMP_INT = $(ROOT)/deps/irrlicht_timestamp
-IRRLICHT_URL_SVN = http://svn.code.sf.net/p/irrlicht/code/branches/ogl-es@$(IRRLICHT_REVISION)
+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.1p
+OPENSSL_VERSION = 1.0.2k
 OPENSSL_BASEDIR = openssl-$(OPENSSL_VERSION)
-OPENSSL_DIR = $(ROOT)/deps/$(OPENSSL_BASEDIR)/
-OPENSSL_LIB = $(OPENSSL_DIR)/libssl.so.1.0.0
+OPENSSL_DIR = $(ANDR_ROOT)/deps/$(OPENSSL_BASEDIR)/
+OPENSSL_LIB = $(OPENSSL_DIR)/libssl.a
 OPENSSL_TIMESTAMP = $(OPENSSL_DIR)timestamp
-OPENSSL_TIMESTAMP_INT = $(ROOT)/deps/openssl_timestamp
-OPENSSL_URL = http://www.openssl.org/source/openssl-$(OPENSSL_VERSION).tar.gz
+OPENSSL_TIMESTAMP_INT = $(ANDR_ROOT)/deps/openssl_timestamp
+OPENSSL_URL = https://www.openssl.org/source/openssl-$(OPENSSL_VERSION).tar.gz
 
-CURL_VERSION = 7.45.0
-CURL_DIR = $(ROOT)/deps/curl-$(CURL_VERSION)
+CURL_VERSION = 7.54.0
+CURL_DIR = $(ANDR_ROOT)/deps/curl-$(CURL_VERSION)
 CURL_LIB = $(CURL_DIR)/lib/.libs/libcurl.a
 CURL_TIMESTAMP = $(CURL_DIR)/timestamp
-CURL_TIMESTAMP_INT = $(ROOT)/deps/curl_timestamp
-CURL_URL_HTTP = http://curl.haxx.se/download/curl-${CURL_VERSION}.tar.bz2
+CURL_TIMESTAMP_INT = $(ANDR_ROOT)/deps/curl_timestamp
+CURL_URL_HTTP = https://curl.haxx.se/download/curl-${CURL_VERSION}.tar.bz2
 
-GMP_VERSION = 6.1.0
-GMP_DIR = $(ROOT)/deps/gmp-$(GMP_VERSION)
+GMP_VERSION = 6.1.2
+GMP_DIR = $(ANDR_ROOT)/deps/gmp-$(GMP_VERSION)
 GMP_LIB = $(GMP_DIR)/usr/lib/libgmp.so
 GMP_TIMESTAMP = $(GMP_DIR)/timestamp
-GMP_TIMESTAMP_INT = $(ROOT)/deps/gmp_timestamp
+GMP_TIMESTAMP_INT = $(ANDR_ROOT)/deps/gmp_timestamp
 GMP_URL_HTTP = https://gmplib.org/download/gmp/gmp-$(GMP_VERSION).tar.bz2
 
-FREETYPE_DIR = $(ROOT)/deps/freetype2-android/
+FREETYPE_DIR = $(ANDR_ROOT)/deps/freetype2-android/
 FREETYPE_LIB = $(FREETYPE_DIR)/Android/obj/local/$(TARGET_ABI)/libfreetype2-static.a
 FREETYPE_TIMESTAMP = $(FREETYPE_DIR)timestamp
-FREETYPE_TIMESTAMP_INT = $(ROOT)/deps/freetype_timestamp
+FREETYPE_TIMESTAMP_INT = $(ANDR_ROOT)/deps/freetype_timestamp
 FREETYPE_URL_GIT = https://github.com/cdave1/freetype2-android
 
 ICONV_VERSION = 1.14
-ICONV_DIR = $(ROOT)/deps/libiconv/
+ICONV_DIR = $(ANDR_ROOT)/deps/libiconv/
 ICONV_LIB = $(ICONV_DIR)/lib/.libs/libiconv.so
 ICONV_TIMESTAMP = $(ICONV_DIR)timestamp
-ICONV_TIMESTAMP_INT = $(ROOT)/deps/iconv_timestamp
-ICONV_URL_HTTP = http://ftp.gnu.org/pub/gnu/libiconv/libiconv-$(ICONV_VERSION).tar.gz
+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-3090200
-SQLITE3_URL = http://www.sqlite.org/2015/$(SQLITE3_FOLDER).zip
+SQLITE3_FOLDER = sqlite-amalgamation-3180000
+SQLITE3_URL = https://www.sqlite.org/2017/$(SQLITE3_FOLDER).zip
 
--include $(PATHCFGFILE)
+ANDROID_SDK = $(shell grep '^sdk\.dir' local.properties | sed 's/^.*=[[:space:]]*//')
+ANDROID_NDK = $(shell grep '^ndk\.dir' local.properties | sed 's/^.*=[[:space:]]*//')
 
 #use interim target variable to switch leveldb on or off
 ifeq ($(HAVE_LEVELDB),1)
@@ -163,54 +148,50 @@ endif
        freetype_download clean_freetype freetype \
        apk clean_apk \
        clean_all clean prep_srcdir \
-       install_debug install envpaths all \
-       manifest clean_manifest\
+       install_debug install_release envpaths all \
        $(ASSETS_TIMESTAMP) $(LEVELDB_TIMESTAMP) \
        $(OPENAL_TIMESTAMP) $(OGG_TIMESTAMP) \
        $(IRRLICHT_TIMESTAMP) $(CURL_TIMESTAMP) \
        $(OPENSSL_TIMESTAMP) \
-       $(ROOT)/jni/src/android_version.h \
-       $(ROOT)/jni/src/android_version_githash.h
+       $(ANDR_ROOT)/jni/src/android_version.h \
+       $(ANDR_ROOT)/jni/src/android_version_githash.h
 
-debug : $(PATHCFGFILE)
+debug : local.properties
        export NDEBUG=;                                                            \
        export BUILD_TYPE=debug;                                                   \
        $(MAKE) apk
 
 all : debug release
 
-release : $(PATHCFGFILE)
+release : local.properties
        @export NDEBUG=1;                                                          \
        export BUILD_TYPE=release;                                                 \
        $(MAKE) apk
 
 reconfig: delconfig
-       @$(MAKE) $(PATHCFGFILE)
+       @$(MAKE) local.properties
 
-delconfig :
-       $(RM) ${PATHCFGFILE}
+delconfig:
+       $(RM) local.properties
 
-$(PATHCFGFILE) :
+local.properties:
        @echo "Please specify path of ANDROID NDK";                                \
-       echo "e.g. /home/user/android-ndk-r9c/";                                   \
+       echo "e.g. $$HOME/Android/Sdk/ndk-bundle/";                                \
        read ANDROID_NDK ;                                                         \
        if [ ! -d $$ANDROID_NDK ] ; then                                           \
                echo "$$ANDROID_NDK is not a valid folder";                            \
                exit 1;                                                                \
        fi;                                                                        \
-       echo "ANDROID_NDK = $$ANDROID_NDK" > ${PATHCFGFILE};                       \
-       echo "NDK_MODULE_PATH = $$ANDROID_NDK/toolchains" >> ${PATHCFGFILE};            \
-       echo "+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++";\
-       echo "+ Note: NDK_MODULE_PATH is set to $$ANDROID_NDK/toolchains";              \
-       echo "+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++";\
+       echo "ndk.dir = $$ANDROID_NDK" > local.properties;                         \
        echo "Please specify path of ANDROID SDK";                                 \
-       echo "e.g. /home/user/adt-bundle-linux-x86_64-20131030/sdk/";              \
+       echo "e.g. $$HOME/Android/Sdk/";                                           \
        read SDKFLDR ;                                                             \
        if [ ! -d $$SDKFLDR ] ; then                                               \
                echo "$$SDKFLDR is not a valid folder";                                \
                exit 1;                                                                \
        fi;                                                                        \
-       echo "SDKFOLDER = $$SDKFLDR" >> ${PATHCFGFILE};
+       echo "sdk.dir = $$SDKFLDR" >> local.properties;
+
 
 $(OPENAL_TIMESTAMP) : openal_download
        @LAST_MODIF=$$(find ${OPENAL_DIR} -type f -printf '%T@ %p\n' | sort -n | tail -1 | cut -f2- -d" "); \
@@ -221,8 +202,8 @@ $(OPENAL_TIMESTAMP) : openal_download
 openal_download :
        @if [ ! -d ${OPENAL_DIR} ] ; then                                          \
                echo "openal sources missing, downloading...";                         \
-               mkdir -p ${ROOT}/deps;                                                 \
-               cd ${ROOT}/deps ;                                                      \
+               mkdir -p ${ANDR_ROOT}/deps;                                            \
+               cd ${ANDR_ROOT}/deps ;                                                 \
                git clone ${OPENAL_URL_GIT} || exit 1;                                 \
        fi
 
@@ -237,14 +218,15 @@ $(OPENAL_LIB): $(OPENAL_TIMESTAMP)
                REFRESH=1;                                                             \
        fi;                                                                        \
        if [ $$REFRESH -ne 0 ] ; then                                              \
-       export PATH=$$PATH:${SDKFOLDER}/platform-tools:${ANDROID_NDK};             \
        echo "changed timestamp for openal detected building...";                  \
        cd ${OPENAL_DIR};                                                          \
-       ndk-build NDEBUG=${NDEBUG} NDK_MODULE_PATH=${NDK_MODULE_PATH}              \
-       APP_ABI=${TARGET_ABI} TARGET_ARCH_ABI=${TARGET_ABI}                        \
-       APP_PLATFORM=${APP_PLATFORM} TARGET_CFLAGS+="${TARGET_CFLAGS_ADDON}"       \
-       TARGET_LDFLAGS+="${TARGET_LDFLAGS_ADDON}"                                  \
-       TARGET_CXXFLAGS+="${TARGET_CXXFLAGS_ADDON}" || exit 1;                     \
+       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};                               \
+       ${ANDROID_NDK}/ndk-build                                                   \
+               NDK_APPLICATION_MK=${ANDR_ROOT}/jni/Deps.mk || exit 1;                 \
        touch ${OPENAL_TIMESTAMP};                                                 \
        touch ${OPENAL_TIMESTAMP_INT};                                             \
        else                                                                       \
@@ -263,12 +245,11 @@ $(OGG_TIMESTAMP) : ogg_download
 ogg_download :
        @if [ ! -d ${OGG_DIR} ] ; then                                             \
                echo "ogg sources missing, downloading...";                            \
-               mkdir -p ${ROOT}/deps;                                                 \
-               cd ${ROOT}/deps ;                                                      \
+               mkdir -p ${ANDR_ROOT}/deps;                                            \
+               cd ${ANDR_ROOT}/deps ;                                                 \
                git clone ${OGG_URL_GIT}|| exit 1;                                     \
                cd libvorbis-libogg-android ;                                          \
-               patch -p1 < ../../libvorbis-libogg-fpu.patch || exit 1;                \
-               sed -i 's-:-?-' jni/Application.mk;                                    \
+               patch -p1 < ${ANDR_ROOT}/patches/libvorbis-libogg-fpu.patch || exit 1; \
        fi
 
 ogg : $(OGG_LIB)
@@ -283,14 +264,15 @@ $(OGG_LIB): $(OGG_TIMESTAMP)
                REFRESH=1;                                                             \
        fi;                                                                        \
        if [ $$REFRESH -ne 0 ] ; then                                              \
-       export PATH=$$PATH:${SDKFOLDER}/platform-tools:${ANDROID_NDK};             \
        echo "changed timestamp for ogg detected building...";                     \
        cd ${OGG_DIR};                                                             \
-       ndk-build NDEBUG=${NDEBUG} NDK_MODULE_PATH=${NDK_MODULE_PATH}              \
-       APP_ABI=${TARGET_ABI} APP_PLATFORM=${APP_PLATFORM}                         \
-       TARGET_CFLAGS+="${TARGET_CFLAGS_ADDON}"                                    \
-       TARGET_LDFLAGS+="${TARGET_LDFLAGS_ADDON}"                                  \
-       TARGET_CXXFLAGS+="${TARGET_CXXFLAGS_ADDON}" || exit 1;                     \
+       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};                               \
+       ${ANDROID_NDK}/ndk-build                                                   \
+               NDK_APPLICATION_MK=${ANDR_ROOT}/jni/Deps.mk || exit 1;                 \
        touch ${OGG_TIMESTAMP};                                                    \
        touch ${OGG_TIMESTAMP_INT};                                                \
        else                                                                       \
@@ -309,17 +291,18 @@ $(OPENSSL_TIMESTAMP) : openssl_download
 openssl_download :
        @if [ ! -d ${OPENSSL_DIR} ] ; then                                         \
                echo "openssl sources missing, downloading...";                        \
-               mkdir -p ${ROOT}/deps;                                                 \
-               cd ${ROOT}/deps ;                                                      \
+               mkdir -p ${ANDR_ROOT}/deps;                                            \
+               cd ${ANDR_ROOT}/deps ;                                                 \
                wget ${OPENSSL_URL} || exit 1;                                         \
                tar -xzf ${OPENSSL_BASEDIR}.tar.gz;                                    \
                cd ${OPENSSL_BASEDIR};                                                 \
-               patch -p1 < ../../openssl_arch.patch;                                  \
+               patch -p1 < ${ANDR_ROOT}/patches/openssl_arch.patch;                   \
+               sed -i 's/-mandroid //g' Configure;                                    \
        fi
 
 openssl : $(OPENSSL_LIB)
 
-$(OPENSSL_LIB): $(OPENSSL_TIMESTAMP)
+$(OPENSSL_LIB): $(OPENSSL_TIMESTAMP) $(GMP_LIB)
        @REFRESH=0;                                                                \
        if [ ! -e ${OPENSSL_TIMESTAMP_INT} ] ; then                                \
                echo "${OPENSSL_TIMESTAMP_INT} doesn't exist";                         \
@@ -334,11 +317,17 @@ $(OPENSSL_LIB): $(OPENSSL_TIMESTAMP)
        ln -s ${OPENSSL_DIR} ../openssl;                                           \
        export TOOLCHAIN=/tmp/ndk-${TARGET_HOST}-openssl;                          \
        ${ANDROID_NDK}/build/tools/make-standalone-toolchain.sh                    \
-       --toolchain=${TARGET_TOOLCHAIN}${COMPILER_VERSION}                         \
-       --install-dir=$${TOOLCHAIN};                                               \
+               --toolchain=${TARGET_TOOLCHAIN}${COMPILER_VERSION}                     \
+               --platform=${APP_PLATFORM}                                             \
+               --stl=libc++                                                           \
+               --install-dir=$${TOOLCHAIN};                                           \
        export PATH="$${TOOLCHAIN}/bin:$${PATH}";                                  \
-       CC=${CROSS_PREFIX}gcc ./Configure android-${TARGET_ARCH} no-idea no-seed -no-sha0 -DL_ENDIAN;\
-       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};                                                   \
@@ -348,8 +337,8 @@ $(OPENSSL_LIB): $(OPENSSL_TIMESTAMP)
 
 clean_openssl :
        $(RM) -rf ${OPENSSL_DIR};                                                  \
-       $(RM) -rf $(ROOT)/deps/${OPENSSL_BASEDIR}.tar.gz;                          \
-       $(RM) -rf $(ROOT)/deps/openssl
+       $(RM) -rf $(ANDR_ROOT)/deps/${OPENSSL_BASEDIR}.tar.gz;                     \
+       $(RM) -rf $(ANDR_ROOT)/deps/openssl
 
 $(LEVELDB_TIMESTAMP) : leveldb_download
        @LAST_MODIF=$$(find ${LEVELDB_DIR} -type f -printf '%T@ %p\n' | sort -n | tail -1 | cut -f2- -d" "); \
@@ -360,13 +349,15 @@ $(LEVELDB_TIMESTAMP) : leveldb_download
 leveldb_download :
        @if [ ! -d ${LEVELDB_DIR} ] ; then                                         \
                echo "leveldb sources missing, downloading...";                        \
-               mkdir -p ${ROOT}/deps;                                                 \
-               cd ${ROOT}/deps ;                                                      \
+               mkdir -p ${ANDR_ROOT}/deps;                                            \
+               cd ${ANDR_ROOT}/deps ;                                                 \
                git clone ${LEVELDB_URL_GIT} || exit 1;                                \
+               cd ${LEVELDB_DIR} || exit 1;                                           \
+               git checkout ${LEVELDB_COMMIT} || exit 1;                              \
        fi
 
 leveldb : $(LEVELDB_LIB)
-
+ifeq ($(HAVE_LEVELDB),1)
 $(LEVELDB_LIB): $(LEVELDB_TIMESTAMP)
        @REFRESH=0;                                                                \
        if [ ! -e ${LEVELDB_TIMESTAMP_INT} ] ; then                                \
@@ -376,28 +367,30 @@ $(LEVELDB_LIB): $(LEVELDB_TIMESTAMP)
                REFRESH=1;                                                             \
        fi;                                                                        \
        if [ $$REFRESH -ne 0 ] ; then                                              \
-       export PATH=$${PATH}:${SDKFOLDER}/platform-tools:${ANDROID_NDK};           \
        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}                         \
-       --install-dir=$${TOOLCHAIN};                                               \
+               --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_CFLAGS_ADDON}";                     \
+       export CPPFLAGS="$${CPPFLAGS} ${TARGET_CXXFLAGS_ADDON}";                   \
        export LDFLAGS="$${LDFLAGS} ${TARGET_LDFLAGS_ADDON}";                      \
        export TARGET_OS=OS_ANDROID_CROSSCOMPILE;                                  \
-       $(MAKE) -s || exit 1;                                                      \
+       $(MAKE) || exit 1;                                                      \
        touch ${LEVELDB_TIMESTAMP};                                                \
        touch ${LEVELDB_TIMESTAMP_INT};                                            \
        $(RM) -rf $${TOOLCHAIN};                                                   \
        else                                                                       \
                echo "nothing to be done for leveldb";                                 \
        fi
+endif
 
 clean_leveldb :
        $(RM) -rf deps/leveldb
@@ -411,7 +404,7 @@ $(FREETYPE_TIMESTAMP) : freetype_download
 freetype_download :
        @if [ ! -d ${FREETYPE_DIR} ] ; then                                        \
                echo "freetype sources missing, downloading...";                       \
-               mkdir -p ${ROOT}/deps;                                                 \
+               mkdir -p ${ANDR_ROOT}/deps;                                            \
                cd deps;                                                               \
                git clone ${FREETYPE_URL_GIT} || exit 1;                               \
        fi
@@ -431,14 +424,15 @@ $(FREETYPE_LIB) : $(FREETYPE_TIMESTAMP)
        fi;                                                                        \
        if [ $$REFRESH -ne 0 ] ; then                                              \
        mkdir -p ${FREETYPE_DIR};                                                  \
-       export PATH=$$PATH:${SDKFOLDER}/platform-tools:${ANDROID_NDK};             \
        echo "changed timestamp for freetype detected building...";                \
        cd ${FREETYPE_DIR}/Android/jni;                                            \
-       ndk-build NDEBUG=${NDEBUG} NDK_MODULE_PATH=${NDK_MODULE_PATH}              \
-       APP_PLATFORM=${APP_PLATFORM} APP_ABI=${TARGET_ABI}                         \
-       TARGET_CFLAGS+="${TARGET_CFLAGS_ADDON}"                                    \
-       TARGET_LDFLAGS+="${TARGET_LDFLAGS_ADDON}"                                  \
-       TARGET_CXXFLAGS+="${TARGET_CXXFLAGS_ADDON}" || exit 1;                     \
+       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};                               \
+       ${ANDROID_NDK}/ndk-build                                                   \
+               NDK_APPLICATION_MK=${ANDR_ROOT}/jni/Deps.mk || exit 1;                 \
        touch ${FREETYPE_TIMESTAMP};                                               \
        touch ${FREETYPE_TIMESTAMP_INT};                                           \
        else                                                                       \
@@ -457,15 +451,15 @@ $(ICONV_TIMESTAMP) : iconv_download
 iconv_download :
        @if [ ! -d ${ICONV_DIR} ] ; then                                           \
                echo "iconv sources missing, downloading...";                      \
-               mkdir -p ${ROOT}/deps;                                             \
-               cd ${ROOT}/deps;                                                   \
+               mkdir -p ${ANDR_ROOT}/deps;                                        \
+               cd ${ANDR_ROOT}/deps;                                              \
                wget ${ICONV_URL_HTTP} || exit 1;                                  \
                tar -xzf libiconv-${ICONV_VERSION}.tar.gz || exit 1;               \
                rm libiconv-${ICONV_VERSION}.tar.gz;                               \
                ln -s libiconv-${ICONV_VERSION} libiconv;                          \
                cd ${ICONV_DIR};                                                   \
-               patch -p1 < ${ROOT}/libiconv_android.patch;                        \
-               patch -p1 < ${ROOT}/libiconv_stdio.patch;                          \
+               patch -p1 < ${ANDR_ROOT}/patches/libiconv_android.patch;           \
+               patch -p1 < ${ANDR_ROOT}/patches/libiconv_stdio.patch;             \
        fi
 
 iconv : $(ICONV_LIB)
@@ -483,17 +477,19 @@ $(ICONV_LIB) : $(ICONV_TIMESTAMP)
        fi;                                                                        \
        if [ $$REFRESH -ne 0 ] ; then                                              \
        mkdir -p ${ICONV_DIR};                                                     \
-       export PATH=$$PATH:${SDKFOLDER}/platform-tools:${ANDROID_NDK};             \
        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}                         \
-       --install-dir=$${TOOLCHAIN};                                               \
+               --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 CFLAGS="$${CFLAGS} ${TARGET_CFLAGS_ADDON}";                         \
+       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; \
@@ -517,13 +513,14 @@ clean_iconv :
 irrlicht_download :
        @if [ ! -d "deps/irrlicht" ] ; then                                        \
                echo "irrlicht sources missing, downloading...";                       \
-               mkdir -p ${ROOT}/deps;                                                 \
+               mkdir -p ${ANDR_ROOT}/deps;                                            \
                cd deps;                                                               \
                svn co ${IRRLICHT_URL_SVN} irrlicht || exit 1;                         \
                cd irrlicht;                                                           \
-               patch -p1 < ../../irrlicht-touchcount.patch || exit 1;                 \
-               patch -p1 < ../../irrlicht-back_button.patch || exit 1;                \
-               patch -p1 < ../../irrlicht-texturehack.patch || exit 1;                \
+               patch -p1 < ${ANDR_ROOT}/patches/irrlicht-touchcount.patch || exit 1;  \
+               patch -p1 < ${ANDR_ROOT}/patches/irrlicht-back_button.patch || exit 1; \
+               patch -p1 < ${ANDR_ROOT}/patches/irrlicht-texturehack.patch || exit 1; \
+               patch -p1 < ${ANDR_ROOT}/patches/irrlicht-native_activity.patch || exit 1; \
        fi
 
 $(IRRLICHT_TIMESTAMP) : irrlicht_download
@@ -547,14 +544,15 @@ $(IRRLICHT_LIB): $(IRRLICHT_TIMESTAMP) $(FREETYPE_LIB)
        fi;                                                                        \
        if [ $$REFRESH -ne 0 ] ; then                                              \
        mkdir -p ${IRRLICHT_DIR};                                                  \
-       export PATH=$$PATH:${SDKFOLDER}/platform-tools:${ANDROID_NDK};             \
        echo "changed timestamp for irrlicht detected building...";                \
        cd deps/irrlicht/source/Irrlicht/Android;                                  \
-       ndk-build NDEBUG=${NDEBUG} NDK_MODULE_PATH=${NDK_MODULE_PATH}              \
-       APP_ABI=${TARGET_ABI} APP_PLATFORM=${APP_PLATFORM}                         \
-       TARGET_CFLAGS+="${TARGET_CFLAGS_ADDON}"                                    \
-       TARGET_LDFLAGS+="${TARGET_LDFLAGS_ADDON}"                                  \
-       TARGET_CXXFLAGS+="${TARGET_CXXFLAGS_ADDON}" || exit 1;                     \
+       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};                               \
+       ${ANDROID_NDK}/ndk-build                                                   \
+               NDK_APPLICATION_MK=${ANDR_ROOT}/jni/Deps.mk || exit 1;                 \
        touch ${IRRLICHT_TIMESTAMP};                                               \
        touch ${IRRLICHT_TIMESTAMP_INT};                                           \
        else                                                                       \
@@ -573,7 +571,7 @@ $(CURL_TIMESTAMP) : curl_download
 curl_download :
        @if [ ! -d "deps/curl-${CURL_VERSION}" ] ; then                            \
                echo "curl sources missing, downloading...";                           \
-               mkdir -p ${ROOT}/deps;                                                 \
+               mkdir -p ${ANDR_ROOT}/deps;                                            \
                cd deps;                                                               \
                wget ${CURL_URL_HTTP} || exit 1;                                       \
                tar -xjf curl-${CURL_VERSION}.tar.bz2 || exit 1;                       \
@@ -596,20 +594,20 @@ $(CURL_LIB): $(CURL_TIMESTAMP) $(OPENSSL_LIB)
        fi;                                                                        \
        if [ $$REFRESH -ne 0 ] ; then                                              \
        mkdir -p ${CURL_DIR};                                                      \
-       export PATH="$${PATH}:${SDKFOLDER}/platform-tools:${ANDROID_NDK}";         \
        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}                         \
-       --install-dir=$${TOOLCHAIN};                                               \
+               --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                     \
-       -L${OPENSSL_DIR} ${TARGET_CFLAGS_ADDON}";                                  \
+       export CPPFLAGS="$${CPPFLAGS} -I${OPENSSL_DIR}/include ${TARGET_CFLAGS_ADDON}"; \
        export CFLAGS="$${CFLAGS} ${TARGET_CFLAGS_ADDON}";                         \
        export LDFLAGS="$${LDFLAGS} -L${OPENSSL_DIR} ${TARGET_LDFLAGS_ADDON}";     \
        ./configure --host=${TARGET_HOST} --disable-shared --enable-static --with-ssl;  \
@@ -634,7 +632,7 @@ $(GMP_TIMESTAMP) : gmp_download
 gmp_download :
        @if [ ! -d "${GMP_DIR}" ] ; then                                           \
                echo "gmp sources missing, downloading...";                        \
-               mkdir -p ${ROOT}/deps;                                             \
+               mkdir -p ${ANDR_ROOT}/deps;                                        \
                cd deps;                                                           \
                wget ${GMP_URL_HTTP} || exit 1;                                    \
                tar -xjf gmp-${GMP_VERSION}.tar.bz2 || exit 1;                     \
@@ -657,17 +655,19 @@ $(GMP_LIB): $(GMP_TIMESTAMP)
        fi;                                                                        \
        if [ $$REFRESH -ne 0 ] ; then                                              \
        mkdir -p ${GMP_DIR};                                                       \
-       export PATH="$${PATH}:${SDKFOLDER}/platform-tools:${ANDROID_NDK}";         \
        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}                         \
-       --install-dir=$${TOOLCHAIN};                                               \
+               --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;          \
@@ -689,18 +689,19 @@ deps/${SQLITE3_FOLDER}/sqlite3.c :
        cd deps;                                                                    \
        wget ${SQLITE3_URL};                                                        \
        unzip ${SQLITE3_FOLDER}.zip;                                                \
-       ln -s ${SQLITE3_FOLDER} sqlite
+       ln -s ${SQLITE3_FOLDER} sqlite;                                             \
+       cd ${SQLITE3_FOLDER};
 
 clean_sqlite3:
        cd deps && $(RM) -rf ${SQLITE3_FOLDER} && $(RM) -f ${SQLITE3_FOLDER}.zip && \
        $(RM) -f sqlite
 
 $(ASSETS_TIMESTAMP) : $(IRRLICHT_LIB)
-       @mkdir -p ${ROOT}/deps;                                                     \
+       @mkdir -p ${ANDR_ROOT}/deps;                                                \
        for DIRNAME in {builtin,client,doc,fonts,games,mods,po,textures}; do        \
-               LAST_MODIF=$$(find ${ROOT}/../../${DIRNAME} -type f -printf '%T@ %p\n' | sort -n | tail -1 | cut -f2- -d" "); \
+               LAST_MODIF=$$(find ${PROJ_ROOT}/${DIRNAME} -type f -printf '%T@ %p\n' | sort -n | tail -1 | cut -f2- -d" "); \
                if [ $$(basename $$LAST_MODIF) != "timestamp" ]; then               \
-                       touch ${ROOT}/../../${DIRNAME}/timestamp;                   \
+                       touch ${PROJ_ROOT}/${DIRNAME}/timestamp;                   \
                        touch ${ASSETS_TIMESTAMP};                                  \
                        echo ${DIRNAME} changed $$LAST_MODIF;                       \
                fi;                                                                 \
@@ -710,11 +711,11 @@ $(ASSETS_TIMESTAMP) : $(IRRLICHT_LIB)
                touch ${IRRLICHT_DIR}/media/timestamp;                                 \
                touch ${ASSETS_TIMESTAMP};                                             \
        fi;                                                                        \
-       if [ ${ROOT}/../../minetest.conf.example -nt ${ASSETS_TIMESTAMP} ] ; then  \
+       if [ ${PROJ_ROOT}/minetest.conf.example -nt ${ASSETS_TIMESTAMP} ] ; then   \
                echo "conf changed";                                                   \
                touch ${ASSETS_TIMESTAMP};                                             \
        fi;                                                                        \
-       if [ ${ROOT}/../../README.txt -nt ${ASSETS_TIMESTAMP} ] ; then             \
+       if [ ${PROJ_ROOT}/README.txt -nt ${ASSETS_TIMESTAMP} ] ; then              \
                touch ${ASSETS_TIMESTAMP};                                             \
        fi;                                                                        \
        if [ ! -e $(ASSETS_TIMESTAMP) ] ; then                                     \
@@ -729,34 +730,34 @@ assets : $(ASSETS_TIMESTAMP)
        if [ ${ASSETS_TIMESTAMP} -nt ${ASSETS_TIMESTAMP}.old ] ; then              \
                REFRESH=1;                                                             \
        fi;                                                                        \
-       if [ ! -d ${ROOT}/assets ] ; then                                          \
+       if [ ! -d ${APP_ROOT}/assets ] ; then                                      \
                REFRESH=1;                                                             \
        fi;                                                                        \
        if [ $$REFRESH -ne 0 ] ; then                                              \
        echo "assets changed, refreshing...";                                      \
        $(MAKE) clean_assets;                                                      \
-       mkdir -p ${ROOT}/assets/Minetest;                                          \
-       cp ${ROOT}/../../minetest.conf.example ${ROOT}/assets/Minetest;            \
-       cp ${ROOT}/../../README.txt ${ROOT}/assets/Minetest;                       \
-       cp -r ${ROOT}/../../builtin ${ROOT}/assets/Minetest;                       \
-       mkdir ${ROOT}/assets/Minetest/client;                                      \
-       cp -r ${ROOT}/../../client/shaders ${ROOT}/assets/Minetest/client;         \
-       cp ${ROOT}/../../doc/lgpl-2.1.txt ${ROOT}/assets/Minetest/LICENSE.txt;     \
-       mkdir ${ROOT}/assets/Minetest/fonts;                                       \
-       cp -r ${ROOT}/../../fonts/*.ttf ${ROOT}/assets/Minetest/fonts/;            \
-       mkdir ${ROOT}/assets/Minetest/games;                                       \
+       mkdir -p ${APP_ROOT}/assets/Minetest;                                      \
+       cp ${PROJ_ROOT}/minetest.conf.example ${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;      \
+       cp ${PROJ_ROOT}/doc/lgpl-2.1.txt ${APP_ROOT}/assets/Minetest/LICENSE.txt;  \
+       mkdir -p ${APP_ROOT}/assets/Minetest/fonts;                                   \
+       cp -r ${PROJ_ROOT}/fonts/*.ttf ${APP_ROOT}/assets/Minetest/fonts/;         \
+       mkdir -p ${APP_ROOT}/assets/Minetest/games;                                   \
        for game in ${GAMES_TO_COPY}; do                                           \
-           cp -r ${ROOT}/../../games/$$game ${ROOT}/assets/Minetest/games/;       \
+           cp -r ${PROJ_ROOT}/games/$$game ${APP_ROOT}/assets/Minetest/games/;    \
        done;                                                                      \
-       mkdir ${ROOT}/assets/Minetest/mods;                                        \
+       mkdir -p ${APP_ROOT}/assets/Minetest/mods;                                    \
        for mod in ${MODS_TO_COPY}; do                                             \
-           cp -r ${ROOT}/../../mods/$$mod ${ROOT}/assets/Minetest/mods/;          \
+           cp -r ${PROJ_ROOT}/mods/$$mod ${APP_ROOT}/assets/Minetest/mods/;       \
        done;                                                                      \
-       cp -r ${ROOT}/../../po ${ROOT}/assets/Minetest;                            \
-       cp -r ${ROOT}/../../textures ${ROOT}/assets/Minetest;                      \
-       mkdir -p ${ROOT}/assets/Minetest/media;                                    \
-       cp -r ${IRRLICHT_DIR}/media/Shaders ${ROOT}/assets/Minetest/media;         \
-       cd ${ROOT}/assets ||  exit 1;                                              \
+       cp -r ${PROJ_ROOT}/po ${APP_ROOT}/assets/Minetest;                         \
+       cp -r ${PROJ_ROOT}/textures ${APP_ROOT}/assets/Minetest;                   \
+       mkdir -p ${APP_ROOT}/assets/Minetest/media;                                \
+       cp -r ${IRRLICHT_DIR}/media/Shaders ${APP_ROOT}/assets/Minetest/media;     \
+       cd ${APP_ROOT}/assets ||  exit 1;                                          \
        find . -name "timestamp" -exec rm {} \; ;                                  \
        find . -name "*.blend" -exec rm {} \; ;                                    \
        find . -name "*~" -exec rm {} \; ;                                         \
@@ -764,8 +765,8 @@ assets : $(ASSETS_TIMESTAMP)
        find . -type d -path "*.svn" -exec rm -rf {} \; ;                          \
        find . -type f -path "*.gitignore" -exec rm -rf {} \; ;                    \
        ls -R | grep ":$$" | sed -e 's/:$$//' -e 's/\.//' -e 's/^\///' > "index.txt"; \
-       find Minetest >"filelist.txt";                                             \
-       cp ${ROOT}/${ASSETS_TIMESTAMP} ${ROOT}/${ASSETS_TIMESTAMP}.old;            \
+       find -L Minetest > filelist.txt;                                             \
+       cp ${ANDR_ROOT}/${ASSETS_TIMESTAMP} ${ANDR_ROOT}/${ASSETS_TIMESTAMP}.old;  \
        else                                                                       \
                echo "nothing to be done for assets";                                  \
        fi
@@ -773,56 +774,55 @@ assets : $(ASSETS_TIMESTAMP)
 clean_assets :
        @$(RM) -r assets
 
-apk: $(PATHCFGFILE) assets $(ICONV_LIB) $(IRRLICHT_LIB) $(CURL_LIB) $(GMP_LIB) $(LEVELDB_TARGET)       \
-       $(OPENAL_LIB) $(OGG_LIB) prep_srcdir $(ROOT)/jni/src/android_version.h     \
-       $(ROOT)/jni/src/android_version_githash.h sqlite3_download
-       @export NDEBUG=$$NDEBUG; $(MAKE) manifest;                                 \
-       export PATH=$$PATH:${SDKFOLDER}/platform-tools:${ANDROID_NDK};             \
-       export ANDROID_HOME=${SDKFOLDER};                                          \
-       mkdir -p ${ROOT}/src;                                                      \
-       ndk-build NDK_MODULE_PATH=${NDK_MODULE_PATH}                               \
-       GPROF=${GPROF} APP_ABI=${TARGET_ABI} HAVE_LEVELDB=${HAVE_LEVELDB}          \
-       APP_PLATFORM=${APP_PLATFORM}                                               \
-       TARGET_LIBDIR=${TARGET_LIBDIR}                                             \
-       TARGET_CFLAGS+="${TARGET_CFLAGS_ADDON}"                                    \
-       TARGET_LDFLAGS+="${TARGET_LDFLAGS_ADDON}"                                  \
-       TARGET_CXXFLAGS+="${TARGET_CXXFLAGS_ADDON}" &&                             \
-       ant $$BUILD_TYPE &&                                                        \
-       echo "++ Success!" &&                                                      \
-       echo "APK: bin/Minetest-$$BUILD_TYPE.apk" &&                               \
-       echo "You can install it with \`adb install -r bin/Minetest-$$BUILD_TYPE.apk\`"
+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    \
+       $(ANDR_ROOT)/jni/src/android_version_githash.h sqlite3_download
+       + @export TARGET_LIBDIR=${TARGET_LIBDIR};                                  \
+       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;                 \
+       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 "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
+
+install_release:
+       ${ANDROID_SDK}/platform-tools/adb install -r build/outputs/apk/Minetest-release.apk
 
 prep_srcdir :
-       @if [ ! -e ${ROOT}/jni/src ]; then                                         \
-               ln -s ${ROOT}/../../src ${ROOT}/jni/src;                           \
+       @if [ ! -e ${ANDR_ROOT}/jni/src ]; then                                    \
+               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;                       \
        fi
 
-clean_apk : manifest
-       @export PATH=$$PATH:${SDKFOLDER}platform-tools:${ANDROID_NDK};             \
-       export ANDROID_HOME=${SDKFOLDER};                                          \
-       ant clean
-
-install_debug :
-       @export PATH=$$PATH:${SDKFOLDER}platform-tools:${ANDROID_NDK};             \
-       adb install -r ${ROOT}/bin/Minetest-debug.apk
-
-install :
-       @export PATH=$$PATH:${SDKFOLDER}platform-tools:${ANDROID_NDK};             \
-       adb install -r ${ROOT}/bin/Minetest-release.apk
-
-envpaths :
-       @echo "export PATH=$$PATH:${SDKFOLDER}platform-tools:${ANDROID_NDK}" > and_env;\
-       echo "export ANDROID_HOME=${SDKFOLDER}" >> and_env;
+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 clean_manifest;                           \
+       $(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
 
-$(ROOT)/jni/src/android_version_githash.h : prep_srcdir
-       @export VERSION_FILE=${ROOT}/jni/src/android_version_githash.h;            \
+$(ANDR_ROOT)/jni/src/android_version_githash.h : prep_srcdir
+       @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";                               \
@@ -840,8 +840,8 @@ $(ROOT)/jni/src/android_version_githash.h : prep_srcdir
        fi
 
 
-$(ROOT)/jni/src/android_version.h : prep_srcdir
-       @export VERSION_FILE=${ROOT}/jni/src/android_version.h;                    \
+$(ANDR_ROOT)/jni/src/android_version.h : prep_srcdir
+       @export VERSION_FILE=${ANDR_ROOT}/jni/src/android_version.h;                \
        export VERSION_FILE_NEW=$${VERSION_FILE}.new;                              \
        {                                                                          \
        echo "#ifndef ANDROID_MT_VERSION_H";                                       \
@@ -849,8 +849,8 @@ $(ROOT)/jni/src/android_version.h : prep_srcdir
        echo "#define VERSION_MAJOR ${VERSION_MAJOR}";                             \
        echo "#define VERSION_MINOR ${VERSION_MINOR}";                             \
        echo "#define VERSION_PATCH ${VERSION_PATCH}";                             \
-       echo "#define VERSION_STRING STR(VERSION_MAJOR)\".\"STR(VERSION_MINOR)\
-       \".\"STR(VERSION_PATCH)";                                                  \
+       echo "#define VERSION_STRING STR(VERSION_MAJOR) \".\" STR(VERSION_MINOR) \
+       \".\" STR(VERSION_PATCH)";                                                 \
        echo "#endif";                                                             \
        } > $${VERSION_FILE_NEW};                                                  \
        if ! cmp -s $${VERSION_FILE} $${VERSION_FILE_NEW}; then                    \
@@ -860,22 +860,4 @@ $(ROOT)/jni/src/android_version.h : prep_srcdir
                rm "$${VERSION_FILE_NEW}";                                         \
        fi
 
-manifest :
-       @BASE_VERSION="${VERSION_MAJOR}.${VERSION_MINOR}.${VERSION_PATCH}";        \
-       if [ "${NDEBUG}x" != "x" ] ; then                                          \
-               DBG='';                                                                \
-               DBG_FLAG="android:debuggable=\"false\"";                               \
-       else                                                                       \
-               DBG="<uses-permission android:name=\"android.permission.SET_DEBUG_APP\" />"; \
-               DBG_FLAG="android:debuggable=\"true\"";                                \
-       fi;                                                                        \
-       cat ${ROOT}/AndroidManifest.xml.template |                                 \
-       sed "s/###ANDROID_VERSION###/${ANDROID_VERSION_CODE}/g" |                  \
-       sed "s/###BASE_VERSION###/$$BASE_VERSION/g" |                              \
-       sed -e "s@###DEBUG_BUILD###@$$DBG@g" |                                     \
-       sed -e "s@###DEBUG_FLAG###@$$DBG_FLAG@g" >${ROOT}/AndroidManifest.xml
-
-clean_manifest :
-       rm -rf ${ROOT}/AndroidManifest.xml
-
 clean : clean_apk clean_assets