From 3025e937f651542cc407ac434f2255960170cc72 Mon Sep 17 00:00:00 2001 From: Dhilan007 Date: Thu, 27 Nov 2014 21:56:06 +0800 Subject: [PATCH] Fixed compiling and linking error of new lua projects when using NDK r10 above. --- .../proj.android/build_native.py | 16 ++++++---------- .../proj.android/jni/Application.mk | 3 +-- .../runtime-src/proj.android/jni/Application.mk | 3 +-- 3 files changed, 8 insertions(+), 14 deletions(-) diff --git a/templates/cpp-template-default/proj.android/build_native.py b/templates/cpp-template-default/proj.android/build_native.py index 3df3041816..fdcdf9b0ac 100755 --- a/templates/cpp-template-default/proj.android/build_native.py +++ b/templates/cpp-template-default/proj.android/build_native.py @@ -43,20 +43,14 @@ def check_environment_variables(): return NDK_ROOT def select_toolchain_version(): - '''Because ndk-r8e uses gcc4.6 as default. gcc4.6 doesn't support c++11. So we should select gcc4.7 when - using ndk-r8e. But gcc4.7 is removed in ndk-r9, so we should determine whether gcc4.7 exist. - Conclution: - ndk-r8e -> use gcc4.7 - ndk-r9 -> use gcc4.8 - ''' ndk_root = check_environment_variables() - if os.path.isdir(os.path.join(ndk_root,"toolchains/arm-linux-androideabi-4.8")): + if os.path.isdir(os.path.join(ndk_root,"toolchains/arm-linux-androideabi-4.9")): + os.environ['NDK_TOOLCHAIN_VERSION'] = '4.9' + print "The Selected NDK toolchain version was 4.9 !" + elif os.path.isdir(os.path.join(ndk_root,"toolchains/arm-linux-androideabi-4.8")): os.environ['NDK_TOOLCHAIN_VERSION'] = '4.8' print "The Selected NDK toolchain version was 4.8 !" - elif os.path.isdir(os.path.join(ndk_root,"toolchains/arm-linux-androideabi-4.7")): - os.environ['NDK_TOOLCHAIN_VERSION'] = '4.7' - print "The Selected NDK toolchain version was 4.7 !" else: print "Couldn't find the gcc toolchain." exit(1) @@ -150,4 +144,6 @@ if __name__ == '__main__': help='the build mode for java project,debug[default] or release.Get more information,please refer to http://developer.android.com/tools/building/building-cmdline.html') (opts, args) = parser.parse_args() + print "We will remove this script next version,you should use cocos console to build android project.\n" + build(opts.ndk_build_param,opts.android_platform,opts.build_mode) diff --git a/templates/cpp-template-default/proj.android/jni/Application.mk b/templates/cpp-template-default/proj.android/jni/Application.mk index 59808706eb..07aa592b13 100644 --- a/templates/cpp-template-default/proj.android/jni/Application.mk +++ b/templates/cpp-template-default/proj.android/jni/Application.mk @@ -1,5 +1,4 @@ -APP_STL := c++_static -NDK_TOOLCHAIN_VERSION=clang +APP_STL := gnustl_static APP_CPPFLAGS := -frtti -DCC_ENABLE_CHIPMUNK_INTEGRATION=1 -std=c++11 -fsigned-char APP_LDFLAGS := -latomic diff --git a/templates/lua-template-default/frameworks/runtime-src/proj.android/jni/Application.mk b/templates/lua-template-default/frameworks/runtime-src/proj.android/jni/Application.mk index 59808706eb..07aa592b13 100644 --- a/templates/lua-template-default/frameworks/runtime-src/proj.android/jni/Application.mk +++ b/templates/lua-template-default/frameworks/runtime-src/proj.android/jni/Application.mk @@ -1,5 +1,4 @@ -APP_STL := c++_static -NDK_TOOLCHAIN_VERSION=clang +APP_STL := gnustl_static APP_CPPFLAGS := -frtti -DCC_ENABLE_CHIPMUNK_INTEGRATION=1 -std=c++11 -fsigned-char APP_LDFLAGS := -latomic