From: Manuel Nickschas Date: Sun, 18 Nov 2018 18:12:10 +0000 (+0100) Subject: cmake: Increase warning level on MSVC X-Git-Tag: test-travis-01~92 X-Git-Url: https://git.quassel-irc.org/?p=quassel.git;a=commitdiff_plain;h=2b20afa535e00faa8d7fc114014463824b8fcca4 cmake: Increase warning level on MSVC By default, CMake sets /W3, which basically outputs nothing. The next level /W4 is more useful, but causes lots of false positives. So let's use /W4 and silence stuff that is annoying and useless. --- diff --git a/cmake/QuasselCompileSettings.cmake b/cmake/QuasselCompileSettings.cmake index 05c5a95d..2914f427 100644 --- a/cmake/QuasselCompileSettings.cmake +++ b/cmake/QuasselCompileSettings.cmake @@ -68,7 +68,22 @@ elseif(MSVC) add_definitions(-DWIN32_LEAN_AND_MEAN -DUNICODE -D_UNICODE -D_USE_MATH_DEFINES -DNOMINMAX) # Compile options - add_compile_options(-EHsc -W3) + add_compile_options(/EHsc) + + # Increase warning level on MSVC + # CMake puts /W3 in CMAKE_CXX_FLAGS which will be appended later, so we need to replace + message(STATUS "CXX ${CMAKE_CXX_FLAGS} REL ${CMAKE_CXX_FLAGS_RELEASE} DEB ${CMAKE_CXX_FLAGS_DEBUG}") + string(REPLACE "/W3" "/W4" CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS}") + + # Silence annoying/useless warnings + # C4127: conditional expression is constant + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} /wd4127") + # C4244: 'identifier': conversion from 't1' to 't2', possible loss of data + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} /wd4244") + # C4456: declaration of 'identifier' hides previous local declaration + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} /wd4456") + # C4458: declaration of 'identifier' hides class member + set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} /wd4458") # Link against the correct version of the C runtime set(CMAKE_EXE_LINKER_FLAGS_RELEASE "/NODEFAULTLIB:libcmt /DEFAULTLIB:msvcrt ${CMAKE_EXE_LINKER_FLAGS_RELEASE}")