shithub: puzzles

Download patch

ref: 3cf0a3b7b0df12a21b705564aecbaa269f856e0e
parent: 7a43cc0ca38de0103f4d1bab7a86387c2c8ed040
author: Simon Tatham <[email protected]>
date: Mon Apr 19 14:12:36 EDT 2021

Suppress too-noisy Visual Studio warnings.

With this and the previous commit's fix for real problems, the Puzzles
build on VS is now warning-free.

--- a/cmake/platforms/windows.cmake
+++ b/cmake/platforms/windows.cmake
@@ -7,6 +7,32 @@
 
 add_compile_definitions(_CRT_SECURE_NO_WARNINGS)
 
+if(CMAKE_C_COMPILER_ID MATCHES "MSVC")
+  # Turn off some warnings that I've just found too noisy.
+  #
+  #  - 4244, 4267: "possible loss of data" when narrowing an integer
+  #    type (separate warning numbers for initialisers and
+  #    assignments). Every time I spot-check instances of this, they
+  #    turn out to be sensible (e.g. something was already checked, or
+  #    was assigned from a previous variable that must have been in
+  #    range). I don't think putting a warning-suppression idiom at
+  #    every one of these sites would improve code legibility.
+  #
+  #  - 4018: "signed/unsigned mismatch" in integer comparison. Again,
+  #    comes up a lot, and generally my spot checks make it look as if
+  #    it's OK.
+  #
+  #  - 4146: applying unary '-' to an unsigned type. This happens once,
+  #    in Untangle, and it's on purpose - but I haven't found any idiom
+  #    at the point of use that reassures the compiler that I meant it.
+  #
+  #  - 4305: truncation from double to float. We use float all the time
+  #    in this code base, and truncations from double are fine.
+
+  set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} \
+/wd4244 /wd4267 /wd4018 /wd4146 /wd4305")
+endif()
+
 function(get_platform_puzzle_extra_source_files OUTVAR NAME)
   set(${OUTVAR} ${CMAKE_SOURCE_DIR}/puzzles.rc PARENT_SCOPE)
 endfunction()