Sirraide wrote:

> 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:

That’s an interesting idea: we could use a new set of IDs that get converted to 
regular diagnostic IDs by the helper and also make it a scoped enum while we’re 
at it so you can’t confuse the two (because the new IDs would be usable with 
`CompatDiag` only); the actual diagnostic IDs for the warnings would still be 
provided (probably in the exact same format that this pr introduces) for cases 
where you might want to issue one or the other separately (or for when you want 
to assign it to a variable and pass it around because there are a few cases 
where we do that because we have a set of more than just 2 compat warnings; 
this pr doesn’t handle such cases and they are rare enough to where I feel like 
it’s not worth trying to handle them like this).

I’ll look into this next because I feel like this shouldn’t be all that hard to 
implement

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