[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.
Showing
- .gitignore 1 addition, 1 deletion.gitignore
- absl/copts/AbseilConfigureCopts.cmake 23 additions, 16 deletionsabsl/copts/AbseilConfigureCopts.cmake
- absl/copts/GENERATED_AbseilCopts.cmake 90 additions, 14 deletionsabsl/copts/GENERATED_AbseilCopts.cmake
- absl/copts/GENERATED_copts.bzl 90 additions, 14 deletionsabsl/copts/GENERATED_copts.bzl
- absl/copts/configure_copts.bzl 18 additions, 18 deletionsabsl/copts/configure_copts.bzl
- absl/copts/copts.py 124 additions, 106 deletionsabsl/copts/copts.py
Please register or sign in to comment