cor3ntin added inline comments.
================ Comment at: clang/test/SemaCXX/cxx2c-placeholder-vars.cpp:2 +// RUN: %clang -cc1 -fsyntax-only -verify -std=c++2c -Wunused-parameter -Wunused %s + +void static_var() { ---------------- cor3ntin wrote: > cor3ntin wrote: > > hubert.reinterpretcast wrote: > > > hubert.reinterpretcast wrote: > > > > hubert.reinterpretcast wrote: > > > > > hubert.reinterpretcast wrote: > > > > > > Can we have tests for: > > > > > > ``` > > > > > > struct { int _, _; } a = { ._ = 0 }; > > > > > > ``` > > > > > > > > > > > > and > > > > > > > > > > > > ``` > > > > > > struct A { > > > > > > A(); > > > > > > int _, _; > > > > > > }; > > > > > > > > > > > > A::A() : _(0) {} > > > > > > ``` > > > > > Codegen test for > > > > > ``` > > > > > static union { int _ = 42; }; > > > > > int &ref = _; > > > > > int foo() { return 13; } > > > > > static union { int _ = foo(); }; > > > > > int main(void) { return ref; } > > > > > ``` > > > > > might be interesting. > > > > > > > > > > I suspect that this case was missed in the committee discussion of > > > > > the paper @cor3ntin. > > > > Less controversial tests to consider: > > > > ``` > > > > struct A { > > > > int _; > > > > union { int _; }; > > > > }; > > > > struct B { union { int _, _; }; }; > > > > ``` > > > > > > > In a similar vein, a codegen test for: > > > ``` > > > struct A { A(); }; > > > inline void f [[gnu::used]]() { > > > static union { A _{}; }; > > > static union { A _{}; }; > > > } > > > ``` > > > > > > Perhaps not intended to be allowed though (premise was no symbols with > > > "linkage"?) > > What's interesting about > > > > ``` > > static union { int _ = 42; }; > > int &ref = _; > > int foo() { return 13; } > > static union { int _ = foo(); }; > > int main(void) { return ref; } > > ``` > > ? > > It's already supported by clang https://godbolt.org/z/6j89EdnEo > > > > > > I'm adding the other tests (and fixing the associated bugs, of which there > > were a few...) > > > > Perhaps not intended to be allowed though (premise was no symbols with > > "linkage"?) > > > Yes, this should be ill-formed, anything where we would have to mangle > multiple `_` should be ill-formed. > I do believe that's covered though, `_` does not have storage duration. > What's interesting about > > ``` > static union { int _ = 42; }; > int &ref = _; > int foo() { return 13; } > static union { int _ = foo(); }; > int main(void) { return ref; } > ``` > ? > It's already supported by clang https://godbolt.org/z/6j89EdnEo > > > I'm adding the other tests (and fixing the associated bugs, of which there > were a few...) > I see it now. Thanks, I hate it. There is apparently a preexisting bug. And yes, i think we should say something about members of anonymous union declared at namespace scope in the standard.... I realize now this is missing Thanks for catching that. Repository: rG LLVM Github Monorepo CHANGES SINCE LAST ACTION https://reviews.llvm.org/D153536/new/ https://reviews.llvm.org/D153536 _______________________________________________ cfe-commits mailing list cfe-commits@lists.llvm.org https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits