erichkeane wrote:

> LGTM but please wait for some additional opinions from other reviewers before 
> landing.

I don't actually spend much time writing compatibility warnings, but think this 
is an improvement.  

As a followup perhaps, I would LOVE it if we could modify the 
DiagnosticsEmitter to make the calls here be `CompatDiag(SrcLoc, DiagBASE)`.

WHERE: 
1- It determines the C++ standard version itself, so it checks LangOpts so we 
don't have to actually tell it what standards verseion.

2- Where the unsigned it takes is actually an index/etc into a decoder.  The 
decoder is just a function that gets generated, so perhaps something like:

```
int Sema::CompatDiag(SourceLocation Loc, unsigned DiagBase) {
  unsigned DiagId = DecodeCompatDiag(getLangOpts(), DiagBase);
  return Diag(Loc, DiagId);
}
// the below is generated:
unsigned DecodeCompatDiag(LangOpts &LO, unsigned DiagBase) {
  switch(DiagBase) {
       case diag_compat::compat_cxx20_foo:
           return LO.CPlusPlus20 ? diag::compat_cxx20_foo : 
diag::compat_pre_cxx20_foo;
       ...
  }
}
```

BUT As I said, what we have in this patch is at least an improvement, and is 
perhaps OK because of that.

https://github.com/llvm/llvm-project/pull/132129
_______________________________________________
cfe-commits mailing list
cfe-commits@lists.llvm.org
https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits

Reply via email to