123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245 |
- #***************************************************************************
- # _ _ ____ _
- # Project ___| | | | _ \| |
- # / __| | | | |_) | |
- # | (__| |_| | _ <| |___
- # \___|\___/|_| \_\_____|
- #
- # Copyright (C) Daniel Stenberg, <daniel@haxx.se>, et al.
- #
- # This software is licensed as described in the file COPYING, which
- # you should have received as part of this distribution. The terms
- # are also available at https://curl.se/docs/copyright.html.
- #
- # You may opt to use, copy, modify, merge, publish, distribute and/or sell
- # copies of the Software, and permit persons to whom the Software is
- # furnished to do so, under the terms of the COPYING file.
- #
- # This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
- # KIND, either express or implied.
- #
- # SPDX-License-Identifier: curl
- #
- ###########################################################################
- include(CheckCCompilerFlag)
- unset(WPICKY)
- if(CURL_WERROR AND
- ((CMAKE_COMPILER_IS_GNUCC AND
- NOT CMAKE_C_COMPILER_VERSION VERSION_LESS 5.0 AND
- NOT CMAKE_VERSION VERSION_LESS 3.23.0) OR # to avoid check_symbol_exists() conflicting with GCC -pedantic-errors
- CMAKE_C_COMPILER_ID MATCHES "Clang"))
- set(WPICKY "${WPICKY} -pedantic-errors")
- endif()
- if(APPLE AND
- (CMAKE_C_COMPILER_ID STREQUAL "Clang" AND NOT CMAKE_C_COMPILER_VERSION VERSION_LESS 3.6) OR
- (CMAKE_C_COMPILER_ID STREQUAL "AppleClang" AND NOT CMAKE_C_COMPILER_VERSION VERSION_LESS 6.3))
- set(WPICKY "${WPICKY} -Werror=partial-availability") # clang 3.6 appleclang 6.3
- endif()
- if(CMAKE_COMPILER_IS_GNUCC OR CMAKE_C_COMPILER_ID MATCHES "Clang")
- set(WPICKY "${WPICKY} -Werror-implicit-function-declaration") # clang 1.0 gcc 2.95
- endif()
- if(PICKY_COMPILER)
- if(CMAKE_COMPILER_IS_GNUCC OR CMAKE_C_COMPILER_ID MATCHES "Clang")
- # https://clang.llvm.org/docs/DiagnosticsReference.html
- # https://gcc.gnu.org/onlinedocs/gcc/Warning-Options.html
- # WPICKY_ENABLE = Options we want to enable as-is.
- # WPICKY_DETECT = Options we want to test first and enable if available.
- # Prefer the -Wextra alias with clang.
- if(CMAKE_C_COMPILER_ID MATCHES "Clang")
- set(WPICKY_ENABLE "-Wextra")
- else()
- set(WPICKY_ENABLE "-W")
- endif()
- list(APPEND WPICKY_ENABLE
- -Wall -pedantic
- )
- # ----------------------------------
- # Add new options here, if in doubt:
- # ----------------------------------
- set(WPICKY_DETECT
- )
- # Assume these options always exist with both clang and gcc.
- # Require clang 3.0 / gcc 2.95 or later.
- list(APPEND WPICKY_ENABLE
- -Wbad-function-cast # clang 2.7 gcc 2.95
- -Wconversion # clang 2.7 gcc 2.95
- -Winline # clang 1.0 gcc 1.0
- -Wmissing-declarations # clang 1.0 gcc 2.7
- -Wmissing-prototypes # clang 1.0 gcc 1.0
- -Wnested-externs # clang 1.0 gcc 2.7
- -Wno-long-long # clang 1.0 gcc 2.95
- -Wno-multichar # clang 1.0 gcc 2.95
- -Wpointer-arith # clang 1.0 gcc 1.4
- -Wshadow # clang 1.0 gcc 2.95
- -Wsign-compare # clang 1.0 gcc 2.95
- -Wundef # clang 1.0 gcc 2.95
- -Wunused # clang 1.1 gcc 2.95
- -Wwrite-strings # clang 1.0 gcc 1.4
- )
- # Always enable with clang, version dependent with gcc
- set(WPICKY_COMMON_OLD
- -Waddress # clang 2.7 gcc 4.3
- -Wattributes # clang 2.7 gcc 4.1
- -Wcast-align # clang 1.0 gcc 4.2
- -Wdeclaration-after-statement # clang 1.0 gcc 3.4
- -Wdiv-by-zero # clang 2.7 gcc 4.1
- -Wempty-body # clang 2.7 gcc 4.3
- -Wendif-labels # clang 1.0 gcc 3.3
- -Wfloat-equal # clang 1.0 gcc 2.96 (3.0)
- -Wformat-security # clang 2.7 gcc 4.1
- -Wignored-qualifiers # clang 2.8 gcc 4.3
- -Wmissing-field-initializers # clang 2.7 gcc 4.1
- -Wmissing-noreturn # clang 2.7 gcc 4.1
- -Wno-format-nonliteral # clang 1.0 gcc 2.96 (3.0)
- -Wno-system-headers # clang 1.0 gcc 3.0
- # -Wpadded # clang 2.9 gcc 4.1 # Not used: We cannot change public structs
- -Wold-style-definition # clang 2.7 gcc 3.4
- -Wredundant-decls # clang 2.7 gcc 4.1
- -Wsign-conversion # clang 2.9 gcc 4.3
- -Wno-error=sign-conversion # FIXME
- -Wstrict-prototypes # clang 1.0 gcc 3.3
- # -Wswitch-enum # clang 2.7 gcc 4.1 # Not used: It basically disallows default case
- -Wtype-limits # clang 2.7 gcc 4.3
- -Wunreachable-code # clang 2.7 gcc 4.1
- # -Wunused-macros # clang 2.7 gcc 4.1 # Not practical
- -Wunused-parameter # clang 2.7 gcc 4.1
- -Wvla # clang 2.8 gcc 4.3
- )
- set(WPICKY_COMMON
- -Wdouble-promotion # clang 3.6 gcc 4.6 appleclang 6.3
- -Wenum-conversion # clang 3.2 gcc 10.0 appleclang 4.6 g++ 11.0
- -Wpragmas # clang 3.5 gcc 4.1 appleclang 6.0
- -Wunused-const-variable # clang 3.4 gcc 6.0 appleclang 5.1
- )
- if(CMAKE_C_COMPILER_ID MATCHES "Clang")
- list(APPEND WPICKY_ENABLE
- ${WPICKY_COMMON_OLD}
- -Wshift-sign-overflow # clang 2.9
- -Wshorten-64-to-32 # clang 1.0
- -Wlanguage-extension-token # clang 3.0
- -Wformat=2 # clang 3.0 gcc 4.8
- )
- # Enable based on compiler version
- if((CMAKE_C_COMPILER_ID STREQUAL "Clang" AND NOT CMAKE_C_COMPILER_VERSION VERSION_LESS 3.6) OR
- (CMAKE_C_COMPILER_ID STREQUAL "AppleClang" AND NOT CMAKE_C_COMPILER_VERSION VERSION_LESS 6.3))
- list(APPEND WPICKY_ENABLE
- ${WPICKY_COMMON}
- -Wunreachable-code-break # clang 3.5 appleclang 6.0
- -Wheader-guard # clang 3.4 appleclang 5.1
- -Wsometimes-uninitialized # clang 3.2 appleclang 4.6
- )
- endif()
- if((CMAKE_C_COMPILER_ID STREQUAL "Clang" AND NOT CMAKE_C_COMPILER_VERSION VERSION_LESS 3.9) OR
- (CMAKE_C_COMPILER_ID STREQUAL "AppleClang" AND NOT CMAKE_C_COMPILER_VERSION VERSION_LESS 8.3))
- list(APPEND WPICKY_ENABLE
- -Wcomma # clang 3.9 appleclang 8.3
- -Wmissing-variable-declarations # clang 3.2 appleclang 4.6
- )
- endif()
- if((CMAKE_C_COMPILER_ID STREQUAL "Clang" AND NOT CMAKE_C_COMPILER_VERSION VERSION_LESS 7.0) OR
- (CMAKE_C_COMPILER_ID STREQUAL "AppleClang" AND NOT CMAKE_C_COMPILER_VERSION VERSION_LESS 10.3))
- list(APPEND WPICKY_ENABLE
- -Wassign-enum # clang 7.0 appleclang 10.3
- -Wextra-semi-stmt # clang 7.0 appleclang 10.3
- )
- endif()
- if((CMAKE_C_COMPILER_ID STREQUAL "Clang" AND NOT CMAKE_C_COMPILER_VERSION VERSION_LESS 10.0) OR
- (CMAKE_C_COMPILER_ID STREQUAL "AppleClang" AND NOT CMAKE_C_COMPILER_VERSION VERSION_LESS 12.4))
- list(APPEND WPICKY_ENABLE
- -Wimplicit-fallthrough # clang 4.0 gcc 7.0 appleclang 12.4 # We do silencing for clang 10.0 and above only
- )
- endif()
- else() # gcc
- list(APPEND WPICKY_DETECT
- ${WPICKY_COMMON}
- )
- # Enable based on compiler version
- if(NOT CMAKE_C_COMPILER_VERSION VERSION_LESS 4.3)
- list(APPEND WPICKY_ENABLE
- ${WPICKY_COMMON_OLD}
- -Wclobbered # gcc 4.3
- -Wmissing-parameter-type # gcc 4.3
- -Wold-style-declaration # gcc 4.3
- -Wstrict-aliasing=3 # gcc 4.0
- -Wtrampolines # gcc 4.3
- )
- endif()
- if(NOT CMAKE_C_COMPILER_VERSION VERSION_LESS 4.5 AND MINGW)
- list(APPEND WPICKY_ENABLE
- -Wno-pedantic-ms-format # gcc 4.5 (MinGW-only)
- )
- endif()
- if(NOT CMAKE_C_COMPILER_VERSION VERSION_LESS 4.8)
- list(APPEND WPICKY_ENABLE
- -Wformat=2 # clang 3.0 gcc 4.8
- )
- endif()
- if(NOT CMAKE_C_COMPILER_VERSION VERSION_LESS 5.0)
- list(APPEND WPICKY_ENABLE
- -Warray-bounds=2 -ftree-vrp # clang 3.0 gcc 5.0 (clang default: -Warray-bounds)
- )
- endif()
- if(NOT CMAKE_C_COMPILER_VERSION VERSION_LESS 6.0)
- list(APPEND WPICKY_ENABLE
- -Wduplicated-cond # gcc 6.0
- -Wnull-dereference # clang 3.0 gcc 6.0 (clang default)
- -fdelete-null-pointer-checks
- -Wshift-negative-value # clang 3.7 gcc 6.0 (clang default)
- -Wshift-overflow=2 # clang 3.0 gcc 6.0 (clang default: -Wshift-overflow)
- )
- endif()
- if(NOT CMAKE_C_COMPILER_VERSION VERSION_LESS 7.0)
- list(APPEND WPICKY_ENABLE
- -Walloc-zero # gcc 7.0
- -Wduplicated-branches # gcc 7.0
- -Wformat-truncation=2 # gcc 7.0
- -Wimplicit-fallthrough # clang 4.0 gcc 7.0
- -Wrestrict # gcc 7.0
- )
- endif()
- if(NOT CMAKE_C_COMPILER_VERSION VERSION_LESS 10.0)
- list(APPEND WPICKY_ENABLE
- -Warith-conversion # gcc 10.0
- )
- endif()
- endif()
- #
- foreach(_ccopt IN LISTS WPICKY_ENABLE)
- set(WPICKY "${WPICKY} ${_ccopt}")
- endforeach()
- foreach(_ccopt IN LISTS WPICKY_DETECT)
- # surprisingly, CHECK_C_COMPILER_FLAG needs a new variable to store each new
- # test result in.
- string(MAKE_C_IDENTIFIER "OPT${_ccopt}" _optvarname)
- # GCC only warns about unknown -Wno- options if there are also other diagnostic messages,
- # so test for the positive form instead
- string(REPLACE "-Wno-" "-W" _ccopt_on "${_ccopt}")
- check_c_compiler_flag(${_ccopt_on} ${_optvarname})
- if(${_optvarname})
- set(WPICKY "${WPICKY} ${_ccopt}")
- endif()
- endforeach()
- endif()
- endif()
- if(WPICKY)
- set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} ${WPICKY}")
- message(STATUS "Picky compiler options:${WPICKY}")
- endif()
|