Quuxplusone added inline comments.

================
Comment at: clang/include/clang/Basic/DiagnosticParseKinds.td:1553
+  "%select{references|destructors|block pointers|ref-qualified member 
functions}2">,
+  InGroup<DiagGroup<"declare-with-symbols">>;
+
----------------
@cjdb: I suggest splitting this diagnostic up, mainly for sanity's sake (it 
currently has 4x2x4 = 32 possible outputs, which is Too Much) but also to 
improve greppability (it took me five tries to find the source of the message 
"when declaring destructors" in this PR). I would do one diagnostic `"use 
'%{&|&&}0' when declaring %{lvalue|rvalue}1 %{references|ref-qualified member 
functions}"`; another diagnostic `"use '~' when declaring destructors"`; and a 
third `"use '^' when declaring block pointers"`.

@aaron.ballman wrote:
> One question I have about both declarations and expressions are whether we 
> have an appetite to diagnose overloaded operators or not. Personally, I think 
> it'd be reasonable to diagnose something like `foo->operator bitand();` or 
> `operator not_eq(A, B);` as expressions, but not reasonable to diagnose the 
> declaration of the overloaded operators using alternative tokens.

AIUI, @cjdb is deferring all diagnostics related to //expressions// into a 
later PR, and I think that's reasonable. There's a subtlety to your example I 
can't tell if you intended: `foo->operator bitand()` is clearly wrong because 
the unary operator `&` being invoked there is not `bitand`; it's address-of! 
`foo->operator bitand()` will presumably fall into the same category as 
`foo->compl Foo()`. Whereas there's nothing so wrong with `foo->operator 
not_eq(bar)` or `operator not_eq(foo, bar)`. 

However, all that has at least two adjacent issues that I know are on @cjdb's 
radar: (1) `auto transformed = foo bitor std::views::transform(bar)` is 
"wrong", and in fact (2) //any// use of alternative tokens other than `and`, 
`or`, `not` is unstylish. If you diagnose //all// usage of `bitand`, `bitor`, 
`compl`, etc., then you don't get any of these subtle problems, because 
`&&/||/!` only have one meaning each (except for rvalue references, which is 
handled in this PR; and GCC-extension `&&label`, which should be easy to catch).


Repository:
  rG LLVM Github Monorepo

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

https://reviews.llvm.org/D107292

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

Reply via email to