diff options
author | Richard Smith <richard-llvm@metafoo.co.uk> | 2013-01-29 04:13:32 +0000 |
---|---|---|
committer | Richard Smith <richard-llvm@metafoo.co.uk> | 2013-01-29 04:13:32 +0000 |
commit | 52c5b87cc9aa76de642dcc76d563b6c9eb0f24f1 (patch) | |
tree | 5b4ec7e1fbc8849fa9cbedcdd1ee0b581adfd280 /clang/lib/Parse/ParseDeclCXX.cpp | |
parent | ff37d94e6f74ed23aa6311af692c5c079aec3eab (diff) | |
download | bcm5719-llvm-52c5b87cc9aa76de642dcc76d563b6c9eb0f24f1.tar.gz bcm5719-llvm-52c5b87cc9aa76de642dcc76d563b6c9eb0f24f1.zip |
PR15017: A '>' can appear after a type-specifier in a template-argument-list.
It turns out that there's no correctness bug here (because we can't have a type
definition in this location), but there was a diagnostic bug.
llvm-svn: 173766
Diffstat (limited to 'clang/lib/Parse/ParseDeclCXX.cpp')
-rw-r--r-- | clang/lib/Parse/ParseDeclCXX.cpp | 3 |
1 files changed, 3 insertions, 0 deletions
diff --git a/clang/lib/Parse/ParseDeclCXX.cpp b/clang/lib/Parse/ParseDeclCXX.cpp index 2c5d142fd7f..4f0c893b040 100644 --- a/clang/lib/Parse/ParseDeclCXX.cpp +++ b/clang/lib/Parse/ParseDeclCXX.cpp @@ -1015,6 +1015,9 @@ bool Parser::isValidAfterTypeSpecifier(bool CouldBeBitfield) { case tok::l_square: // enum E [[]] x // Note, no tok::kw_alignas here; alignas cannot appertain to a type. return getLangOpts().CPlusPlus11 && NextToken().is(tok::l_square); + case tok::greater: + // template<class T = class X> + return getLangOpts().CPlusPlus; } return false; } |