mirror of
https://github.com/Kitware/CMake.git
synced 2026-01-04 04:40:56 -06:00
This was done for C++ by commit v3.5.0-rc1~69^2 (Record compile features for MinGW Clang on Windows, 2016-01-11). Make the same change for C. The `UNIX` condition on Clang C compiler features was already dropped by refactoring in commit v3.9.0-rc1~17^2~4 (Compilers: Port to use default cmake_record_lang_compile_features macros, 2017-05-10). Our documentation already claims support for this combination. This was simply an oversight when support was added for MinGW Clang C++. Issue: #15897 Issue: #15943
37 lines
1.1 KiB
CMake
37 lines
1.1 KiB
CMake
include(Compiler/Clang)
|
|
__compiler_clang(C)
|
|
|
|
cmake_policy(GET CMP0025 appleClangPolicy)
|
|
if(APPLE AND NOT appleClangPolicy STREQUAL NEW)
|
|
return()
|
|
endif()
|
|
|
|
if(NOT CMAKE_C_COMPILER_VERSION VERSION_LESS 3.4)
|
|
if(NOT "x${CMAKE_C_SIMULATE_ID}" STREQUAL "xMSVC")
|
|
set(CMAKE_C90_STANDARD_COMPILE_OPTION "-std=c90")
|
|
set(CMAKE_C90_EXTENSION_COMPILE_OPTION "-std=gnu90")
|
|
|
|
set(CMAKE_C99_STANDARD_COMPILE_OPTION "-std=c99")
|
|
set(CMAKE_C99_EXTENSION_COMPILE_OPTION "-std=gnu99")
|
|
|
|
set(CMAKE_C11_STANDARD_COMPILE_OPTION "-std=c11")
|
|
set(CMAKE_C11_EXTENSION_COMPILE_OPTION "-std=gnu11")
|
|
else()
|
|
# clang-cl doesn't have any of these
|
|
set(CMAKE_C90_STANDARD_COMPILE_OPTION "")
|
|
set(CMAKE_C90_EXTENSION_COMPILE_OPTION "")
|
|
|
|
set(CMAKE_C99_STANDARD_COMPILE_OPTION "")
|
|
set(CMAKE_C99_EXTENSION_COMPILE_OPTION "")
|
|
|
|
set(CMAKE_C11_STANDARD_COMPILE_OPTION "")
|
|
set(CMAKE_C11_EXTENSION_COMPILE_OPTION "")
|
|
endif()
|
|
endif()
|
|
|
|
if(NOT "x${CMAKE_C_SIMULATE_ID}" STREQUAL "xMSVC")
|
|
__compiler_check_default_language_standard(C 3.4 99 3.6 11)
|
|
else()
|
|
set(CMAKE_C_STANDARD_DEFAULT "")
|
|
endif()
|