Commit 4a46a8c1 by Patrick Steinhardt

cmake: encapsulate enabling/disabling compiler warnings

There are multiple sites where we enable or disable compiler warning via
"-W<warning>" or "-Wno-<warning>". As we want to extend this mechanism
later on to conditionally switch these over to "-Werror=<warning>", we
encapsulate the logic into its their own macros `ENABLE_WARNINGS` and
`DISABLE_WARNINGS`.

Note that we in fact have to use a macro here. Using a function would
not modify the CFLAGS inside of the callers scope, but in the function's
scope only.
parent 0a93ded1
...@@ -223,8 +223,16 @@ IF (MSVC) ...@@ -223,8 +223,16 @@ IF (MSVC)
ELSE () ELSE ()
SET(CMAKE_C_FLAGS "-D_GNU_SOURCE ${CMAKE_C_FLAGS}") SET(CMAKE_C_FLAGS "-D_GNU_SOURCE ${CMAKE_C_FLAGS}")
ADD_C_FLAG_IF_SUPPORTED(-Wall) MACRO(ENABLE_WARNINGS flag)
ADD_C_FLAG_IF_SUPPORTED(-Wextra) ADD_C_FLAG_IF_SUPPORTED(-W${flag})
ENDMACRO()
MACRO(DISABLE_WARNINGS flag)
ADD_C_FLAG_IF_SUPPORTED(-Wno-${flag})
ENDMACRO()
ENABLE_WARNINGS(all)
ENABLE_WARNINGS(extra)
IF (CMAKE_SYSTEM_NAME MATCHES "(Solaris|SunOS)") IF (CMAKE_SYSTEM_NAME MATCHES "(Solaris|SunOS)")
SET(CMAKE_C_FLAGS "-std=c99 -D_POSIX_C_SOURCE=200112L -D__EXTENSIONS__ -D_POSIX_PTHREAD_SEMANTICS ${CMAKE_C_FLAGS}") SET(CMAKE_C_FLAGS "-std=c99 -D_POSIX_C_SOURCE=200112L -D__EXTENSIONS__ -D_POSIX_PTHREAD_SEMANTICS ${CMAKE_C_FLAGS}")
...@@ -247,16 +255,16 @@ ELSE () ...@@ -247,16 +255,16 @@ ELSE ()
ADD_DEFINITIONS(-D__USE_MINGW_ANSI_STDIO=1) ADD_DEFINITIONS(-D__USE_MINGW_ANSI_STDIO=1)
ENDIF () ENDIF ()
ADD_C_FLAG_IF_SUPPORTED(-Wdocumentation) ENABLE_WARNINGS(documentation)
ADD_C_FLAG_IF_SUPPORTED(-Wno-missing-field-initializers) DISABLE_WARNINGS(missing-field-initializers)
ADD_C_FLAG_IF_SUPPORTED(-Wstrict-aliasing=2) ENABLE_WARNINGS(strict-aliasing=2)
ADD_C_FLAG_IF_SUPPORTED(-Wstrict-prototypes) ENABLE_WARNINGS(strict-prototypes)
ADD_C_FLAG_IF_SUPPORTED(-Wdeclaration-after-statement) ENABLE_WARNINGS(declaration-after-statement)
ADD_C_FLAG_IF_SUPPORTED(-Wno-unused-const-variable) DISABLE_WARNINGS(unused-const-variable)
ADD_C_FLAG_IF_SUPPORTED(-Wno-unused-function) DISABLE_WARNINGS(unused-function)
IF (APPLE) # Apple deprecated OpenSSL IF (APPLE) # Apple deprecated OpenSSL
ADD_C_FLAG_IF_SUPPORTED(-Wno-deprecated-declarations) DISABLE_WARNINGS(deprecated-declarations)
ENDIF() ENDIF()
IF (PROFILE) IF (PROFILE)
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment