[CMake] Set correct flags for clang-cl (#278)

clang-cl produce binaries with MSVC ABI and wants to be as flag-compatible with pure MSVC as possible, so this leads to all sorts of weird cases.

clang-cl alias /Wall as clang's -Weverything which is way too verbose, so it needs /W3 like pure MSVC.
clang-cl only understand GCC style warning flags (-W[no]blah) and just silent drop MSVC style warning flags (/wd[num]).
clang-cl needs MSVC define flags since it is consuming the same header files as pure MSVC.
CMake set CMAKE_CXX_COMPILER_ID as Clang when clang-cl is detected, so need extra if (MSVC) to differentiate it.

We are not doing clang-cl specialization in Bazel as currently there is no reliable way to detect clang-cl in Bazel..

This PR should be NFC for LLVM/GCC users on Unix platforms.

Other changes:

Add ABSL_ prefix to variable names to avoid name collision in CMake.
This commit is contained in:
Loo Rong Jie 2019-03-23 03:23:01 +08:00 committed by Derek Mauro
parent e75672f6af
commit 253eb74164
6 changed files with 346 additions and 169 deletions

2
.gitignore vendored
View file

@ -11,5 +11,5 @@ CMakeLists.txt.user
# Ignore VS Code files # Ignore VS Code files
.vscode/* .vscode/*
# Ignore generated python artifacts # Ignore generated python artifacts
copts/copts.pyc *.pyc
copts/__pycache__/ copts/__pycache__/

View file

@ -5,14 +5,20 @@ set(ABSL_LSAN_LINKOPTS "")
set(ABSL_HAVE_LSAN OFF) set(ABSL_HAVE_LSAN OFF)
if ("${CMAKE_CXX_COMPILER_ID}" STREQUAL "GNU") if ("${CMAKE_CXX_COMPILER_ID}" STREQUAL "GNU")
set(ABSL_DEFAULT_COPTS "${GCC_FLAGS}") set(ABSL_DEFAULT_COPTS "${ABSL_GCC_FLAGS}")
set(ABSL_TEST_COPTS "${GCC_FLAGS};${GCC_TEST_FLAGS}") set(ABSL_TEST_COPTS "${ABSL_GCC_FLAGS};${ABSL_GCC_TEST_FLAGS}")
set(ABSL_EXCEPTIONS_FLAG "${GCC_EXCEPTIONS_FLAGS}") set(ABSL_EXCEPTIONS_FLAG "${ABSL_GCC_EXCEPTIONS_FLAGS}")
elseif("${CMAKE_CXX_COMPILER_ID}" MATCHES "Clang") elseif("${CMAKE_CXX_COMPILER_ID}" MATCHES "Clang")
# MATCHES so we get both Clang and AppleClang # MATCHES so we get both Clang and AppleClang
set(ABSL_DEFAULT_COPTS "${LLVM_FLAGS}") if (MSVC)
set(ABSL_TEST_COPTS "${LLVM_FLAGS};${LLVM_TEST_FLAGS}") # clang-cl is half MSVC, half LLVM
set(ABSL_EXCEPTIONS_FLAG "${LLVM_EXCEPTIONS_FLAGS}") set(ABSL_DEFAULT_COPTS "${ABSL_CLANG_CL_FLAGS}")
set(ABSL_TEST_COPTS "${ABSL_CLANG_CL_FLAGS};${ABSL_CLANG_CL_TEST_FLAGS}")
set(ABSL_EXCEPTIONS_FLAG "${ABSL_CLANG_CL_EXCEPTIONS_FLAGS}")
else()
set(ABSL_DEFAULT_COPTS "${ABSL_LLVM_FLAGS}")
set(ABSL_TEST_COPTS "${ABSL_LLVM_FLAGS};${ABSL_LLVM_TEST_FLAGS}")
set(ABSL_EXCEPTIONS_FLAG "${ABSL_LLVM_EXCEPTIONS_FLAGS}")
if ("${CMAKE_CXX_COMPILER_ID}" STREQUAL "Clang") if ("${CMAKE_CXX_COMPILER_ID}" STREQUAL "Clang")
# AppleClang doesn't have lsan # AppleClang doesn't have lsan
# https://developer.apple.com/documentation/code_diagnostics # https://developer.apple.com/documentation/code_diagnostics
@ -21,10 +27,11 @@ elseif("${CMAKE_CXX_COMPILER_ID}" MATCHES "Clang")
set(ABSL_HAVE_LSAN ON) set(ABSL_HAVE_LSAN ON)
endif() endif()
endif() endif()
endif()
elseif("${CMAKE_CXX_COMPILER_ID}" STREQUAL "MSVC") elseif("${CMAKE_CXX_COMPILER_ID}" STREQUAL "MSVC")
set(ABSL_DEFAULT_COPTS "${MSVC_FLAGS}") set(ABSL_DEFAULT_COPTS "${ABSL_MSVC_FLAGS}")
set(ABSL_TEST_COPTS "${MSVC_FLAGS};${MSVC_TEST_FLAGS}") set(ABSL_TEST_COPTS "${ABSL_MSVC_FLAGS};${ABSL_MSVC_TEST_FLAGS}")
set(ABSL_EXCEPTIONS_FLAG "${MSVC_EXCEPTIONS_FLAGS}") set(ABSL_EXCEPTIONS_FLAG "${ABSL_MSVC_EXCEPTIONS_FLAGS}")
else() else()
message(WARNING "Unknown compiler: ${CMAKE_CXX_COMPILER}. Building with no default flags") message(WARNING "Unknown compiler: ${CMAKE_CXX_COMPILER}. Building with no default flags")
set(ABSL_DEFAULT_COPTS "") set(ABSL_DEFAULT_COPTS "")

View file

@ -3,11 +3,87 @@
# (1) Edit absl/copts/copts.py. # (1) Edit absl/copts/copts.py.
# (2) Run `python <path_to_absl>/copts/generate_copts.py`. # (2) Run `python <path_to_absl>/copts/generate_copts.py`.
list(APPEND GCC_EXCEPTIONS_FLAGS list(APPEND ABSL_CLANG_CL_EXCEPTIONS_FLAGS
"/U_HAS_EXCEPTIONS"
"/D_HAS_EXCEPTIONS=1"
"/EHsc"
)
list(APPEND ABSL_CLANG_CL_FLAGS
"/W3"
"-Wno-c++98-compat-pedantic"
"-Wno-conversion"
"-Wno-covered-switch-default"
"-Wno-deprecated"
"-Wno-disabled-macro-expansion"
"-Wno-double-promotion"
"-Wno-comma"
"-Wno-extra-semi"
"-Wno-extra-semi-stmt"
"-Wno-packed"
"-Wno-padded"
"-Wno-sign-compare"
"-Wno-float-conversion"
"-Wno-float-equal"
"-Wno-format-nonliteral"
"-Wno-gcc-compat"
"-Wno-global-constructors"
"-Wno-exit-time-destructors"
"-Wno-nested-anon-types"
"-Wno-non-modular-include-in-module"
"-Wno-old-style-cast"
"-Wno-range-loop-analysis"
"-Wno-reserved-id-macro"
"-Wno-shorten-64-to-32"
"-Wno-switch-enum"
"-Wno-thread-safety-negative"
"-Wno-undef"
"-Wno-unknown-warning-option"
"-Wno-unreachable-code"
"-Wno-unused-macros"
"-Wno-weak-vtables"
"-Wbitfield-enum-conversion"
"-Wbool-conversion"
"-Wconstant-conversion"
"-Wenum-conversion"
"-Wint-conversion"
"-Wliteral-conversion"
"-Wnon-literal-null-conversion"
"-Wnull-conversion"
"-Wobjc-literal-conversion"
"-Wno-sign-conversion"
"-Wstring-conversion"
"/DNOMINMAX"
"/DWIN32_LEAN_AND_MEAN"
"/D_CRT_SECURE_NO_WARNINGS"
"/D_SCL_SECURE_NO_WARNINGS"
"/D_ENABLE_EXTENDED_ALIGNED_STORAGE"
)
list(APPEND ABSL_CLANG_CL_TEST_FLAGS
"-Wno-c99-extensions"
"-Wno-missing-noreturn"
"-Wno-missing-prototypes"
"-Wno-missing-variable-declarations"
"-Wno-null-conversion"
"-Wno-shadow"
"-Wno-shift-sign-overflow"
"-Wno-sign-compare"
"-Wno-unused-function"
"-Wno-unused-member-function"
"-Wno-unused-parameter"
"-Wno-unused-private-field"
"-Wno-unused-template"
"-Wno-used-but-marked-unused"
"-Wno-zero-as-null-pointer-constant"
"-Wno-gnu-zero-variadic-macro-arguments"
)
list(APPEND ABSL_GCC_EXCEPTIONS_FLAGS
"-fexceptions" "-fexceptions"
) )
list(APPEND GCC_FLAGS list(APPEND ABSL_GCC_FLAGS
"-Wall" "-Wall"
"-Wextra" "-Wextra"
"-Wcast-qual" "-Wcast-qual"
@ -24,7 +100,7 @@ list(APPEND GCC_FLAGS
"-Wno-sign-compare" "-Wno-sign-compare"
) )
list(APPEND GCC_TEST_FLAGS list(APPEND ABSL_GCC_TEST_FLAGS
"-Wno-conversion-null" "-Wno-conversion-null"
"-Wno-missing-declarations" "-Wno-missing-declarations"
"-Wno-sign-compare" "-Wno-sign-compare"
@ -33,11 +109,11 @@ list(APPEND GCC_TEST_FLAGS
"-Wno-unused-private-field" "-Wno-unused-private-field"
) )
list(APPEND LLVM_EXCEPTIONS_FLAGS list(APPEND ABSL_LLVM_EXCEPTIONS_FLAGS
"-fexceptions" "-fexceptions"
) )
list(APPEND LLVM_FLAGS list(APPEND ABSL_LLVM_FLAGS
"-Wall" "-Wall"
"-Wextra" "-Wextra"
"-Weverything" "-Weverything"
@ -85,7 +161,7 @@ list(APPEND LLVM_FLAGS
"-Wstring-conversion" "-Wstring-conversion"
) )
list(APPEND LLVM_TEST_FLAGS list(APPEND ABSL_LLVM_TEST_FLAGS
"-Wno-c99-extensions" "-Wno-c99-extensions"
"-Wno-missing-noreturn" "-Wno-missing-noreturn"
"-Wno-missing-prototypes" "-Wno-missing-prototypes"
@ -104,28 +180,28 @@ list(APPEND LLVM_TEST_FLAGS
"-Wno-gnu-zero-variadic-macro-arguments" "-Wno-gnu-zero-variadic-macro-arguments"
) )
list(APPEND MSVC_EXCEPTIONS_FLAGS list(APPEND ABSL_MSVC_EXCEPTIONS_FLAGS
"/U_HAS_EXCEPTIONS" "/U_HAS_EXCEPTIONS"
"/D_HAS_EXCEPTIONS=1" "/D_HAS_EXCEPTIONS=1"
"/EHsc" "/EHsc"
) )
list(APPEND MSVC_FLAGS list(APPEND ABSL_MSVC_FLAGS
"/W3" "/W3"
"/DNOMINMAX"
"/DWIN32_LEAN_AND_MEAN"
"/D_CRT_SECURE_NO_WARNINGS"
"/D_SCL_SECURE_NO_WARNINGS"
"/D_ENABLE_EXTENDED_ALIGNED_STORAGE"
"/wd4005" "/wd4005"
"/wd4068" "/wd4068"
"/wd4180" "/wd4180"
"/wd4244" "/wd4244"
"/wd4267" "/wd4267"
"/wd4800" "/wd4800"
"/DNOMINMAX"
"/DWIN32_LEAN_AND_MEAN"
"/D_CRT_SECURE_NO_WARNINGS"
"/D_SCL_SECURE_NO_WARNINGS"
"/D_ENABLE_EXTENDED_ALIGNED_STORAGE"
) )
list(APPEND MSVC_TEST_FLAGS list(APPEND ABSL_MSVC_TEST_FLAGS
"/wd4018" "/wd4018"
"/wd4101" "/wd4101"
"/wd4503" "/wd4503"

View file

@ -4,11 +4,87 @@
(2) Run `python <path_to_absl>/copts/generate_copts.py`. (2) Run `python <path_to_absl>/copts/generate_copts.py`.
""" """
GCC_EXCEPTIONS_FLAGS = [ ABSL_CLANG_CL_EXCEPTIONS_FLAGS = [
"/U_HAS_EXCEPTIONS",
"/D_HAS_EXCEPTIONS=1",
"/EHsc",
]
ABSL_CLANG_CL_FLAGS = [
"/W3",
"-Wno-c++98-compat-pedantic",
"-Wno-conversion",
"-Wno-covered-switch-default",
"-Wno-deprecated",
"-Wno-disabled-macro-expansion",
"-Wno-double-promotion",
"-Wno-comma",
"-Wno-extra-semi",
"-Wno-extra-semi-stmt",
"-Wno-packed",
"-Wno-padded",
"-Wno-sign-compare",
"-Wno-float-conversion",
"-Wno-float-equal",
"-Wno-format-nonliteral",
"-Wno-gcc-compat",
"-Wno-global-constructors",
"-Wno-exit-time-destructors",
"-Wno-nested-anon-types",
"-Wno-non-modular-include-in-module",
"-Wno-old-style-cast",
"-Wno-range-loop-analysis",
"-Wno-reserved-id-macro",
"-Wno-shorten-64-to-32",
"-Wno-switch-enum",
"-Wno-thread-safety-negative",
"-Wno-undef",
"-Wno-unknown-warning-option",
"-Wno-unreachable-code",
"-Wno-unused-macros",
"-Wno-weak-vtables",
"-Wbitfield-enum-conversion",
"-Wbool-conversion",
"-Wconstant-conversion",
"-Wenum-conversion",
"-Wint-conversion",
"-Wliteral-conversion",
"-Wnon-literal-null-conversion",
"-Wnull-conversion",
"-Wobjc-literal-conversion",
"-Wno-sign-conversion",
"-Wstring-conversion",
"/DNOMINMAX",
"/DWIN32_LEAN_AND_MEAN",
"/D_CRT_SECURE_NO_WARNINGS",
"/D_SCL_SECURE_NO_WARNINGS",
"/D_ENABLE_EXTENDED_ALIGNED_STORAGE",
]
ABSL_CLANG_CL_TEST_FLAGS = [
"-Wno-c99-extensions",
"-Wno-missing-noreturn",
"-Wno-missing-prototypes",
"-Wno-missing-variable-declarations",
"-Wno-null-conversion",
"-Wno-shadow",
"-Wno-shift-sign-overflow",
"-Wno-sign-compare",
"-Wno-unused-function",
"-Wno-unused-member-function",
"-Wno-unused-parameter",
"-Wno-unused-private-field",
"-Wno-unused-template",
"-Wno-used-but-marked-unused",
"-Wno-zero-as-null-pointer-constant",
"-Wno-gnu-zero-variadic-macro-arguments",
]
ABSL_GCC_EXCEPTIONS_FLAGS = [
"-fexceptions", "-fexceptions",
] ]
GCC_FLAGS = [ ABSL_GCC_FLAGS = [
"-Wall", "-Wall",
"-Wextra", "-Wextra",
"-Wcast-qual", "-Wcast-qual",
@ -25,7 +101,7 @@ GCC_FLAGS = [
"-Wno-sign-compare", "-Wno-sign-compare",
] ]
GCC_TEST_FLAGS = [ ABSL_GCC_TEST_FLAGS = [
"-Wno-conversion-null", "-Wno-conversion-null",
"-Wno-missing-declarations", "-Wno-missing-declarations",
"-Wno-sign-compare", "-Wno-sign-compare",
@ -34,11 +110,11 @@ GCC_TEST_FLAGS = [
"-Wno-unused-private-field", "-Wno-unused-private-field",
] ]
LLVM_EXCEPTIONS_FLAGS = [ ABSL_LLVM_EXCEPTIONS_FLAGS = [
"-fexceptions", "-fexceptions",
] ]
LLVM_FLAGS = [ ABSL_LLVM_FLAGS = [
"-Wall", "-Wall",
"-Wextra", "-Wextra",
"-Weverything", "-Weverything",
@ -86,7 +162,7 @@ LLVM_FLAGS = [
"-Wstring-conversion", "-Wstring-conversion",
] ]
LLVM_TEST_FLAGS = [ ABSL_LLVM_TEST_FLAGS = [
"-Wno-c99-extensions", "-Wno-c99-extensions",
"-Wno-missing-noreturn", "-Wno-missing-noreturn",
"-Wno-missing-prototypes", "-Wno-missing-prototypes",
@ -105,28 +181,28 @@ LLVM_TEST_FLAGS = [
"-Wno-gnu-zero-variadic-macro-arguments", "-Wno-gnu-zero-variadic-macro-arguments",
] ]
MSVC_EXCEPTIONS_FLAGS = [ ABSL_MSVC_EXCEPTIONS_FLAGS = [
"/U_HAS_EXCEPTIONS", "/U_HAS_EXCEPTIONS",
"/D_HAS_EXCEPTIONS=1", "/D_HAS_EXCEPTIONS=1",
"/EHsc", "/EHsc",
] ]
MSVC_FLAGS = [ ABSL_MSVC_FLAGS = [
"/W3", "/W3",
"/DNOMINMAX",
"/DWIN32_LEAN_AND_MEAN",
"/D_CRT_SECURE_NO_WARNINGS",
"/D_SCL_SECURE_NO_WARNINGS",
"/D_ENABLE_EXTENDED_ALIGNED_STORAGE",
"/wd4005", "/wd4005",
"/wd4068", "/wd4068",
"/wd4180", "/wd4180",
"/wd4244", "/wd4244",
"/wd4267", "/wd4267",
"/wd4800", "/wd4800",
"/DNOMINMAX",
"/DWIN32_LEAN_AND_MEAN",
"/D_CRT_SECURE_NO_WARNINGS",
"/D_SCL_SECURE_NO_WARNINGS",
"/D_ENABLE_EXTENDED_ALIGNED_STORAGE",
] ]
MSVC_TEST_FLAGS = [ ABSL_MSVC_TEST_FLAGS = [
"/wd4018", "/wd4018",
"/wd4101", "/wd4101",
"/wd4503", "/wd4503",

View file

@ -6,35 +6,35 @@ change Abseil copts, edit absl/copts/copts.py
load( load(
"//absl:copts/GENERATED_copts.bzl", "//absl:copts/GENERATED_copts.bzl",
"GCC_EXCEPTIONS_FLAGS", "ABSL_GCC_EXCEPTIONS_FLAGS",
"GCC_FLAGS", "ABSL_GCC_FLAGS",
"GCC_TEST_FLAGS", "ABSL_GCC_TEST_FLAGS",
"LLVM_EXCEPTIONS_FLAGS", "ABSL_LLVM_EXCEPTIONS_FLAGS",
"LLVM_FLAGS", "ABSL_LLVM_FLAGS",
"LLVM_TEST_FLAGS", "ABSL_LLVM_TEST_FLAGS",
"MSVC_EXCEPTIONS_FLAGS", "ABSL_MSVC_EXCEPTIONS_FLAGS",
"MSVC_FLAGS", "ABSL_MSVC_FLAGS",
"MSVC_TEST_FLAGS", "ABSL_MSVC_TEST_FLAGS",
) )
ABSL_DEFAULT_COPTS = select({ ABSL_DEFAULT_COPTS = select({
"//absl:windows": MSVC_FLAGS, "//absl:windows": ABSL_MSVC_FLAGS,
"//absl:llvm_compiler": LLVM_FLAGS, "//absl:llvm_compiler": ABSL_LLVM_FLAGS,
"//conditions:default": GCC_FLAGS, "//conditions:default": ABSL_GCC_FLAGS,
}) })
# in absence of modules (--compiler=gcc or -c opt), cc_tests leak their copts # in absence of modules (--compiler=gcc or -c opt), cc_tests leak their copts
# to their (included header) dependencies and fail to build outside absl # to their (included header) dependencies and fail to build outside absl
ABSL_TEST_COPTS = ABSL_DEFAULT_COPTS + select({ ABSL_TEST_COPTS = ABSL_DEFAULT_COPTS + select({
"//absl:windows": MSVC_TEST_FLAGS, "//absl:windows": ABSL_MSVC_TEST_FLAGS,
"//absl:llvm_compiler": LLVM_TEST_FLAGS, "//absl:llvm_compiler": ABSL_LLVM_TEST_FLAGS,
"//conditions:default": GCC_TEST_FLAGS, "//conditions:default": ABSL_GCC_TEST_FLAGS,
}) })
ABSL_EXCEPTIONS_FLAG = select({ ABSL_EXCEPTIONS_FLAG = select({
"//absl:windows": MSVC_EXCEPTIONS_FLAGS, "//absl:windows": ABSL_MSVC_EXCEPTIONS_FLAGS,
"//absl:llvm_compiler": LLVM_EXCEPTIONS_FLAGS, "//absl:llvm_compiler": ABSL_LLVM_EXCEPTIONS_FLAGS,
"//conditions:default": GCC_EXCEPTIONS_FLAGS, "//conditions:default": ABSL_GCC_EXCEPTIONS_FLAGS,
}) })
ABSL_EXCEPTIONS_FLAG_LINKOPTS = select({ ABSL_EXCEPTIONS_FLAG_LINKOPTS = select({

View file

@ -11,44 +11,20 @@ The generated copts are consumed by configure_copts.bzl and
AbseilConfigureCopts.cmake. AbseilConfigureCopts.cmake.
""" """
COPT_VARS = { # /Wall with msvc includes unhelpful warnings such as C4711, C4710, ...
"GCC_FLAGS": [ MSVC_BIG_WARNING_FLAGS = [
"-Wall", "/W3",
"-Wextra", ]
"-Wcast-qual",
"-Wconversion-null",
"-Wmissing-declarations",
"-Woverlength-strings",
"-Wpointer-arith",
"-Wunused-local-typedefs",
"-Wunused-result",
"-Wvarargs",
"-Wvla", # variable-length array
"-Wwrite-strings",
# gcc-4.x has spurious missing field initializer warnings.
# https://gcc.gnu.org/bugzilla/show_bug.cgi?id=36750
# Remove when gcc-4.x is no longer supported.
"-Wno-missing-field-initializers",
# Google style does not use unsigned integers, though STL containers
# have unsigned types.
"-Wno-sign-compare",
],
"GCC_TEST_FLAGS": [
"-Wno-conversion-null",
"-Wno-missing-declarations",
"-Wno-sign-compare",
"-Wno-unused-function",
"-Wno-unused-parameter",
"-Wno-unused-private-field",
],
"GCC_EXCEPTIONS_FLAGS": ["-fexceptions"],
# Docs on single flags is preceded by a comment. LLVM_BIG_WARNING_FLAGS = [
# Docs on groups of flags is preceded by ###.
"LLVM_FLAGS": [
"-Wall", "-Wall",
"-Wextra", "-Wextra",
"-Weverything", "-Weverything",
]
# Docs on single flags is preceded by a comment.
# Docs on groups of flags is preceded by ###.
LLVM_DISABLE_WARNINGS_FLAGS = [
# Abseil does not support C++98 # Abseil does not support C++98
"-Wno-c++98-compat-pedantic", "-Wno-c++98-compat-pedantic",
# Turns off all implicit conversion warnings. Most are re-enabled below. # Turns off all implicit conversion warnings. Most are re-enabled below.
@ -109,8 +85,9 @@ COPT_VARS = {
"-Wobjc-literal-conversion", "-Wobjc-literal-conversion",
"-Wno-sign-conversion", "-Wno-sign-conversion",
"-Wstring-conversion", "-Wstring-conversion",
], ]
"LLVM_TEST_FLAGS": [
LLVM_TEST_DISABLE_WARNINGS_FLAGS = [
"-Wno-c99-extensions", "-Wno-c99-extensions",
"-Wno-missing-noreturn", "-Wno-missing-noreturn",
"-Wno-missing-prototypes", "-Wno-missing-prototypes",
@ -128,18 +105,13 @@ COPT_VARS = {
"-Wno-zero-as-null-pointer-constant", "-Wno-zero-as-null-pointer-constant",
# gtest depends on this GNU extension being offered. # gtest depends on this GNU extension being offered.
"-Wno-gnu-zero-variadic-macro-arguments", "-Wno-gnu-zero-variadic-macro-arguments",
], ]
"LLVM_EXCEPTIONS_FLAGS": ["-fexceptions"],
# /Wall with msvc includes unhelpful warnings such as C4711, C4710, ... MSVC_STYLE_EXCEPTIONS_FLAGS = [
"MSVC_FLAGS": [ "/U_HAS_EXCEPTIONS", "/D_HAS_EXCEPTIONS=1", "/EHsc"
"/W3", ]
"/wd4005", # macro-redefinition
"/wd4068", # unknown pragma MSVC_DEFINES = [
"/wd4180", # qualifier applied to function type has no meaning; ignored
"/wd4244", # conversion from 'type1' to 'type2', possible loss of data
"/wd4267", # conversion from 'size_t' to 'type', possible loss of data
# forcing value to bool 'true' or 'false' (performance warning)
"/wd4800",
"/DNOMINMAX", # Don't define min and max macros (windows.h) "/DNOMINMAX", # Don't define min and max macros (windows.h)
# Don't bloat namespace with incompatible winsock versions. # Don't bloat namespace with incompatible winsock versions.
"/DWIN32_LEAN_AND_MEAN", "/DWIN32_LEAN_AND_MEAN",
@ -148,13 +120,59 @@ COPT_VARS = {
"/D_SCL_SECURE_NO_WARNINGS", "/D_SCL_SECURE_NO_WARNINGS",
# Introduced in VS 2017 15.8, allow overaligned types in aligned_storage # Introduced in VS 2017 15.8, allow overaligned types in aligned_storage
"/D_ENABLE_EXTENDED_ALIGNED_STORAGE", "/D_ENABLE_EXTENDED_ALIGNED_STORAGE",
]
COPT_VARS = {
"ABSL_GCC_FLAGS": [
"-Wall",
"-Wextra",
"-Wcast-qual",
"-Wconversion-null",
"-Wmissing-declarations",
"-Woverlength-strings",
"-Wpointer-arith",
"-Wunused-local-typedefs",
"-Wunused-result",
"-Wvarargs",
"-Wvla", # variable-length array
"-Wwrite-strings",
# gcc-4.x has spurious missing field initializer warnings.
# https://gcc.gnu.org/bugzilla/show_bug.cgi?id=36750
# Remove when gcc-4.x is no longer supported.
"-Wno-missing-field-initializers",
# Google style does not use unsigned integers, though STL containers
# have unsigned types.
"-Wno-sign-compare",
], ],
"MSVC_TEST_FLAGS": [ "ABSL_GCC_TEST_FLAGS": [
"-Wno-conversion-null",
"-Wno-missing-declarations",
"-Wno-sign-compare",
"-Wno-unused-function",
"-Wno-unused-parameter",
"-Wno-unused-private-field",
],
"ABSL_GCC_EXCEPTIONS_FLAGS": ["-fexceptions"],
"ABSL_LLVM_FLAGS": LLVM_BIG_WARNING_FLAGS + LLVM_DISABLE_WARNINGS_FLAGS,
"ABSL_LLVM_TEST_FLAGS": LLVM_TEST_DISABLE_WARNINGS_FLAGS,
"ABSL_LLVM_EXCEPTIONS_FLAGS": ["-fexceptions"],
"ABSL_CLANG_CL_FLAGS": (MSVC_BIG_WARNING_FLAGS +
LLVM_DISABLE_WARNINGS_FLAGS + MSVC_DEFINES),
"ABSL_CLANG_CL_TEST_FLAGS": LLVM_TEST_DISABLE_WARNINGS_FLAGS,
"ABSL_CLANG_CL_EXCEPTIONS_FLAGS": MSVC_STYLE_EXCEPTIONS_FLAGS,
"ABSL_MSVC_FLAGS": MSVC_BIG_WARNING_FLAGS + MSVC_DEFINES + [
"/wd4005", # macro-redefinition
"/wd4068", # unknown pragma
"/wd4180", # qualifier applied to function type has no meaning; ignored
"/wd4244", # conversion from 'type1' to 'type2', possible loss of data
"/wd4267", # conversion from 'size_t' to 'type', possible loss of data
# forcing value to bool 'true' or 'false' (performance warning)
"/wd4800",
],
"ABSL_MSVC_TEST_FLAGS": [
"/wd4018", # signed/unsigned mismatch "/wd4018", # signed/unsigned mismatch
"/wd4101", # unreferenced local variable "/wd4101", # unreferenced local variable
"/wd4503", # decorated name length exceeded, name was truncated "/wd4503", # decorated name length exceeded, name was truncated
], ],
"MSVC_EXCEPTIONS_FLAGS": [ "ABSL_MSVC_EXCEPTIONS_FLAGS": MSVC_STYLE_EXCEPTIONS_FLAGS,
"/U_HAS_EXCEPTIONS", "/D_HAS_EXCEPTIONS=1", "/EHsc"
]
} }