remove -fpermissive compiler flag
Remove -fpermissive from the list of flags passed to gcc and clang. Remove -fpermissive from the cxxflags from wxWidgets config as well. When checking wxWidgets ABI compatibility version, temporarily add -fpermissive to compiler flags on Win32 because minhook requires it.
This commit is contained in:
parent
571ecbe3e8
commit
bfe21aee3e
|
@ -427,7 +427,7 @@ if(CMAKE_COMPILER_IS_GNUCXX OR CMAKE_CXX_COMPILER_ID STREQUAL Clang)
|
||||||
add_compile_options(${C_COMPILE_FLAG})
|
add_compile_options(${C_COMPILE_FLAG})
|
||||||
endforeach()
|
endforeach()
|
||||||
|
|
||||||
set(MY_CXX_FLAGS -std=gnu++11 -fpermissive -fexceptions)
|
set(MY_CXX_FLAGS -std=gnu++11 -fexceptions)
|
||||||
|
|
||||||
foreach(ARG ${MY_CXX_FLAGS})
|
foreach(ARG ${MY_CXX_FLAGS})
|
||||||
set(MY_CXX_FLAGS_STR "${MY_CXX_FLAGS_STR} ${ARG}")
|
set(MY_CXX_FLAGS_STR "${MY_CXX_FLAGS_STR} ${ARG}")
|
||||||
|
|
|
@ -65,6 +65,10 @@ function(normalize_wx_paths)
|
||||||
endif()
|
endif()
|
||||||
endfunction()
|
endfunction()
|
||||||
|
|
||||||
|
macro(cleanup_wx_vars)
|
||||||
|
list(REMOVE_ITEM wxWidgets_CXX_FLAGS -fpermissive)
|
||||||
|
endmacro()
|
||||||
|
|
||||||
if(CMAKE_PREFIX_PATH)
|
if(CMAKE_PREFIX_PATH)
|
||||||
set(wxWidgets_CONFIG_OPTIONS "--prefix=${CMAKE_PREFIX_PATH}")
|
set(wxWidgets_CONFIG_OPTIONS "--prefix=${CMAKE_PREFIX_PATH}")
|
||||||
endif()
|
endif()
|
||||||
|
@ -88,6 +92,7 @@ endif()
|
||||||
# do a compile test later
|
# do a compile test later
|
||||||
list(APPEND wxWidgets_USE_LIBS gl)
|
list(APPEND wxWidgets_USE_LIBS gl)
|
||||||
find_package(wxWidgets QUIET)
|
find_package(wxWidgets QUIET)
|
||||||
|
cleanup_wx_vars()
|
||||||
normalize_wx_paths()
|
normalize_wx_paths()
|
||||||
|
|
||||||
SET(CHECK_WX_OPENGL FALSE)
|
SET(CHECK_WX_OPENGL FALSE)
|
||||||
|
@ -153,8 +158,9 @@ ENDIF()
|
||||||
IF(NOT WX_HAS_OPENGL)
|
IF(NOT WX_HAS_OPENGL)
|
||||||
ADD_DEFINITIONS(-DNO_OGL)
|
ADD_DEFINITIONS(-DNO_OGL)
|
||||||
LIST(REMOVE_ITEM wxWidgets_USE_LIBS gl)
|
LIST(REMOVE_ITEM wxWidgets_USE_LIBS gl)
|
||||||
FIND_PACKAGE(wxWidgets REQUIRED)
|
find_package(wxWidgets REQUIRED)
|
||||||
normalize_wx_paths()
|
normalize_wx_paths()
|
||||||
|
cleanup_wx_vars()
|
||||||
ENDIF()
|
ENDIF()
|
||||||
|
|
||||||
IF(CMAKE_COMPILER_IS_GNUCXX AND NOT CMAKE_CROSSCOMPILING)
|
IF(CMAKE_COMPILER_IS_GNUCXX AND NOT CMAKE_CROSSCOMPILING)
|
||||||
|
@ -233,7 +239,9 @@ int main(int argc, char** argv)
|
||||||
|
|
||||||
# on windows we need the trampoline library from dependencies
|
# on windows we need the trampoline library from dependencies
|
||||||
IF(WIN32)
|
IF(WIN32)
|
||||||
SET(CMAKE_REQUIRED_DEFINITIONS ${CMAKE_REQUIRED_DEFINITIONS} -w -fpermissive "-I${CMAKE_SOURCE_DIR}/dependencies/minhook/include")
|
# minhook requires -fpermissive unfortunately
|
||||||
|
set(CMAKE_REQUIRED_FLAGS ${CMAKE_REQUIRED_FLAGS} -fpermissive)
|
||||||
|
SET(CMAKE_REQUIRED_DEFINITIONS ${CMAKE_REQUIRED_DEFINITIONS} -fpermissive -w "-I${CMAKE_SOURCE_DIR}/dependencies/minhook/include")
|
||||||
SET(CMAKE_REQUIRED_LIBRARIES ${CMAKE_REQUIRED_LIBRARIES} -Wl,--subsystem,console)
|
SET(CMAKE_REQUIRED_LIBRARIES ${CMAKE_REQUIRED_LIBRARIES} -Wl,--subsystem,console)
|
||||||
|
|
||||||
IF(AMD64)
|
IF(AMD64)
|
||||||
|
@ -245,6 +253,10 @@ int main(int argc, char** argv)
|
||||||
|
|
||||||
CHECK_CXX_SOURCE_RUNS("${WX_TEST_CONSOLE_APP}" WX_DEFAULT_ABI_VERSION_COMPATIBLE)
|
CHECK_CXX_SOURCE_RUNS("${WX_TEST_CONSOLE_APP}" WX_DEFAULT_ABI_VERSION_COMPATIBLE)
|
||||||
|
|
||||||
|
# remove -fpermissive set for minhook
|
||||||
|
list(REMOVE_ITEM CMAKE_REQUIRED_FLAGS -fpermissive)
|
||||||
|
list(REMOVE_ITEM CMAKE_REQUIRED_DEFINITIONS -fpermissive)
|
||||||
|
|
||||||
IF(NOT WX_DEFAULT_ABI_VERSION_COMPATIBLE)
|
IF(NOT WX_DEFAULT_ABI_VERSION_COMPATIBLE)
|
||||||
# currently goes up to 11 with gcc7, but we give it some room
|
# currently goes up to 11 with gcc7, but we give it some room
|
||||||
SET(WX_ABI_VERSION 15)
|
SET(WX_ABI_VERSION 15)
|
||||||
|
|
Loading…
Reference in New Issue