mirror of
https://github.com/Kitware/CMake.git
synced 2026-01-03 04:10:05 -06:00
Revert commit 5b45a3d0ce (CheckCompilerFlag: Match the Clang "argument
unused" output for all languages, 2023-01-23, v3.26.0-rc1~38^2). It
broke existing projects that were silently tolerating unrelated unused
arguments in their checks for C and CXX. For example, using
`CFLAGS=-nostdinc` or `CXXFLAGS=-nostdinc++` causes those flags to be
used when driving the linker as well, and Clang warns they are unused in
that case.
Add a test case covering the now-restored behavior.
Fixes: #24591
43 lines
1.4 KiB
CMake
43 lines
1.4 KiB
CMake
|
|
enable_language (C)
|
|
include(CheckCompilerFlag)
|
|
|
|
set(C 1) # test that this is tolerated
|
|
|
|
# test that the check uses an isolated locale
|
|
set(_env_LC_ALL "${LC_ALL}")
|
|
set(ENV{LC_ALL} "BAD")
|
|
|
|
check_compiler_flag(C "-_this_is_not_a_flag_" SHOULD_FAIL)
|
|
if(SHOULD_FAIL)
|
|
message(SEND_ERROR "invalid C compile flag didn't fail.")
|
|
endif()
|
|
|
|
if(CMAKE_C_COMPILER_ID MATCHES "GNU|LCC|Clang" AND NOT "x${CMAKE_C_SIMULATE_ID}" STREQUAL "xMSVC")
|
|
check_compiler_flag(C "-x c" SHOULD_WORK)
|
|
if(NOT SHOULD_WORK)
|
|
message(SEND_ERROR "${CMAKE_C_COMPILER_ID} compiler flag '-x c' check failed")
|
|
endif()
|
|
|
|
block()
|
|
# Test tolerating a flag that is not used when driving the linker.
|
|
string(APPEND CMAKE_C_FLAGS " -nostdinc")
|
|
check_compiler_flag(C "-x c" SHOULD_WORK_NOSTDINC)
|
|
if(NOT SHOULD_WORK_NOSTDINC)
|
|
message(SEND_ERROR "${CMAKE_C_COMPILER_ID} compiler flag '-x c -nostdinc' check failed")
|
|
endif()
|
|
endblock()
|
|
endif()
|
|
|
|
if(CMAKE_C_COMPILER_ID STREQUAL "GNU") # LCC C compiler silently ignore -frtti instead of failing, so skip it here.
|
|
check_compiler_flag(C "-frtti" SHOULD_FAIL_RTTI)
|
|
if(SHOULD_FAIL_RTTI)
|
|
message(SEND_ERROR "${CMAKE_C_COMPILER_ID} compiler flag '-frtti' check passed but should have failed")
|
|
endif()
|
|
endif()
|
|
|
|
if(NOT "$ENV{LC_ALL}" STREQUAL "BAD")
|
|
message(SEND_ERROR "ENV{LC_ALL} was not preserved by check_compiler_flag")
|
|
endif()
|
|
set(ENV{LC_ALL} ${_env_LC_ALL})
|