aaron.ballman added reviewers: sammccall, rjmccall, efriedma.
aaron.ballman added a comment.

In D133289#3784117 <https://reviews.llvm.org/D133289#3784117>, @aaron.ballman 
wrote:

> One thought that occurred to me is that the way C has this specified is 
> awfully effectively the same way implicit int worked. It may be worth 
> exploring a change to our implicit int functionality to instead generate an 
> implicit `auto` type when in C2x mode.

I've been thinking about this more and I'm starting to make myself a bit 
uncomfortable with the current approach, at least in terms of how we're 
handling it on the parsing side of things. I think it's reasonable for us to 
form an `AutoType` when we eventually get down to forming the type. But I'm 
uncomfortable with not modeling the language when parsing. e.g., I think we 
want to parse `auto` as a storage class specifier rather than a type specifier, 
and we want to rely on the lack of a type specifier coupled with use of `auto` 
as a storage class specifier to determine the situations where we want to infer 
a type. The resulting semantics should be basically equivalent, but this 
ensures that we're properly parsing as the language expects which helps us be 
forwards-compatible with future changes in C that build on top of this being a 
storage class specifier rather than a type.

Adding a few more reviewers for some extra opinions on this.



================
Comment at: clang/include/clang/Basic/DiagnosticParseKinds.td:374
+def err_c2x_auto_compound_literal_not_allowed: Error<
+  "'auto' is not allowed in compound litterals">;
 def ext_auto_type : Extension<
----------------



================
Comment at: clang/lib/Parse/ParseExpr.cpp:1515
+    // This is a temporary fix while we don't support C2x 6.5.2.5p4
+    if (getLangOpts().C2x && GetLookAheadToken(2).getKind() == tok::l_brace) {
+      Diag(Tok, diag::err_c2x_auto_compound_literal_not_allowed);
----------------
Why would this not be handled from `Sema::ActOnCompoundLiteral()`?


================
Comment at: clang/test/C/C2x/n3007.c:7
+void test_qualifiers(int x, const int y) {
+  // TODO: prohibit cont auto
+  const auto a = x;
----------------
Why? My reading of the grammar is that `const auto` is valid. `const` is a 
type-specifier-qualifier declaration-specifier, and `auto` is a 
storage-class-specifier declaration-specifier, and a declaration is allowed to 
use a sequence of declaration-specifiers.


================
Comment at: clang/test/C/C2x/n3007.c:15
+
+  // TODO: prohibit cont auto
+  const int ci = 12;
----------------



================
Comment at: clang/test/Sema/c2x-auto.c:49
+    auto b = 9;
+    auto c = a + b;
+  }
----------------
to268 wrote:
> shafik wrote:
> > When I made the comment about the example from the proposal, this was what 
> > I was thinking about.
> Do i need to treat shadowing when using `auto` as invalid?
You shouldn't need to do anything special there, I think. It should naturally 
fall out that you cannot use a variable in its own initialization. Note, you 
don't even need an inner scope for that: https://godbolt.org/z/EYa3fMxqx 
(example is compiled in C++ mode).


Repository:
  rG LLVM Github Monorepo

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

https://reviews.llvm.org/D133289

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

Reply via email to