mirror of
https://github.com/Kitware/CMake.git
synced 2026-01-05 21:31:08 -06:00
XL: Use common compiler macros for language standard default
This commit is contained in:
@@ -12,21 +12,21 @@ string(APPEND CMAKE_C_FLAGS_INIT " -qthreaded")
|
|||||||
# little-endian, all versions on Linux ppc64 big-endian, all versions on AIX
|
# little-endian, all versions on Linux ppc64 big-endian, all versions on AIX
|
||||||
# and BGQ, etc) are derived from the UNIX compiler and only accept the
|
# and BGQ, etc) are derived from the UNIX compiler and only accept the
|
||||||
# -qlanglvl option.
|
# -qlanglvl option.
|
||||||
if (CMAKE_SYSTEM MATCHES "Linux.*ppc64le" AND
|
if (CMAKE_C_COMPILER_VERSION VERSION_GREATER_EQUAL 10.1)
|
||||||
CMAKE_C_COMPILER_VERSION VERSION_GREATER_EQUAL 13.1.1)
|
if (CMAKE_SYSTEM MATCHES "Linux.*ppc64le" AND
|
||||||
set(CMAKE_C90_STANDARD_COMPILE_OPTION "-std=c89")
|
CMAKE_C_COMPILER_VERSION VERSION_GREATER_EQUAL 13.1.1)
|
||||||
set(CMAKE_C90_EXTENSION_COMPILE_OPTION "-std=gnu89")
|
set(CMAKE_C90_STANDARD_COMPILE_OPTION "-std=c89")
|
||||||
set(CMAKE_C99_STANDARD_COMPILE_OPTION "-std=c99")
|
set(CMAKE_C90_EXTENSION_COMPILE_OPTION "-std=gnu89")
|
||||||
set(CMAKE_C99_EXTENSION_COMPILE_OPTION "-std=gnu99")
|
set(CMAKE_C99_STANDARD_COMPILE_OPTION "-std=c99")
|
||||||
if (CMAKE_C_COMPILER_VERSION VERSION_GREATER_EQUAL 13.1.2)
|
set(CMAKE_C99_EXTENSION_COMPILE_OPTION "-std=gnu99")
|
||||||
set(CMAKE_C11_STANDARD_COMPILE_OPTION "-std=c11")
|
if (CMAKE_C_COMPILER_VERSION VERSION_GREATER_EQUAL 13.1.2)
|
||||||
set(CMAKE_C11_EXTENSION_COMPILE_OPTION "-std=gnu11")
|
set(CMAKE_C11_STANDARD_COMPILE_OPTION "-std=c11")
|
||||||
|
set(CMAKE_C11_EXTENSION_COMPILE_OPTION "-std=gnu11")
|
||||||
|
else ()
|
||||||
|
set(CMAKE_C11_STANDARD_COMPILE_OPTION "-qlanglvl=extc1x")
|
||||||
|
set(CMAKE_C11_EXTENSION_COMPILE_OPTION "-qlanglvl=extc1x")
|
||||||
|
endif ()
|
||||||
else ()
|
else ()
|
||||||
set(CMAKE_C11_STANDARD_COMPILE_OPTION "-qlanglvl=extc1x")
|
|
||||||
set(CMAKE_C11_EXTENSION_COMPILE_OPTION "-qlanglvl=extc1x")
|
|
||||||
endif ()
|
|
||||||
else ()
|
|
||||||
if (CMAKE_C_COMPILER_VERSION VERSION_GREATER_EQUAL 10.1)
|
|
||||||
set(CMAKE_C90_STANDARD_COMPILE_OPTION "-qlanglvl=stdc89")
|
set(CMAKE_C90_STANDARD_COMPILE_OPTION "-qlanglvl=stdc89")
|
||||||
set(CMAKE_C90_EXTENSION_COMPILE_OPTION "-qlanglvl=extc89")
|
set(CMAKE_C90_EXTENSION_COMPILE_OPTION "-qlanglvl=extc89")
|
||||||
set(CMAKE_C99_STANDARD_COMPILE_OPTION "-qlanglvl=stdc99")
|
set(CMAKE_C99_STANDARD_COMPILE_OPTION "-qlanglvl=stdc99")
|
||||||
@@ -38,15 +38,4 @@ else ()
|
|||||||
endif ()
|
endif ()
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
if (CMAKE_C_COMPILER_VERSION VERSION_GREATER_EQUAL 10.1)
|
__compiler_check_default_language_standard(C 10.1 90)
|
||||||
if (NOT CMAKE_C_COMPILER_FORCED)
|
|
||||||
if (NOT CMAKE_C_STANDARD_COMPUTED_DEFAULT)
|
|
||||||
message(FATAL_ERROR "CMAKE_C_STANDARD_COMPUTED_DEFAULT should be set for ${CMAKE_C_COMPILER_ID} (${CMAKE_C_COMPILER}) version ${CMAKE_C_COMPILER_VERSION}")
|
|
||||||
else ()
|
|
||||||
set(CMAKE_C_STANDARD_DEFAULT ${CMAKE_C_STANDARD_COMPUTED_DEFAULT})
|
|
||||||
endif ()
|
|
||||||
elseif (NOT CMAKE_C_STANDARD_COMPUTED_DEFAULT)
|
|
||||||
# Compiler id was forced so just guess the default standard level.
|
|
||||||
set(CMAKE_C_STANDARD_DEFAULT 90)
|
|
||||||
endif ()
|
|
||||||
endif ()
|
|
||||||
|
|||||||
@@ -12,32 +12,30 @@ string(APPEND CMAKE_CXX_FLAGS_INIT " -qthreaded")
|
|||||||
# little-endian, all versions on Linux ppc64 big-endian, all versions on AIX
|
# little-endian, all versions on Linux ppc64 big-endian, all versions on AIX
|
||||||
# and BGQ, etc) are derived from the UNIX compiler and only accept the
|
# and BGQ, etc) are derived from the UNIX compiler and only accept the
|
||||||
# -qlanglvl option.
|
# -qlanglvl option.
|
||||||
if (CMAKE_SYSTEM MATCHES "Linux.*ppc64")
|
if (CMAKE_CXX_COMPILER_VERSION VERSION_GREATER_EQUAL 10.1)
|
||||||
if (CMAKE_SYSTEM MATCHES "Linux.*ppc64le" AND
|
if (CMAKE_SYSTEM MATCHES "Linux.*ppc64")
|
||||||
CMAKE_CXX_COMPILER_VERSION VERSION_GREATER_EQUAL 13.1.1)
|
if (CMAKE_SYSTEM MATCHES "Linux.*ppc64le" AND
|
||||||
set(CMAKE_CXX98_STANDARD_COMPILE_OPTION "-std=c++98")
|
CMAKE_CXX_COMPILER_VERSION VERSION_GREATER_EQUAL 13.1.1)
|
||||||
set(CMAKE_CXX98_EXTENSION_COMPILE_OPTION "-std=gnu++98")
|
set(CMAKE_CXX98_STANDARD_COMPILE_OPTION "-std=c++98")
|
||||||
if (CMAKE_CXX_COMPILER_VERSION VERSION_GREATER_EQUAL 13.1.2)
|
set(CMAKE_CXX98_EXTENSION_COMPILE_OPTION "-std=gnu++98")
|
||||||
set(CMAKE_CXX11_STANDARD_COMPILE_OPTION "-std=c++11")
|
if (CMAKE_CXX_COMPILER_VERSION VERSION_GREATER_EQUAL 13.1.2)
|
||||||
set(CMAKE_CXX11_EXTENSION_COMPILE_OPTION "-std=gnu++11")
|
set(CMAKE_CXX11_STANDARD_COMPILE_OPTION "-std=c++11")
|
||||||
set(CMAKE_CXX14_STANDARD_COMPILE_OPTION "-std=c++1y")
|
set(CMAKE_CXX11_EXTENSION_COMPILE_OPTION "-std=gnu++11")
|
||||||
set(CMAKE_CXX14_EXTENSION_COMPILE_OPTION "-qlanglvl=extended1y")
|
set(CMAKE_CXX14_STANDARD_COMPILE_OPTION "-std=c++1y")
|
||||||
|
set(CMAKE_CXX14_EXTENSION_COMPILE_OPTION "-qlanglvl=extended1y")
|
||||||
|
else ()
|
||||||
|
set(CMAKE_CXX11_STANDARD_COMPILE_OPTION "-qlanglvl=extended0x")
|
||||||
|
set(CMAKE_CXX11_EXTENSION_COMPILE_OPTION "-qlanglvl=extended0x")
|
||||||
|
endif ()
|
||||||
else ()
|
else ()
|
||||||
set(CMAKE_CXX11_STANDARD_COMPILE_OPTION "-qlanglvl=extended0x")
|
# The non-clang based Linux ppc64 compiler, both big-endian and
|
||||||
set(CMAKE_CXX11_EXTENSION_COMPILE_OPTION "-qlanglvl=extended0x")
|
# little-endian lacks, the non-extension language level flags
|
||||||
endif ()
|
|
||||||
else ()
|
|
||||||
# The non-clang based Linux ppc64 compiler, both big-endian and
|
|
||||||
# little-endian lacks, the non-extension language level flags
|
|
||||||
if (CMAKE_CXX_COMPILER_VERSION VERSION_GREATER_EQUAL 10.1)
|
|
||||||
set(CMAKE_CXX98_STANDARD_COMPILE_OPTION "-qlanglvl=extended")
|
set(CMAKE_CXX98_STANDARD_COMPILE_OPTION "-qlanglvl=extended")
|
||||||
set(CMAKE_CXX98_EXTENSION_COMPILE_OPTION "-qlanglvl=extended")
|
set(CMAKE_CXX98_EXTENSION_COMPILE_OPTION "-qlanglvl=extended")
|
||||||
set(CMAKE_CXX11_STANDARD_COMPILE_OPTION "-qlanglvl=extended0x")
|
set(CMAKE_CXX11_STANDARD_COMPILE_OPTION "-qlanglvl=extended0x")
|
||||||
set(CMAKE_CXX11_EXTENSION_COMPILE_OPTION "-qlanglvl=extended0x")
|
set(CMAKE_CXX11_EXTENSION_COMPILE_OPTION "-qlanglvl=extended0x")
|
||||||
endif ()
|
endif ()
|
||||||
endif ()
|
else ()
|
||||||
else ()
|
|
||||||
if (CMAKE_CXX_COMPILER_VERSION VERSION_GREATER_EQUAL 10.1)
|
|
||||||
set(CMAKE_CXX98_STANDARD_COMPILE_OPTION "-qlanglvl=strict98")
|
set(CMAKE_CXX98_STANDARD_COMPILE_OPTION "-qlanglvl=strict98")
|
||||||
set(CMAKE_CXX98_EXTENSION_COMPILE_OPTION "-qlanglvl=extended")
|
set(CMAKE_CXX98_EXTENSION_COMPILE_OPTION "-qlanglvl=extended")
|
||||||
set(CMAKE_CXX11_STANDARD_COMPILE_OPTION "-qlanglvl=extended0x")
|
set(CMAKE_CXX11_STANDARD_COMPILE_OPTION "-qlanglvl=extended0x")
|
||||||
@@ -45,18 +43,7 @@ else ()
|
|||||||
endif ()
|
endif ()
|
||||||
endif ()
|
endif ()
|
||||||
|
|
||||||
|
__compiler_check_default_language_standard(CXX 10.1 98)
|
||||||
|
|
||||||
set(CMAKE_CXX_COMPILE_OBJECT
|
set(CMAKE_CXX_COMPILE_OBJECT
|
||||||
"<CMAKE_CXX_COMPILER> -+ <DEFINES> <INCLUDES> <FLAGS> -o <OBJECT> -c <SOURCE>")
|
"<CMAKE_CXX_COMPILER> -+ <DEFINES> <INCLUDES> <FLAGS> -o <OBJECT> -c <SOURCE>")
|
||||||
|
|
||||||
if (CMAKE_CXX_COMPILER_VERSION VERSION_GREATER_EQUAL 10.1)
|
|
||||||
if (NOT CMAKE_CXX_COMPILER_FORCED)
|
|
||||||
if (NOT CMAKE_CXX_STANDARD_COMPUTED_DEFAULT)
|
|
||||||
message(FATAL_ERROR "CMAKE_CXX_STANDARD_COMPUTED_DEFAULT should be set for ${CMAKE_CXX_COMPILER_ID} (${CMAKE_CXX_COMPILER}) version ${CMAKE_CXX_COMPILER_VERSION}")
|
|
||||||
else ()
|
|
||||||
set(CMAKE_CXX_STANDARD_DEFAULT ${CMAKE_CXX_STANDARD_COMPUTED_DEFAULT})
|
|
||||||
endif ()
|
|
||||||
elseif (NOT CMAKE_CXX_STANDARD_COMPUTED_DEFAULT)
|
|
||||||
# Compiler id was forced so just guess the default standard level.
|
|
||||||
set(CMAKE_CXX_STANDARD_DEFAULT 98)
|
|
||||||
endif ()
|
|
||||||
endif ()
|
|
||||||
|
|||||||
@@ -8,6 +8,8 @@ if(__COMPILER_XL)
|
|||||||
endif()
|
endif()
|
||||||
set(__COMPILER_XL 1)
|
set(__COMPILER_XL 1)
|
||||||
|
|
||||||
|
include(Compiler/CMakeCommonCompilerMacros)
|
||||||
|
|
||||||
# Find the CreateExportList program that comes with this toolchain.
|
# Find the CreateExportList program that comes with this toolchain.
|
||||||
find_program(CMAKE_XL_CreateExportList
|
find_program(CMAKE_XL_CreateExportList
|
||||||
NAMES CreateExportList
|
NAMES CreateExportList
|
||||||
|
|||||||
Reference in New Issue
Block a user