aaron.ballman added a comment.

In D133887#3799347 <https://reviews.llvm.org/D133887#3799347>, @Izaron wrote:

> In D133887#3799310 <https://reviews.llvm.org/D133887#3799310>, @aaron.ballman 
> wrote:
>
>> Thank you for working on this! I spotted an issue where we're not quite 
>> complete with this implementation work. I pushed up a new test case in 
>> https://github.com/llvm/llvm-project/commit/a244194f73788de6dfd6d753ff09be3625613f9f
>>  that shows it (and set the C status page back to Partial in case this takes 
>> a while to address), but `case` and `default` labels should be accepted the 
>> same as any other label at the end of a compound statement.
>>
>> Btw, when working on C standards features, I've started adding test coverage 
>> that demonstrates we fully implement the paper into the `clang/test/C/` 
>> directory, under the correct standard version. This helps us to track the 
>> status of proposals a bit more easily within the code base.
>
> Hi! Thanks for this information! How did you find out that we should accept 
> labels at end of statement in **C**, but not in **C++**? That is not obvious 
> for me unfortunately. If C supports it, why would C++ not support it?

I knew the answer for C off the top of my head, but was still looking up the 
info for C++. C++ does actually behave the same way:

https://eel.is/c++draft/stmt.label#1 -- `case` and `default` are both a `label`
https://eel.is/c++draft/stmt.block#1.sentence-2 -- all labels at the end of a 
compound statement are treated as if they are followed by a null statement
https://eel.is/c++draft/stmt.stmt#nt:selection-statement -- a `switch` is 
followed by a `statement`
https://eel.is/c++draft/stmt.stmt#stmt.pre-1 -- a `compound-statement` is a 
`statement`

I can fix up the C++ status page as well if you'd like, or I can hold off if 
you're already working on this, it's up to you!


Repository:
  rG LLVM Github Monorepo

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

https://reviews.llvm.org/D133887

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

Reply via email to