aaron.ballman added inline comments.

================
Comment at: clang/lib/Parse/ParseDeclCXX.cpp:874-876
+    if (!getLangOpts().CPlusPlus)
+      Diag(Tok, diag::warn_cxx_static_assert_in_c)
+          << FixItHint::CreateReplacement(Tok.getLocation(), "_Static_assert");
----------------
rsmith wrote:
> I don't think this diagnostic is useful as-is: on Windows, including 
> `<assert.h>` doesn't help because it doesn't `#define static_assert`. And 
> people hitting this also can't switch to using `_Static_assert`, because MSVC 
> doesn't provide it, only `static_assert`.
> 
> If we want to warn here, we could perhaps check whether `<assert.h>` has been 
> included, but getting that check correct across PCH / modules is not 
> straightforward. (If we knew what include guard the CRT's `assert.h` used (if 
> any), I guess we could check whether that's defined, but that'd be a bit of a 
> hack.) But I'm somewhat inclined to think we don't have a good way to 
> distinguish between the good cases and the bad ones, so we shouldn't warn. 
> Hopefully MS will fix their CRT at some point and we can stop providing this 
> compatibility hack entirely (or start warning on it by default).
Are you sure they don't support `_Static_assert` yet? I seem to be able to use 
it fine: https://godbolt.org/z/vG47he

That said, this does appear to be only available in newer versions of MSVC, so 
perhaps you're correct about the diagnostic being a bit unhelpful. My primary 
concern is that use of `static_assert` in C is a nonconforming extension and we 
default to `-fms-compatibility` on Windows when Clang is built by MSVC. So it's 
not difficult to accidentally run into this, but the only warning we give on it 
with `-Weverything -pedantic` is how it's not compatible with C++98.

WDYT?


CHANGES SINCE LAST ACTION
  https://reviews.llvm.org/D95396/new/

https://reviews.llvm.org/D95396

_______________________________________________
cfe-commits mailing list
cfe-commits@lists.llvm.org
https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits

Reply via email to