CMake: Additional fixes/tweaks for C++11 on macOS
The changes in 0a94c1890f
where an
incomplete solution.
The apple compiler automatically choses libc++ if the deployment target
is >= 10.9. Lower deployment targets need explicit compiler options
to use libc++.
This commit is contained in:
@@ -20,12 +20,7 @@ endif()
|
|||||||
if(APPLE AND NOT CMAKE_OSX_DEPLOYMENT_TARGET)
|
if(APPLE AND NOT CMAKE_OSX_DEPLOYMENT_TARGET)
|
||||||
# If no deployment target has been set default to the minimum supported
|
# If no deployment target has been set default to the minimum supported
|
||||||
# OS X version (this has to be set before the first project() call)
|
# OS X version (this has to be set before the first project() call)
|
||||||
if(CMAKE_CXX_STANDARD EQUAL 11 OR CMAKE_CXX_STANDARD EQUAL 14)
|
set(CMAKE_OSX_DEPLOYMENT_TARGET 10.7 CACHE STRING "OS X Deployment Target")
|
||||||
set(OSX_DEFAULT_DEPLOYMENT_TARGET 10.9)
|
|
||||||
else()
|
|
||||||
set(OSX_DEFAULT_DEPLOYMENT_TARGET 10.7)
|
|
||||||
endif()
|
|
||||||
set(CMAKE_OSX_DEPLOYMENT_TARGET ${OSX_DEFAULT_DEPLOYMENT_TARGET} CACHE STRING "OS X Deployment Target")
|
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
project(wxWidgets)
|
project(wxWidgets)
|
||||||
|
@@ -73,16 +73,18 @@ function(wx_set_common_target_properties target_name)
|
|||||||
if(DEFINED wxBUILD_CXX_STANDARD AND NOT wxBUILD_CXX_STANDARD STREQUAL COMPILER_DEFAULT)
|
if(DEFINED wxBUILD_CXX_STANDARD AND NOT wxBUILD_CXX_STANDARD STREQUAL COMPILER_DEFAULT)
|
||||||
# TODO: implement for older CMake versions ?
|
# TODO: implement for older CMake versions ?
|
||||||
set_target_properties(${target_name} PROPERTIES CXX_STANDARD ${wxBUILD_CXX_STANDARD})
|
set_target_properties(${target_name} PROPERTIES CXX_STANDARD ${wxBUILD_CXX_STANDARD})
|
||||||
if(wxBUILD_CXX_STANDARD EQUAL 11 OR wxBUILD_CXX_STANDARD EQUAL 14)
|
if(
|
||||||
if (APPLE)
|
APPLE AND
|
||||||
if(CMAKE_GENERATOR EQUAL "Xcode")
|
CMAKE_OSX_DEPLOYMENT_TARGET VERSION_LESS 10.9 AND
|
||||||
|
(wxBUILD_CXX_STANDARD EQUAL 11 OR wxBUILD_CXX_STANDARD EQUAL 14)
|
||||||
|
)
|
||||||
|
if(CMAKE_GENERATOR STREQUAL "Xcode")
|
||||||
set_target_properties(${target_name} PROPERTIES XCODE_ATTRIBUTE_CLANG_CXX_LIBRARY libc++)
|
set_target_properties(${target_name} PROPERTIES XCODE_ATTRIBUTE_CLANG_CXX_LIBRARY libc++)
|
||||||
else()
|
else()
|
||||||
target_compile_options(${target_name} PUBLIC "-stdlib=libc++")
|
target_compile_options(${target_name} PUBLIC "-stdlib=libc++")
|
||||||
|
target_link_libraries(${target_name} PRIVATE "-stdlib=libc++")
|
||||||
endif()
|
endif()
|
||||||
endif()
|
endif()
|
||||||
#TODO: define for other generators than Xcode
|
|
||||||
endif()
|
|
||||||
endif()
|
endif()
|
||||||
set_target_properties(${target_name} PROPERTIES
|
set_target_properties(${target_name} PROPERTIES
|
||||||
LIBRARY_OUTPUT_DIRECTORY "${wxOUTPUT_DIR}${wxPLATFORM_LIB_DIR}"
|
LIBRARY_OUTPUT_DIRECTORY "${wxOUTPUT_DIR}${wxPLATFORM_LIB_DIR}"
|
||||||
@@ -363,7 +365,7 @@ macro(wx_exe_link_libraries name)
|
|||||||
if(wxBUILD_MONOLITHIC)
|
if(wxBUILD_MONOLITHIC)
|
||||||
target_link_libraries(${name} PUBLIC mono)
|
target_link_libraries(${name} PUBLIC mono)
|
||||||
else()
|
else()
|
||||||
target_link_libraries(${name};${ARGN})
|
target_link_libraries(${name};PRIVATE;${ARGN})
|
||||||
endif()
|
endif()
|
||||||
endmacro()
|
endmacro()
|
||||||
|
|
||||||
|
@@ -23,6 +23,14 @@ include(CheckTypeSize)
|
|||||||
include(CMakePushCheckState)
|
include(CMakePushCheckState)
|
||||||
include(TestBigEndian)
|
include(TestBigEndian)
|
||||||
|
|
||||||
|
if(
|
||||||
|
APPLE AND
|
||||||
|
CMAKE_OSX_DEPLOYMENT_TARGET VERSION_LESS 10.9 AND
|
||||||
|
(CMAKE_CXX_STANDARD EQUAL 11 OR CMAKE_CXX_STANDARD EQUAL 14)
|
||||||
|
)
|
||||||
|
set(CMAKE_REQUIRED_FLAGS ${CMAKE_REQUIRED_FLAGS} "-stdlib=libc++")
|
||||||
|
endif()
|
||||||
|
|
||||||
# Add a definition to setup.h and append it to a list of defines for
|
# Add a definition to setup.h and append it to a list of defines for
|
||||||
# for compile checks
|
# for compile checks
|
||||||
macro(wx_setup_definition def)
|
macro(wx_setup_definition def)
|
||||||
|
Reference in New Issue
Block a user