mirror of
https://github.com/overte-org/overte.git
synced 2025-08-09 06:18:52 +02:00
use libc++ and clang toolchain
This commit is contained in:
parent
aea60692de
commit
47f15f6ad8
4 changed files with 69 additions and 30 deletions
|
@ -3,6 +3,8 @@ cmake_minimum_required(VERSION 3.2)
|
||||||
if (USE_ANDROID_TOOLCHAIN)
|
if (USE_ANDROID_TOOLCHAIN)
|
||||||
set(CMAKE_TOOLCHAIN_FILE "${CMAKE_CURRENT_SOURCE_DIR}/cmake/android/android.toolchain.cmake")
|
set(CMAKE_TOOLCHAIN_FILE "${CMAKE_CURRENT_SOURCE_DIR}/cmake/android/android.toolchain.cmake")
|
||||||
set(ANDROID_NATIVE_API_LEVEL 19)
|
set(ANDROID_NATIVE_API_LEVEL 19)
|
||||||
|
set(ANDROID_TOOLCHAIN_NAME arm-linux-androideabi-clang3.5)
|
||||||
|
set(ANDROID_STL c++_static)
|
||||||
endif ()
|
endif ()
|
||||||
|
|
||||||
if (WIN32)
|
if (WIN32)
|
||||||
|
@ -64,7 +66,7 @@ if (WIN32)
|
||||||
set(CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} /DEBUG /OPT:REF /OPT:ICF")
|
set(CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} /DEBUG /OPT:REF /OPT:ICF")
|
||||||
else ()
|
else ()
|
||||||
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wall -Wextra -fno-strict-aliasing -Wno-unused-parameter")
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wall -Wextra -fno-strict-aliasing -Wno-unused-parameter")
|
||||||
if (CMAKE_COMPILER_IS_GNUCC OR CMAKE_COMPILER_IS_GNUCXX)
|
if (CMAKE_CXX_COMPILER_ID MATCHES "GNU")
|
||||||
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -ggdb -Woverloaded-virtual -Wdouble-promotion")
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -ggdb -Woverloaded-virtual -Wdouble-promotion")
|
||||||
if (CMAKE_CXX_COMPILER_VERSION VERSION_GREATER "5.1") # gcc 5.1 and on have suggest-override
|
if (CMAKE_CXX_COMPILER_VERSION VERSION_GREATER "5.1") # gcc 5.1 and on have suggest-override
|
||||||
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wsuggest-override")
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wsuggest-override")
|
||||||
|
@ -72,6 +74,7 @@ else ()
|
||||||
endif ()
|
endif ()
|
||||||
endif(WIN32)
|
endif(WIN32)
|
||||||
|
|
||||||
|
if (NOT ANDROID)
|
||||||
if ((NOT MSVC12) AND (NOT MSVC14))
|
if ((NOT MSVC12) AND (NOT MSVC14))
|
||||||
include(CheckCXXCompilerFlag)
|
include(CheckCXXCompilerFlag)
|
||||||
CHECK_CXX_COMPILER_FLAG("-std=c++11" COMPILER_SUPPORTS_CXX11)
|
CHECK_CXX_COMPILER_FLAG("-std=c++11" COMPILER_SUPPORTS_CXX11)
|
||||||
|
@ -85,6 +88,10 @@ if ((NOT MSVC12) AND (NOT MSVC14))
|
||||||
message(STATUS "The compiler ${CMAKE_CXX_COMPILER} has no C++11 support. Please use a different C++ compiler.")
|
message(STATUS "The compiler ${CMAKE_CXX_COMPILER} has no C++11 support. Please use a different C++ compiler.")
|
||||||
endif()
|
endif()
|
||||||
endif ()
|
endif ()
|
||||||
|
else ()
|
||||||
|
# assume that the toolchain selected for android has C++11 support
|
||||||
|
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -std=c++11")
|
||||||
|
endif ()
|
||||||
|
|
||||||
if (APPLE)
|
if (APPLE)
|
||||||
set(CMAKE_XCODE_ATTRIBUTE_CLANG_CXX_LANGUAGE_STANDARD "c++0x")
|
set(CMAKE_XCODE_ATTRIBUTE_CLANG_CXX_LANGUAGE_STANDARD "c++0x")
|
||||||
|
|
|
@ -154,6 +154,8 @@
|
||||||
# Implies -frtti -fno-exceptions.
|
# Implies -frtti -fno-exceptions.
|
||||||
# Available for NDK r7b and newer.
|
# Available for NDK r7b and newer.
|
||||||
# Silently degrades to gnustl_static if not available.
|
# Silently degrades to gnustl_static if not available.
|
||||||
|
# c++_static -> Use the LLVM libc++ runtime as a static library.
|
||||||
|
# c++_shared -> Use the LLVM libc++ runtime as a shared library.
|
||||||
#
|
#
|
||||||
# ANDROID_STL_FORCE_FEATURES=ON - turn rtti and exceptions support based on
|
# ANDROID_STL_FORCE_FEATURES=ON - turn rtti and exceptions support based on
|
||||||
# chosen runtime. If disabled, then the user is responsible for settings
|
# chosen runtime. If disabled, then the user is responsible for settings
|
||||||
|
@ -833,7 +835,7 @@ set( ANDROID_STL_FORCE_FEATURES ON CACHE BOOL "automatically configure rtti and
|
||||||
mark_as_advanced( ANDROID_STL ANDROID_STL_FORCE_FEATURES )
|
mark_as_advanced( ANDROID_STL ANDROID_STL_FORCE_FEATURES )
|
||||||
|
|
||||||
if( BUILD_WITH_ANDROID_NDK )
|
if( BUILD_WITH_ANDROID_NDK )
|
||||||
if( NOT "${ANDROID_STL}" MATCHES "^(none|system|system_re|gabi\\+\\+_static|gabi\\+\\+_shared|stlport_static|stlport_shared|gnustl_static|gnustl_shared)$")
|
if( NOT "${ANDROID_STL}" MATCHES "^(none|system|system_re|gabi\\+\\+_static|gabi\\+\\+_shared|stlport_static|stlport_shared|gnustl_static|gnustl_shared|c\\+\\+_static|c\\+\\+_shared)$")
|
||||||
message( FATAL_ERROR "ANDROID_STL is set to invalid value \"${ANDROID_STL}\".
|
message( FATAL_ERROR "ANDROID_STL is set to invalid value \"${ANDROID_STL}\".
|
||||||
The possible values are:
|
The possible values are:
|
||||||
none -> Do not configure the runtime.
|
none -> Do not configure the runtime.
|
||||||
|
@ -845,6 +847,8 @@ The possible values are:
|
||||||
stlport_shared -> Use the STLport runtime as a shared library.
|
stlport_shared -> Use the STLport runtime as a shared library.
|
||||||
gnustl_static -> (default) Use the GNU STL as a static library.
|
gnustl_static -> (default) Use the GNU STL as a static library.
|
||||||
gnustl_shared -> Use the GNU STL as a shared library.
|
gnustl_shared -> Use the GNU STL as a shared library.
|
||||||
|
c++_static -> Use the LLVM libc++ runtime as a static library.
|
||||||
|
c++_shared -> Use the LLVM libc++ runtime as a shared library.
|
||||||
" )
|
" )
|
||||||
endif()
|
endif()
|
||||||
elseif( BUILD_WITH_STANDALONE_TOOLCHAIN )
|
elseif( BUILD_WITH_STANDALONE_TOOLCHAIN )
|
||||||
|
@ -1026,6 +1030,34 @@ if( BUILD_WITH_ANDROID_NDK )
|
||||||
else()
|
else()
|
||||||
set( __libstl "${__libstl}/libs/${ANDROID_NDK_ABI_NAME}/libstdc++.a" )
|
set( __libstl "${__libstl}/libs/${ANDROID_NDK_ABI_NAME}/libstdc++.a" )
|
||||||
endif()
|
endif()
|
||||||
|
elseif( ANDROID_STL MATCHES "c\\+\\+_shared" OR ANDROID_STL MATCHES "c\\+\\+_static" )
|
||||||
|
set( ANDROID_EXCEPTIONS ON )
|
||||||
|
set( ANDROID_RTTI ON )
|
||||||
|
set( ANDROID_CXX_ROOT "${ANDROID_NDK}/sources/cxx-stl/" )
|
||||||
|
set( ANDROID_LLVM_ROOT "${ANDROID_CXX_ROOT}/llvm-libc++" )
|
||||||
|
|
||||||
|
if( X86 )
|
||||||
|
set( ANDROID_ABI_INCLUDE_DIRS "${ANDROID_CXX_ROOT}/gabi++/include" )
|
||||||
|
else()
|
||||||
|
set( ANDROID_ABI_INCLUDE_DIRS "${ANDROID_CXX_ROOT}/llvm-libc++abi/include" )
|
||||||
|
endif()
|
||||||
|
|
||||||
|
set( ANDROID_STL_INCLUDE_DIRS "${ANDROID_LLVM_ROOT}/libcxx/include" "${ANDROID_ABI_INCLUDE_DIRS}" )
|
||||||
|
|
||||||
|
# android support sfiles
|
||||||
|
include_directories ( SYSTEM ${ANDROID_NDK}/sources/android/support/include )
|
||||||
|
|
||||||
|
if(ANDROID_STL MATCHES "c\\+\\+_shared")
|
||||||
|
set ( LLVM_LIBRARY_NAME "libc++_shared.so")
|
||||||
|
else()
|
||||||
|
set ( LLVM_LIBRARY_NAME "libc++_static.a" )
|
||||||
|
endif ()
|
||||||
|
|
||||||
|
if( EXISTS "${ANDROID_LLVM_ROOT}/libs/${ANDROID_NDK_ABI_NAME}/${LLVM_LIBRARY_NAME}" )
|
||||||
|
set( __libstl "${ANDROID_LLVM_ROOT}/libs/${ANDROID_NDK_ABI_NAME}/${LLVM_LIBRARY_NAME}" )
|
||||||
|
else()
|
||||||
|
message( FATAL_ERROR "Could not find libc++ library" )
|
||||||
|
endif()
|
||||||
else()
|
else()
|
||||||
message( FATAL_ERROR "Unknown runtime: ${ANDROID_STL}" )
|
message( FATAL_ERROR "Unknown runtime: ${ANDROID_STL}" )
|
||||||
endif()
|
endif()
|
||||||
|
|
Loading…
Reference in a new issue