]> git.lizzy.rs Git - dragonfireclient.git/blobdiff - build/android/Makefile
sound_openal.cpp: remove unused header
[dragonfireclient.git] / build / android / Makefile
index 4c371afeacc4825e049365b91162fc55a34f50b8..66d12ac8b5c20a32f3c0812e15af50c344135b9d 100644 (file)
@@ -2,13 +2,6 @@
 
 OS := $(shell uname)
 
-#automaticaly set number of jobs
-ifeq ($(OS),Linux)
-  PARALLEL := $(shell grep -c ^processor /proc/cpuinfo)
-else
-  PARALLEL := 1
-endif
-
 # compile with GPROF
 # GPROF = 1
 
@@ -21,12 +14,22 @@ PATHCFGFILE = path.cfg
 ROOT = $(shell pwd)
 
 GAMES_TO_COPY = minetest_game
+MODS_TO_COPY =
+
+
+VERSION_MAJOR := $(shell cat $(ROOT)/../../CMakeLists.txt | \
+       grep ^set\(VERSION_MAJOR\ | sed 's/)/ /' | cut -f2 -d' ')
+VERSION_MINOR := $(shell cat $(ROOT)/../../CMakeLists.txt | \
+       grep ^set\(VERSION_MINOR\ | sed 's/)/ /' | cut -f2 -d' ')
+VERSION_PATCH := $(shell cat $(ROOT)/../../CMakeLists.txt | \
+       grep ^set\(VERSION_PATCH\ | sed 's/)/ /' | cut -f2 -d' ')
 
 ################################################################################
 # Android Version code
 # Increase for each build!
 ################################################################################
-ANDROID_VERSION_CODE = 7
+# Play Store actual version (16/03/15): 11
+ANDROID_VERSION_CODE = 13
 
 ################################################################################
 # toolchain config for arm old processors
@@ -45,13 +48,11 @@ ANDROID_VERSION_CODE = 7
 # toolchain config for arm new processors
 ################################################################################
 TARGET_HOST = arm-linux
-TARGET_ABI = armeabi-v7a-hard
+TARGET_ABI = armeabi-v7a
 TARGET_LIBDIR = armeabi-v7a
 TARGET_TOOLCHAIN = arm-linux-androideabi-
-TARGET_CFLAGS_ADDON =  -mfpu=vfpv3-d16 -D_NDK_MATH_NO_SOFTFP=1 \
-                                               -mfloat-abi=hard -march=armv7-a
+TARGET_CFLAGS_ADDON = -mfloat-abi=softfp -mfpu=vfpv3
 TARGET_CXXFLAGS_ADDON = $(TARGET_CFLAGS_ADDON)
-TARGET_LDFLAGS_ADDON = -Wl,--no-warn-mismatch -lm_hard
 TARGET_ARCH = armv7
 CROSS_PREFIX = arm-linux-androideabi-
 COMPILER_VERSION = 4.8
@@ -88,7 +89,7 @@ LEVELDB_DIR = $(ROOT)/deps/leveldb/
 LEVELDB_LIB = $(LEVELDB_DIR)libleveldb.a
 LEVELDB_TIMESTAMP = $(LEVELDB_DIR)/timestamp
 LEVELDB_TIMESTAMP_INT = $(ROOT)/deps/leveldb_timestamp
-LEVELDB_URL_GIT = https://code.google.com/p/leveldb/
+LEVELDB_URL_GIT = https://github.com/google/leveldb
 
 OPENAL_DIR = $(ROOT)/deps/openal-soft/
 OPENAL_LIB = $(OPENAL_DIR)libs/$(TARGET_ABI)/libopenal.so
@@ -124,12 +125,26 @@ 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
 
+GMP_VERSION = 6.0.0
+GMP_DIR = $(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_URL_HTTP = https://gmplib.org/download/gmp/gmp-$(GMP_VERSION).tar.bz2
+
 FREETYPE_DIR = $(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_URL_GIT = https://github.com/cdave1/freetype2-android
 
+ICONV_VERSION = 1.14
+ICONV_DIR = $(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
+
 SQLITE3_FOLDER = sqlite-amalgamation-3080704
 SQLITE3_URL = http://www.sqlite.org/2014/$(SQLITE3_FOLDER).zip
 
@@ -153,22 +168,23 @@ endif
        $(OPENAL_TIMESTAMP) $(OGG_TIMESTAMP) \
        $(IRRLICHT_TIMESTAMP) $(CURL_TIMESTAMP) \
        $(OPENSSL_TIMESTAMP) curl_binary \
-       $(ROOT)/jni/src/android_version.h
-       
+       $(ROOT)/jni/src/android_version.h \
+       $(ROOT)/jni/src/android_version_githash.h
+
 debug : $(PATHCFGFILE)
        export NDEBUG=;                                                            \
        export BUILD_TYPE=debug;                                                   \
-       $(MAKE) -j${PARALLEL} apk
-       
+       $(MAKE) apk
+
 all : debug release
-       
+
 release : $(PATHCFGFILE)
        @export NDEBUG=1;                                                          \
        export BUILD_TYPE=release;                                                 \
-       $(MAKE) -j${PARALLEL} apk
+       $(MAKE) apk
 
 reconfig: delconfig
-       @$(MAKE) -j${PARALLEL} $(PATHCFGFILE)
+       @$(MAKE) $(PATHCFGFILE)
 
 delconfig :
        $(RM) ${PATHCFGFILE}
@@ -200,7 +216,7 @@ $(OPENAL_TIMESTAMP) : openal_download
        if [ $$(basename $$LAST_MODIF) != "timestamp" ] ; then                     \
                touch ${OPENAL_TIMESTAMP};                                            \
        fi
-       
+
 openal_download :
        @if [ ! -d ${OPENAL_DIR} ] ; then                                          \
                echo "openal sources missing, downloading...";                         \
@@ -208,7 +224,7 @@ openal_download :
                cd ${ROOT}/deps ;                                                      \
                git clone ${OPENAL_URL_GIT} || exit 1;                                 \
        fi
-       
+
 openal : $(OPENAL_LIB)
 
 $(OPENAL_LIB): $(OPENAL_TIMESTAMP)
@@ -224,8 +240,8 @@ $(OPENAL_LIB): $(OPENAL_TIMESTAMP)
        echo "changed timestamp for openal detected building...";                  \
        cd ${OPENAL_DIR};                                                          \
        ndk-build NDEBUG=${NDEBUG} NDK_MODULE_PATH=${NDK_MODULE_PATH}              \
-       APP_ABI=${TARGET_ABI} APP_PLATFORM=${APP_PLATFORM} -j${PARALLEL}           \
-       TARGET_CFLAGS+="${TARGET_CFLAGS_ADDON}"                                    \
+       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;                     \
        touch ${OPENAL_TIMESTAMP};                                                 \
@@ -233,16 +249,16 @@ $(OPENAL_LIB): $(OPENAL_TIMESTAMP)
        else                                                                       \
                echo "nothing to be done for openal";                                  \
        fi
-       
+
 clean_openal :
        $(RM) -rf ${OPENAL_DIR}
-       
+
 $(OGG_TIMESTAMP) : ogg_download
        @LAST_MODIF=$$(find ${OGG_DIR} -type f -printf '%T@ %p\n' | sort -n | tail -1 | cut -f2- -d" "); \
        if [ $$(basename $$LAST_MODIF) != "timestamp" ] ; then                     \
                touch ${OGG_TIMESTAMP};                                                \
        fi
-       
+
 ogg_download :
        @if [ ! -d ${OGG_DIR} ] ; then                                             \
                echo "ogg sources missing, downloading...";                            \
@@ -251,8 +267,9 @@ ogg_download :
                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;                                    \
        fi
-       
+
 ogg : $(OGG_LIB)
 
 $(OGG_LIB): $(OGG_TIMESTAMP)
@@ -269,7 +286,7 @@ $(OGG_LIB): $(OGG_TIMESTAMP)
        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} -j${PARALLEL}           \
+       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;                     \
@@ -281,13 +298,13 @@ $(OGG_LIB): $(OGG_TIMESTAMP)
 
 clean_ogg :
        $(RM) -rf ${OGG_DIR}
-       
+
 $(OPENSSL_TIMESTAMP) : openssl_download
        @LAST_MODIF=$$(find ${OPENSSL_DIR} -type f -printf '%T@ %p\n' | sort -n | tail -1 | cut -f2- -d" "); \
        if [ $$(basename $$LAST_MODIF) != "timestamp" ] ; then                     \
                touch ${OPENSSL_TIMESTAMP};                                            \
        fi
-       
+
 openssl_download :
        @if [ ! -d ${OPENSSL_DIR} ] ; then                                         \
                echo "openssl sources missing, downloading...";                        \
@@ -298,7 +315,7 @@ openssl_download :
                cd ${OPENSSL_BASEDIR};                                                 \
                patch -p1 < ../../openssl_arch.patch;                                  \
        fi
-       
+
 openssl : $(OPENSSL_LIB)
 
 $(OPENSSL_LIB): $(OPENSSL_TIMESTAMP)
@@ -317,7 +334,7 @@ $(OPENSSL_LIB): $(OPENSSL_TIMESTAMP)
        export TOOLCHAIN=/tmp/ndk-${TARGET_HOST}-openssl;                          \
        ${ANDROID_NDK}/build/tools/make-standalone-toolchain.sh                    \
        --toolchain=${TARGET_TOOLCHAIN}${COMPILER_VERSION}                         \
-       --install-dir=$${TOOLCHAIN} --system=linux-x86_64;                         \
+       --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; \
@@ -346,7 +363,7 @@ leveldb_download :
                cd ${ROOT}/deps ;                                                      \
                git clone ${LEVELDB_URL_GIT} || exit 1;                                \
        fi
-       
+
 leveldb : $(LEVELDB_LIB)
 
 $(LEVELDB_LIB): $(LEVELDB_TIMESTAMP)
@@ -365,7 +382,7 @@ $(LEVELDB_LIB): $(LEVELDB_TIMESTAMP)
        export TOOLCHAIN=/tmp/ndk-${TARGET_HOST}-leveldb;                          \
        ${ANDROID_NDK}/build/tools/make-standalone-toolchain.sh                    \
        --toolchain=${TARGET_TOOLCHAIN}${COMPILER_VERSION}                         \
-       --install-dir=$${TOOLCHAIN} --system=linux-x86_64;                         \
+       --install-dir=$${TOOLCHAIN};                                               \
        export PATH="$${TOOLCHAIN}/bin:$${PATH}";                                  \
        export CC=${CROSS_PREFIX}gcc;                                              \
        export CXX=${CROSS_PREFIX}g++;                                             \
@@ -373,17 +390,17 @@ $(LEVELDB_LIB): $(LEVELDB_TIMESTAMP)
        export CPPFLAGS="$${CPPFLAGS} ${TARGET_CFLAGS_ADDON}";                     \
        export LDFLAGS="$${LDFLAGS} ${TARGET_LDFLAGS_ADDON}";                      \
        export TARGET_OS=OS_ANDROID_CROSSCOMPILE;                                  \
-       $(MAKE) -j${PARALLEL} -s || exit 1;                                        \
+       $(MAKE) -s || exit 1;                                                      \
        touch ${LEVELDB_TIMESTAMP};                                                \
        touch ${LEVELDB_TIMESTAMP_INT};                                            \
        $(RM) -rf $${TOOLCHAIN};                                                   \
        else                                                                       \
                echo "nothing to be done for leveldb";                                 \
        fi
-       
+
 clean_leveldb :
        $(RM) -rf deps/leveldb
-       
+
 $(FREETYPE_TIMESTAMP) : freetype_download
        @LAST_MODIF=$$(find ${FREETYPE_DIR} -type f -printf '%T@ %p\n' | sort -n | tail -1 | cut -f2- -d" "); \
        if [ $$(basename $$LAST_MODIF) != "timestamp" ] ; then                     \
@@ -397,13 +414,7 @@ freetype_download :
                cd deps;                                                               \
                git clone ${FREETYPE_URL_GIT} || exit 1;                               \
        fi
-       
-$(IRRLICHT_TIMESTAMP) : irrlicht_download
-       @LAST_MODIF=$$(find ${IRRLICHT_DIR} -type f -printf '%T@ %p\n' | sort -n | tail -1 | cut -f2- -d" "); \
-       if [ $$(basename $$LAST_MODIF) != "timestamp" ] ; then                     \
-               touch ${IRRLICHT_TIMESTAMP};                                           \
-       fi
-       
+
 freetype : $(FREETYPE_LIB)
 
 $(FREETYPE_LIB) : $(FREETYPE_TIMESTAMP)
@@ -423,7 +434,7 @@ $(FREETYPE_LIB) : $(FREETYPE_TIMESTAMP)
        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} -j${PARALLEL}           \
+       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;                     \
@@ -432,10 +443,71 @@ $(FREETYPE_LIB) : $(FREETYPE_TIMESTAMP)
        else                                                                       \
                echo "nothing to be done for freetype";                                \
        fi
-       
+
 clean_freetype :
        $(RM) -rf ${FREETYPE_DIR}
 
+$(ICONV_TIMESTAMP) : iconv_download
+       @LAST_MODIF=$$(find ${ICONV_DIR} -type f -printf '%T@ %p\n' | sort -n | tail -1 | cut -f2- -d" "); \
+       if [ $$(basename $$LAST_MODIF) != "timestamp" ] ; then                     \
+               touch ${ICONV_TIMESTAMP};                                           \
+       fi
+
+iconv_download :
+       @if [ ! -d ${ICONV_DIR} ] ; then                                           \
+               echo "iconv sources missing, downloading...";                      \
+               mkdir -p ${ROOT}/deps;                                             \
+               cd ${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;                          \
+       fi
+
+iconv : $(ICONV_LIB)
+
+$(ICONV_LIB) : $(ICONV_TIMESTAMP)
+       @REFRESH=0;                                                                \
+       if [ ! -e ${ICONV_TIMESTAMP_INT} ] ; then                                  \
+               REFRESH=1;                                                         \
+       fi;                                                                        \
+       if [ ! -e ${ICONV_LIB} ] ; then                                            \
+               REFRESH=1;                                                         \
+       fi;                                                                        \
+       if [ ${ICONV_TIMESTAMP} -nt ${ICONV_TIMESTAMP_INT} ] ; then                \
+               REFRESH=1;                                                         \
+       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};                                               \
+       export PATH="$${TOOLCHAIN}/bin:$${PATH}";                                  \
+       export CC=${CROSS_PREFIX}gcc;                                              \
+       export CXX=${CROSS_PREFIX}g++;                                             \
+       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; \
+       grep "iconv_LDFLAGS" src/Makefile;                                         \
+       $(MAKE) -s || exit 1;                                                      \
+       touch ${ICONV_TIMESTAMP};                                                  \
+       touch ${ICONV_TIMESTAMP_INT};                                              \
+       rm -rf ${TOOLCHAIN};                                                       \
+       else                                                                       \
+               echo "nothing to be done for iconv";                               \
+       fi
+
+clean_iconv :
+       $(RM) -rf ${ICONV_DIR}
+
 #Note: Texturehack patch is required for gpu's not supporting color format
 #      correctly. Known bad GPU:
 #      -geforce on emulator
@@ -453,6 +525,12 @@ irrlicht_download :
                patch -p1 < ../../irrlicht-texturehack.patch || exit 1;                \
        fi
 
+$(IRRLICHT_TIMESTAMP) : irrlicht_download
+       @LAST_MODIF=$$(find ${IRRLICHT_DIR} -type f -printf '%T@ %p\n' | sort -n | tail -1 | cut -f2- -d" "); \
+       if [ $$(basename $$LAST_MODIF) != "timestamp" ] ; then                     \
+               touch ${IRRLICHT_TIMESTAMP};                                           \
+       fi
+
 irrlicht : $(IRRLICHT_LIB)
 
 $(IRRLICHT_LIB): $(IRRLICHT_TIMESTAMP) $(FREETYPE_LIB)
@@ -472,7 +550,7 @@ $(IRRLICHT_LIB): $(IRRLICHT_TIMESTAMP) $(FREETYPE_LIB)
        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} -j${PARALLEL}           \
+       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;                     \
@@ -481,10 +559,10 @@ $(IRRLICHT_LIB): $(IRRLICHT_TIMESTAMP) $(FREETYPE_LIB)
        else                                                                       \
                echo "nothing to be done for irrlicht";                                \
        fi
-       
+
 clean_irrlicht :
        $(RM) -rf deps/irrlicht
-       
+
 $(CURL_TIMESTAMP) : curl_download
        @LAST_MODIF=$$(find ${CURL_DIR} -type f -printf '%T@ %p\n' | sort -n | tail -1 | cut -f2- -d" "); \
        if [ $$(basename $$LAST_MODIF) != "timestamp" ] ; then                     \
@@ -524,7 +602,7 @@ $(CURL_LIB): $(CURL_TIMESTAMP) $(OPENSSL_LIB)
        export TOOLCHAIN=/tmp/ndk-${TARGET_HOST}-curl;                             \
        ${ANDROID_NDK}/build/tools/make-standalone-toolchain.sh                    \
        --toolchain=${TARGET_TOOLCHAIN}${COMPILER_VERSION}                         \
-       --install-dir=$${TOOLCHAIN} --system=linux-x86_64;                         \
+       --install-dir=$${TOOLCHAIN};                                               \
        export PATH="$${TOOLCHAIN}/bin:$${PATH}";                                  \
        export CC=${CROSS_PREFIX}gcc;                                              \
        export CXX=${CROSS_PREFIX}g++;                                             \
@@ -534,22 +612,22 @@ $(CURL_LIB): $(CURL_TIMESTAMP) $(OPENSSL_LIB)
        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;  \
-       $(MAKE) -j${PARALLEL} -s || exit 1;                                        \
+       $(MAKE) -s || exit 1;                                                      \
        touch ${CURL_TIMESTAMP};                                                   \
        touch ${CURL_TIMESTAMP_INT};                                               \
        $(RM) -rf $${TOOLCHAIN};                                                   \
        else                                                                       \
                echo "nothing to be done for curl";                                    \
        fi
-       
+
 clean_curl :
        $(RM) -rf deps/curl-${CURL_VERSION}                                        \
        $(RM) -f deps/curl
-       
-       
-curl_binary: 
+
+
+curl_binary:
        @if [ ! -d "deps/curl-${CURL_VERSION_BINARY}" ] ; then                     \
-               echo "curl sources missing, downloading...";                           \
+               echo "curl binary missing, downloading...";                           \
                mkdir -p ${ROOT}/deps;                                                 \
                cd deps;                                                               \
                wget http://curl.haxx.se/gknw.net/7.34.0/dist-android/curl-7.34.0-rtmp-ssh2-ssl-zlib-static-bin-android.tar.gz || exit 1;\
@@ -558,6 +636,64 @@ curl_binary:
                rm curl-7.34.0-rtmp-ssh2-ssl-zlib-static-bin-android.tar.gz;           \
        fi
 
+$(GMP_TIMESTAMP) : gmp_download
+       @LAST_MODIF=$$(find ${GMP_DIR} -type f -printf '%T@ %p\n' | sort -n | tail -1 | cut -f2- -d" "); \
+       if [ $$(basename $$LAST_MODIF) != "timestamp" ] ; then                     \
+               touch ${GMP_TIMESTAMP};                                            \
+       fi
+
+gmp_download :
+       @if [ ! -d "${GMP_DIR}" ] ; then                                           \
+               echo "gmp sources missing, downloading...";                        \
+               mkdir -p ${ROOT}/deps;                                             \
+               cd deps;                                                           \
+               wget ${GMP_URL_HTTP} || exit 1;                                    \
+               tar -xjf gmp-${GMP_VERSION}.tar.bz2 || exit 1;                     \
+               rm gmp-${GMP_VERSION}.tar.bz2;                                     \
+               ln -s gmp-${GMP_VERSION} gmp;                                      \
+       fi
+
+gmp : $(GMP_LIB)
+
+$(GMP_LIB): $(GMP_TIMESTAMP)
+       @REFRESH=0;                                                                \
+       if [ ! -e ${GMP_TIMESTAMP_INT} ] ; then                                    \
+               REFRESH=1;                                                         \
+       fi;                                                                        \
+       if [ ! -e ${GMP_LIB} ] ; then                                              \
+               REFRESH=1;                                                         \
+       fi;                                                                        \
+       if [ ${GMP_TIMESTAMP} -nt ${GMP_TIMESTAMP_INT} ] ; then                    \
+               REFRESH=1;                                                         \
+       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 TOOLCHAIN=/tmp/ndk-${TARGET_HOST}-gmp;                              \
+       ${ANDROID_NDK}/build/tools/make-standalone-toolchain.sh                    \
+       --toolchain=${TARGET_TOOLCHAIN}${COMPILER_VERSION}                         \
+       --install-dir=$${TOOLCHAIN};                                               \
+       export PATH="$${TOOLCHAIN}/bin:$${PATH}";                                  \
+       export CC=${CROSS_PREFIX}gcc;                                              \
+       export CXX=${CROSS_PREFIX}g++;                                             \
+       export LIBGMP_LDFLAGS="-avoid-version";                                    \
+       export LIBGMPXX_LDFLAGS="-avoid-version";                                  \
+       ./configure --disable-static --host=${TARGET_HOST} --prefix=/usr;          \
+       $(MAKE) install DESTDIR=/${GMP_DIR} || exit 1;                             \
+       touch ${GMP_TIMESTAMP};                                                    \
+       touch ${GMP_TIMESTAMP_INT};                                                \
+       $(RM) -rf $${TOOLCHAIN};                                                   \
+       else                                                                       \
+               echo "nothing to be done for gmp";                                 \
+       fi
+
+clean_gmp:
+       $(RM) -rf deps/gmp-${GMP_VERSION}                                          \
+       $(RM) -f deps/gmp
+
 sqlite3_download: deps/${SQLITE3_FOLDER}/sqlite3.c
 
 deps/${SQLITE3_FOLDER}/sqlite3.c :
@@ -565,54 +701,21 @@ deps/${SQLITE3_FOLDER}/sqlite3.c :
        wget ${SQLITE3_URL};                                                        \
        unzip ${SQLITE3_FOLDER}.zip;                                                \
        ln -s ${SQLITE3_FOLDER} sqlite
-       
+
 clean_sqlite3:
        cd deps && $(RM) -rf ${SQLITE3_FOLDER} && $(RM) -f ${SQLITE3_FOLDER}.zip && \
        $(RM) -f sqlite
 
 $(ASSETS_TIMESTAMP) : $(IRRLICHT_LIB)
        @mkdir -p ${ROOT}/deps;                                                     \
-       LAST_MODIF=$$(find ${ROOT}/../../builtin -type f -printf '%T@ %p\n' | sort -n | tail -1 | cut -f2- -d" "); \
-       if [ $$(basename $$LAST_MODIF) != "timestamp" ] ; then                     \
-               touch ${ROOT}/../../builtin/timestamp;                                 \
-               touch ${ASSETS_TIMESTAMP};                                             \
-               echo builtin changed $$LAST_MODIF;                                     \
-       fi;                                                                        \
-       LAST_MODIF=$$(find ${ROOT}/../../client -type f -printf '%T@ %p\n' | sort -n | tail -1 | cut -f2- -d" "); \
-       if [ $$(basename $$LAST_MODIF) != "timestamp" ] ; then                     \
-               touch ${ROOT}/../../client/timestamp;                                  \
-               touch ${ASSETS_TIMESTAMP};                                             \
-       fi;                                                                        \
-       LAST_MODIF=$$(find ${ROOT}/../../doc -type f -printf '%T@ %p\n' | sort -n | tail -1 | cut -f2- -d" "); \
-       if [ $$(basename $$LAST_MODIF) != "timestamp" ] ; then                     \
-               touch ${ROOT}/../../doc/timestamp;                                     \
-               touch ${ASSETS_TIMESTAMP};                                             \
-       fi;                                                                        \
-       LAST_MODIF=$$(find ${ROOT}/../../fonts -type f -printf '%T@ %p\n' | sort -n | tail -1 | cut -f2- -d" "); \
-       if [ $$(basename $$LAST_MODIF) != "timestamp" ] ; then                     \
-               touch ${ROOT}/../../fonts/timestamp;                                   \
-               touch ${ASSETS_TIMESTAMP};                                             \
-       fi;                                                                        \
-       LAST_MODIF=$$(find ${ROOT}/../../games -type f -printf '%T@ %p\n' | sort -n | tail -1 | cut -f2- -d" "); \
-       if [ $$(basename $$LAST_MODIF) != "timestamp" ] ; then                     \
-               touch ${ROOT}/../../games/timestamp;                                   \
-               touch ${ASSETS_TIMESTAMP};                                             \
-       fi;                                                                        \
-       LAST_MODIF=$$(find ${ROOT}/../../mods -type f -printf '%T@ %p\n' | sort -n | tail -1 | cut -f2- -d" "); \
-       if [ $$(basename $$LAST_MODIF) != "timestamp" ] ; then                     \
-               touch ${ROOT}/../../mods/timestamp;                                    \
-               touch ${ASSETS_TIMESTAMP};                                             \
-       fi;                                                                        \
-       LAST_MODIF=$$(find ${ROOT}/../../po -type f -printf '%T@ %p\n' | sort -n | tail -1 | cut -f2- -d" "); \
-       if [ $$(basename $$LAST_MODIF) != "timestamp" ] ; then                     \
-               touch ${ROOT}/../../po/timestamp;                                      \
-               touch ${ASSETS_TIMESTAMP};                                             \
-       fi;                                                                        \
-       LAST_MODIF=$$(find ${ROOT}/../../textures -type f -printf '%T@ %p\n' | sort -n | tail -1 | cut -f2- -d" "); \
-       if [ $$(basename $$LAST_MODIF) != "timestamp" ] ; then                     \
-               touch ${ROOT}/../../textures/timestamp;                                \
-               touch ${ASSETS_TIMESTAMP};                                             \
-       fi;                                                                        \
+       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" "); \
+               if [ $$(basename $$LAST_MODIF) != "timestamp" ]; then               \
+                       touch ${ROOT}/../../${DIRNAME}/timestamp;                   \
+                       touch ${ASSETS_TIMESTAMP};                                  \
+                       echo ${DIRNAME} changed $$LAST_MODIF;                       \
+               fi;                                                                 \
+       done;                                                                       \
        LAST_MODIF=$$(find ${IRRLICHT_DIR}/media -type f -printf '%T@ %p\n' | sort -n | tail -1 | cut -f2- -d" "); \
        if [ $$(basename $$LAST_MODIF) != "timestamp" ] ; then                     \
                touch ${IRRLICHT_DIR}/media/timestamp;                                 \
@@ -628,7 +731,7 @@ $(ASSETS_TIMESTAMP) : $(IRRLICHT_LIB)
        if [ ! -e $(ASSETS_TIMESTAMP) ] ; then                                     \
                touch $(ASSETS_TIMESTAMP);                                             \
        fi
-       
+
 assets : $(ASSETS_TIMESTAMP)
        @REFRESH=0;                                                                \
        if [ ! -e ${ASSETS_TIMESTAMP}.old ] ; then                                 \
@@ -642,7 +745,7 @@ assets : $(ASSETS_TIMESTAMP)
        fi;                                                                        \
        if [ $$REFRESH -ne 0 ] ; then                                              \
        echo "assets changed, refreshing...";                                      \
-       $(MAKE) -j${PARALLEL} clean_assets;                                        \
+       $(MAKE) clean_assets;                                                      \
        mkdir -p ${ROOT}/assets/Minetest;                                          \
        cp ${ROOT}/../../minetest.conf.example ${ROOT}/assets/Minetest;            \
        cp ${ROOT}/../../README.txt ${ROOT}/assets/Minetest;                       \
@@ -651,11 +754,13 @@ assets : $(ASSETS_TIMESTAMP)
        cp -r ${ROOT}/../../doc ${ROOT}/assets/Minetest;                           \
        cp -r ${ROOT}/../../fonts ${ROOT}/assets/Minetest;                         \
        mkdir ${ROOT}/assets/Minetest/games;                                       \
-       for game in ${GAMES_TO_COPY};                                              \
-       do                                                                         \
+       for game in ${GAMES_TO_COPY}; do                                           \
            cp -r ${ROOT}/../../games/$$game ${ROOT}/assets/Minetest/games/;       \
        done;                                                                      \
-       cp -r ${ROOT}/../../mods ${ROOT}/assets/Minetest;                          \
+       mkdir ${ROOT}/assets/Minetest/mods;                                        \
+       for mod in ${MODS_TO_COPY}; do                                             \
+           cp -r ${ROOT}/../../mods/$$mod ${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;                                    \
@@ -676,15 +781,15 @@ assets : $(ASSETS_TIMESTAMP)
 
 clean_assets :
        @$(RM) -r assets
-       
-apk: $(PATHCFGFILE) assets $(IRRLICHT_LIB) $(CURL_LIB) $(LEVELDB_TARGET)       \
+
+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     \
-       sqlite3_download
-       @export NDEBUG=$$NDEBUG; $(MAKE) -j${PARALLEL} manifest;                   \
+       $(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} -j${PARALLEL}                 \
+       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}                                             \
@@ -695,70 +800,77 @@ apk: $(PATHCFGFILE) assets $(IRRLICHT_LIB) $(CURL_LIB) $(LEVELDB_TARGET)       \
        echo "++ Success!" &&                                                      \
        echo "APK: bin/Minetest-$$BUILD_TYPE.apk" &&                               \
        echo "You can install it with \`adb install -r bin/Minetest-$$BUILD_TYPE.apk\`"
-       
+
 prep_srcdir :
-       @rm ${ROOT}/jni/src;                                                       \
-       ln -s ${ROOT}/../../src ${ROOT}/jni/src
-       
+       @if [ ! -e ${ROOT}/jni/src ]; then                                         \
+               ln -s ${ROOT}/../../src ${ROOT}/jni/src;                           \
+       fi
+
 clean_apk : manifest
        @export PATH=$$PATH:${SDKFOLDER}platform-tools:${ANDROID_NDK};             \
        export ANDROID_HOME=${SDKFOLDER};                                          \
        ant clean
-       
-install_debug : 
+
+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_all : 
-       @$(MAKE) -j${PARALLEL} clean_apk;                                          \
-       $(MAKE) clean_assets clean_irrlicht clean_leveldb clean_curl clean_openssl \
-       clean_openal clean_ogg clean_manifest;                                     \
+
+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;                           \
        sleep 1;                                                                   \
        $(RM) -r gen libs obj deps bin Debug and_env
-       
-$(ROOT)/jni/src/android_version.h :
-       @echo "#define STR_HELPER(x) #x"                                           \
-       >${ROOT}/jni/src/android_version.h;                                        \
-       echo "#define STR(x) STR_HELPER(x)"                                        \
-       >> ${ROOT}/jni/src/android_version.h;                                      \
-       echo "#define VERSION_MAJOR $$(cat ${ROOT}/../../CMakeLists.txt |          \
-       grep ^set\(VERSION_MAJOR\ | sed 's/)/ /' | awk '{print $$2;}')"            \
-       >> ${ROOT}/jni/src/android_version.h;                                      \
-       echo "#define VERSION_MINOR $$(cat ${ROOT}/../../CMakeLists.txt |          \
-       grep ^set\(VERSION_MINOR\ | sed 's/)/ /' | awk '{print $$2;}')"            \
-       >> ${ROOT}/jni/src/android_version.h;                                      \
-       echo "#define VERSION_PATCH $$(cat ${ROOT}/../../CMakeLists.txt |          \
-       grep ^set\(VERSION_PATCH\ | sed 's/)/ /' | awk '{print $$2;}')"            \
-       >> ${ROOT}/jni/src/android_version.h;                                      \
-       echo "#define VERSION_PATCH_ORIG $$(cat ${ROOT}/../../CMakeLists.txt |     \
-       grep ^set\(VERSION_PATCH\ | sed 's/)/ /' | awk '{print $$2;}')"            \
-       >> ${ROOT}/jni/src/android_version.h;                                      \
+
+$(ROOT)/jni/src/android_version_githash.h : prep_srcdir
+       @export VERSION_FILE=${ROOT}/jni/src/android_version_githash.h;            \
+       export VERSION_FILE_NEW=$${VERSION_FILE}.new;                              \
+       {                                                                          \
+       echo "#ifndef ANDROID_MT_VERSION_GITHASH_H";                               \
+       echo "#define ANDROID_MT_VERSION_GITHASH_H";                               \
        export GITHASH=$$(git rev-parse --short=8 HEAD);                           \
-       if [ "x$$GITHASH" = "x" ] ; then                                           \
-               export GITHASH=gUnknown;                                               \
-       fi;                                                                        \
-       echo "#define CMAKE_VERSION_GITHASH \"$$GITHASH\""                         \
-       >> ${ROOT}/jni/src/android_version.h;                                      \
-       echo "#define CMAKE_VERSION_STRING STR(VERSION_MAJOR)\".\"STR(VERSION_MINOR)\
-       \".\"STR(VERSION_PATCH)"                                                   \
-       >> ${ROOT}/jni/src/android_version.h;
-       
+       export VERSION_STR="${VERSION_MAJOR}.${VERSION_MINOR}.${VERSION_PATCH}";   \
+       echo "#define VERSION_GITHASH \"$$VERSION_STR-$$GITHASH-Android\"";        \
+       echo "#endif";                                                             \
+       } > "$${VERSION_FILE_NEW}";                                                \
+       if ! cmp -s $${VERSION_FILE} $${VERSION_FILE_NEW}; then                    \
+               echo "android_version_githash.h changed, updating...";             \
+               mv "$${VERSION_FILE_NEW}" "$${VERSION_FILE}";                      \
+       else                                                                       \
+               rm "$${VERSION_FILE_NEW}";                                         \
+       fi
+
+
+$(ROOT)/jni/src/android_version.h : prep_srcdir
+       @export VERSION_FILE=${ROOT}/jni/src/android_version.h;                    \
+       export VERSION_FILE_NEW=$${VERSION_FILE}.new;                              \
+       {                                                                          \
+       echo "#ifndef ANDROID_MT_VERSION_H";                                       \
+       echo "#define ANDROID_MT_VERSION_H";                                       \
+       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 "#endif";                                                             \
+       } > $${VERSION_FILE_NEW};                                                  \
+       if ! cmp -s $${VERSION_FILE} $${VERSION_FILE_NEW}; then                    \
+               echo "android_version.h changed, updating...";                     \
+               mv "$${VERSION_FILE_NEW}" "$${VERSION_FILE}";                      \
+       else                                                                       \
+               rm "$${VERSION_FILE_NEW}";                                         \
+       fi
+
 manifest :
-       @VERS_MAJOR=$$(cat ${ROOT}/../../CMakeLists.txt |                          \
-       grep ^set\(VERSION_MAJOR\ | sed 's/)/ /' | awk '{print $$2;}');            \
-       VERS_MINOR=$$(cat ${ROOT}/../../CMakeLists.txt |                           \
-       grep ^set\(VERSION_MINOR\ | sed 's/)/ /' | awk '{print $$2;}');            \
-       VERS_PATCH=$$(cat ${ROOT}/../../CMakeLists.txt |                           \
-       grep ^set\(VERSION_PATCH\ | sed 's/)/ /' | awk '{print $$2;}');            \
-       BASE_VERSION="$$VERS_MAJOR.$$VERS_MINOR.$$VERS_PATCH";                     \
+       @BASE_VERSION="${VERSION_MAJOR}.${VERSION_MINOR}.${VERSION_PATCH}";        \
        if [ "${NDEBUG}x" != "x" ] ; then                                          \
                DBG='';                                                                \
                DBG_FLAG="android:debuggable=\"false\"";                               \
@@ -767,11 +879,11 @@ manifest :
                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 "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