From: Nico Weber Date: Fri, 18 Jan 2013 18:41:42 +0000 (+0000) Subject: Fix parsing of class specifiers before '\n' 'operator'. X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=55fc3a767b9945bd1f311f2339dcaa8761da5661;p=clang Fix parsing of class specifiers before '\n' 'operator'. r159549 / r159164 regressed clang to reject struct s {}; struct s operator++(struct s a) { return a; } This fixes the regression. Richard, pleas check if this looks right. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@172834 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Parse/ParseDeclCXX.cpp b/lib/Parse/ParseDeclCXX.cpp index cc3318501a..9aa3a8b2af 100644 --- a/lib/Parse/ParseDeclCXX.cpp +++ b/lib/Parse/ParseDeclCXX.cpp @@ -964,6 +964,7 @@ bool Parser::isValidAfterTypeSpecifier(bool CouldBeBitfield) { case tok::annot_template_id: // struct foo {...} a ::b; case tok::l_paren: // struct foo {...} ( x); case tok::comma: // __builtin_offsetof(struct foo{...} , + case tok::kw_operator: // struct foo operator++() {...} return true; case tok::colon: return CouldBeBitfield; // enum E { ... } : 2; diff --git a/test/Parser/cxx-decl.cpp b/test/Parser/cxx-decl.cpp index 5a4c9da0f6..aa775c8c76 100644 --- a/test/Parser/cxx-decl.cpp +++ b/test/Parser/cxx-decl.cpp @@ -132,6 +132,24 @@ struct S { typedef S() : n(1), m(2) { } // expected-error {{function definition declared 'typedef'}} }; + +namespace TestIsValidAfterTypeSpecifier { +struct s {}; + +namespace a { +struct s operator++(struct s a) +{ return a; } +} + +namespace b { +// The newline after s should make no difference. +struct s +operator++(struct s a) +{ return a; } +} + +} + // PR8380 extern "" // expected-error {{unknown linkage language}} test6a { ;// expected-error {{C++ requires a type specifier for all declarations}} \