rsmith added a comment.

@rnk / @thakis Can you take a look at this and see if you're happy with this 
"defining `assert` implicitly defines `static_assert`" approach?



================
Comment at: clang/include/clang/Basic/DiagnosticParseKinds.td:427-429
+def warn_cxx_static_assert_in_c : Warning<
+  "'static_assert' is spelled '_Static_assert' in C; consider including "
+  "<assert.h>">, InGroup<DiagGroup<"static-assert-extension">>;
----------------
Perhaps:

```
def ext_ms_static_assert : ExtWarn<
  "use of 'static_assert' without inclusion of <assert.h> is a Microsoft 
extension">,
  "<assert.h>">, InGroup<MicrosoftStaticAssert>;
```

I think `MicrosoftStaticAssert` should also be a subgroup of the `Microsoft` 
(`-Wmicrosoft`) warning group.


================
Comment at: clang/lib/Lex/PPDirectives.cpp:2884
+    Tok.setKind(tok::kw__Static_assert);
+    Tok.setIdentifierInfo(getIdentifierInfo("_Static_assert"));
+    MI->AddTokenToBody(Tok);
----------------
Do we need to give the expansion token a source location? What do diagnostics 
pointing at this token look like?


================
Comment at: clang/lib/Parse/ParseDeclCXX.cpp:881
+    // MSVC's assert.h does not provide such a macro definition.
+    if (!getLangOpts().CPlusPlus && !PP.isMacroDefined("assert"))
+      Diag(Tok, diag::warn_cxx_static_assert_in_c)
----------------
I don't think we need the `isMacroDefined` check here; we will have a 
`static_assert` macro in that case, so we won't see a `kw_static_assert` token. 
Checking for `assert` being defined means we won't warn on this, and we should:

```
#include <assert.h>
#undef static_assert
static_assert(1, "");
```


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