Skip to content

Commit

Permalink
Merge pull request #3722 from timou/cmake-windows-clean
Browse files Browse the repository at this point in the history
Suppress VS2017 compiler/linker warnings
  • Loading branch information
liujisi committed Oct 27, 2017
2 parents 23adfeb + a23669c commit 4526d8b
Showing 1 changed file with 20 additions and 1 deletion.
21 changes: 20 additions & 1 deletion cmake/CMakeLists.txt
Original file line number Original file line Diff line number Diff line change
Expand Up @@ -135,12 +135,31 @@ endif (protobuf_BUILD_SHARED_LIBS)
if (MSVC) if (MSVC)
# Build with multiple processes # Build with multiple processes
add_definitions(/MP) add_definitions(/MP)
add_definitions(/wd4244 /wd4267 /wd4018 /wd4355 /wd4800 /wd4251 /wd4996 /wd4146 /wd4305 /wd4309) # MSVC warning suppressions
add_definitions(
/wd4018 # 'expression' : signed/unsigned mismatch
/wd4065 # switch statement contains 'default' but no 'case' labels
/wd4146 # unary minus operator applied to unsigned type, result still unsigned
/wd4244 # 'conversion' conversion from 'type1' to 'type2', possible loss of data
/wd4251 # 'identifier' : class 'type' needs to have dll-interface to be used by clients of class 'type2'
/wd4267 # 'var' : conversion from 'size_t' to 'type', possible loss of data
/wd4305 # 'identifier' : truncation from 'type1' to 'type2'
/wd4307 # 'operator' : integral constant overflow
/wd4309 # 'conversion' : truncation of constant value
/wd4334 # 'operator' : result of 32-bit shift implicitly converted to 64 bits (was 64-bit shift intended?)
/wd4355 # 'this' : used in base member initializer list
/wd4506 # no definition for inline function 'function'
/wd4800 # 'type' : forcing value to bool 'true' or 'false' (performance warning)
/wd4996 # The compiler encountered a deprecated declaration.
)
# Allow big object # Allow big object
add_definitions(/bigobj) add_definitions(/bigobj)
string(REPLACE "/" "\\" PROTOBUF_SOURCE_WIN32_PATH ${protobuf_SOURCE_DIR}) string(REPLACE "/" "\\" PROTOBUF_SOURCE_WIN32_PATH ${protobuf_SOURCE_DIR})
string(REPLACE "/" "\\" PROTOBUF_BINARY_WIN32_PATH ${protobuf_BINARY_DIR}) string(REPLACE "/" "\\" PROTOBUF_BINARY_WIN32_PATH ${protobuf_BINARY_DIR})
configure_file(extract_includes.bat.in extract_includes.bat) configure_file(extract_includes.bat.in extract_includes.bat)

# Suppress linker warnings about files with no symbols defined.
set(CMAKE_STATIC_LINKER_FLAGS /ignore:4221)
endif (MSVC) endif (MSVC)


get_filename_component(protobuf_source_dir ${protobuf_SOURCE_DIR} PATH) get_filename_component(protobuf_source_dir ${protobuf_SOURCE_DIR} PATH)
Expand Down

0 comments on commit 4526d8b

Please sign in to comment.