From ee751ac767dfa8a65d4c9fa26672ceabab22640d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Timo=20R=C3=B6hling?= Date: Fri, 22 Oct 2021 14:23:23 +0200 Subject: [PATCH] Fix check_symbols_exists() with -pedantic-errors Closes: #777542 --- ...k_symbol_exists-with-pedantic-errors.patch | 64 +++++++++++++++++++ debian/patches/series | 1 + 2 files changed, 65 insertions(+) create mode 100644 debian/patches/0006-Fix-check_symbol_exists-with-pedantic-errors.patch diff --git a/debian/patches/0006-Fix-check_symbol_exists-with-pedantic-errors.patch b/debian/patches/0006-Fix-check_symbol_exists-with-pedantic-errors.patch new file mode 100644 index 000000000..971dd7a0c --- /dev/null +++ b/debian/patches/0006-Fix-check_symbol_exists-with-pedantic-errors.patch @@ -0,0 +1,64 @@ +From: =?utf-8?q?Timo_R=C3=B6hling?= +Date: Fri, 22 Oct 2021 15:32:20 +0200 +Subject: Fix check_symbol_exists() with -pedantic-errors + +Forwarded: https://gitlab.kitware.com/cmake/cmake/-/merge_requests/6656 +--- + Modules/CheckSymbolExists.cmake | 15 +++++++++++++++ + Tests/CMakeOnly/CheckSymbolExists/CMakeLists.txt | 11 +++++++++++ + 2 files changed, 26 insertions(+) + +diff --git a/Modules/CheckSymbolExists.cmake b/Modules/CheckSymbolExists.cmake +index f8ca584..a87fdbd 100644 +--- a/Modules/CheckSymbolExists.cmake ++++ b/Modules/CheckSymbolExists.cmake +@@ -67,14 +67,29 @@ cmake_policy(SET CMP0054 NEW) # if() quoted variables not dereferenced + + macro(CHECK_SYMBOL_EXISTS SYMBOL FILES VARIABLE) + if(CMAKE_C_COMPILER_LOADED) ++ __CHECK_SYMBOL_EXISTS_FILTER_FLAGS(C) + __CHECK_SYMBOL_EXISTS_IMPL("${CMAKE_BINARY_DIR}${CMAKE_FILES_DIRECTORY}/CMakeTmp/CheckSymbolExists.c" "${SYMBOL}" "${FILES}" "${VARIABLE}" ) ++ __CHECK_SYMBOL_EXISTS_RESTORE_FLAGS(C) + elseif(CMAKE_CXX_COMPILER_LOADED) ++ __CHECK_SYMBOL_EXISTS_FILTER_FLAGS(CXX) + __CHECK_SYMBOL_EXISTS_IMPL("${CMAKE_BINARY_DIR}${CMAKE_FILES_DIRECTORY}/CMakeTmp/CheckSymbolExists.cxx" "${SYMBOL}" "${FILES}" "${VARIABLE}" ) ++ __CHECK_SYMBOL_EXISTS_RESTORE_FLAGS(CXX) + else() + message(FATAL_ERROR "CHECK_SYMBOL_EXISTS needs either C or CXX language enabled") + endif() + endmacro() + ++macro(__CHECK_SYMBOL_EXISTS_FILTER_FLAGS LANG) ++ set(__CMAKE_${LANG}_FLAGS_SAVED "${CMAKE_${LANG}_FLAGS}") ++ string(REGEX REPLACE "(^| )-Werror([= ][^ ]*)?( |$)" " " CMAKE_${LANG}_FLAGS "${CMAKE_${LANG}_FLAGS}") ++ string(REGEX REPLACE "(^| )-pedantic-errors( |$)" " " CMAKE_${LANG}_FLAGS "${CMAKE_${LANG}_FLAGS}") ++endmacro() ++ ++macro(__CHECK_SYMBOL_EXISTS_RESTORE_FLAGS LANG) ++ set(CMAKE_${LANG}_FLAGS "${__CMAKE_${LANG}_FLAGS_SAVED}") ++ unset(__CMAKE_${LANG}_FLAGS_SAVED) ++endmacro() ++ + macro(__CHECK_SYMBOL_EXISTS_IMPL SOURCEFILE SYMBOL FILES VARIABLE) + if(NOT DEFINED "${VARIABLE}" OR "x${${VARIABLE}}" STREQUAL "x${VARIABLE}") + set(CMAKE_CONFIGURABLE_FILE_CONTENT "/* */\n") +diff --git a/Tests/CMakeOnly/CheckSymbolExists/CMakeLists.txt b/Tests/CMakeOnly/CheckSymbolExists/CMakeLists.txt +index 9a9bb2a..0ced696 100644 +--- a/Tests/CMakeOnly/CheckSymbolExists/CMakeLists.txt ++++ b/Tests/CMakeOnly/CheckSymbolExists/CMakeLists.txt +@@ -48,4 +48,15 @@ if (CMAKE_COMPILER_IS_GNUCC) + if (CSE_RESULT_O3) + message(SEND_ERROR "CheckSymbolExists reported a nonexistent symbol as existing with optimization -O3") + endif () ++ ++ string(APPEND CMAKE_C_FLAGS " -pedantic-errors") ++ unset(CS_RESULT_PEDANTIC_ERRORS CACHE) ++ message(STATUS "Testing with -pedantic-errors") ++ ++ check_symbol_exists(fopen "stdio.h" CSE_RESULT_PEDANTIC_ERRORS) ++ ++ if(NOT CSE_RESULT_PEDANTIC_ERRORS) ++ message(SEND_ERROR "ChecKSymbolExists reported an existing symbol as nonexisting with -pedantic-errors") ++ endif() ++ + endif () diff --git a/debian/patches/series b/debian/patches/series index ab032988e..4a96f0bd9 100644 --- a/debian/patches/series +++ b/debian/patches/series @@ -3,3 +3,4 @@ 0003-Fix-RunCMake.CPack_DEB.EXTRA-on-Debian-non-Linux-OSe.patch 0004-Fix-misinterpretation-of-Debian-Policy-on-LIBEXECDIR.patch 0005-Make-FindFLTK-safe-to-include-multiple-times.patch +0006-Fix-check_symbol_exists-with-pedantic-errors.patch