diff options
author | Richard Smith <richard-llvm@metafoo.co.uk> | 2012-03-12 08:56:40 +0000 |
---|---|---|
committer | Richard Smith <richard-llvm@metafoo.co.uk> | 2012-03-12 08:56:40 +0000 |
commit | 7796eb5643244f3134834253ce5ea89107ac21c1 (patch) | |
tree | 223c93c51604d1e6128470ad42ea5af267b8abaf /test/Parser | |
parent | 69730c115c2d0fec2f20609d905d920a5a41b29b (diff) |
Fix parsing of trailing-return-type. Types are syntactically prohibited from
being defined here: [] () -> struct S {} does not define struct S.
In passing, implement DR1318 (syntactic disambiguation of 'final').
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@152551 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'test/Parser')
-rw-r--r-- | test/Parser/cxx0x-ambig.cpp | 11 | ||||
-rw-r--r-- | test/Parser/cxx0x-decl.cpp | 10 | ||||
-rw-r--r-- | test/Parser/cxx0x-lambda-expressions.cpp | 5 |
3 files changed, 24 insertions, 2 deletions
diff --git a/test/Parser/cxx0x-ambig.cpp b/test/Parser/cxx0x-ambig.cpp index c955dc1690..b77bae500e 100644 --- a/test/Parser/cxx0x-ambig.cpp +++ b/test/Parser/cxx0x-ambig.cpp @@ -5,15 +5,24 @@ // final 'context sensitive' mess. namespace final { struct S { int n; }; + struct T { int n; }; namespace N { int n; + // These declare variables named final.. + extern struct S final; + extern struct S final [[]]; + extern struct S final, foo; + struct S final = S(); + // This defines a class, not a variable, even though it would successfully // parse as a variable but not as a class. DR1318's wording suggests that // this disambiguation is only performed on an ambiguity, but that was not // the intent. - struct S final { + struct S final { // expected-note {{here}} int(n) // expected-error {{expected ';'}} }; + // This too. + struct T final : S {}; // expected-error {{base 'S' is marked 'final'}} } } diff --git a/test/Parser/cxx0x-decl.cpp b/test/Parser/cxx0x-decl.cpp index 73aa3fdc40..b9f5141a53 100644 --- a/test/Parser/cxx0x-decl.cpp +++ b/test/Parser/cxx0x-decl.cpp @@ -6,3 +6,13 @@ namespace Commas { b [[ ]], c alignas(double); } + +struct S {}; +enum E { e }; + +auto f() -> struct S { + return S(); +} +auto g() -> enum E { + return E(); +} diff --git a/test/Parser/cxx0x-lambda-expressions.cpp b/test/Parser/cxx0x-lambda-expressions.cpp index 87d14051e9..9c71941421 100644 --- a/test/Parser/cxx0x-lambda-expressions.cpp +++ b/test/Parser/cxx0x-lambda-expressions.cpp @@ -1,5 +1,7 @@ // RUN: %clang_cc1 -fsyntax-only -Wno-unused-value -verify -std=c++11 %s +enum E { e }; + class C { int f() { @@ -19,6 +21,8 @@ class C { [=,&foo] () {}; [&,foo] () {}; [this] () {}; + [] () -> class C { return C(); }; + [] () -> enum E { return e; }; [] -> int { return 0; }; // expected-error{{lambda requires '()' before return type}} [] mutable -> int { return 0; }; // expected-error{{lambda requires '()' before 'mutable'}} @@ -37,4 +41,3 @@ class C { int a6[1] = {[this] = 1 }; // expected-error{{integral constant expression must have integral or unscoped enumeration type, not 'C *'}} } }; - |