diff options
author | Richard Smith <richard@metafoo.co.uk> | 2020-01-17 15:42:11 -0800 |
---|---|---|
committer | Richard Smith <richard@metafoo.co.uk> | 2020-01-17 15:47:21 -0800 |
commit | a42fd84cff265b7e9faa3fe42885ee171393e4db (patch) | |
tree | 5d11cced383c21fb9901c3e2454e469f51daa2c4 /clang/lib/Parse/Parser.cpp | |
parent | 49dc3a94671d0b3a995381d5b00dc89366ac0481 (diff) | |
download | llvm-a42fd84cff265b7e9faa3fe42885ee171393e4db.zip llvm-a42fd84cff265b7e9faa3fe42885ee171393e4db.tar.gz llvm-a42fd84cff265b7e9faa3fe42885ee171393e4db.tar.bz2 |
Remove redundant CXXScopeSpec from TemplateIdAnnotation.
A TemplateIdAnnotation represents only a template-id, not a
nested-name-specifier plus a template-id. Don't make a redundant copy of
the CXXScopeSpec and store it on the template-id annotation.
This slightly improves error recovery by more properly handling the case
where we would form an invalid CXXScopeSpec while parsing a typename
specifier, instead of accidentally putting the token stream into a
broken "annot_template_id with a scope specifier, but with no preceding
annot_cxxscope token" state.
Diffstat (limited to 'clang/lib/Parse/Parser.cpp')
-rw-r--r-- | clang/lib/Parse/Parser.cpp | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/clang/lib/Parse/Parser.cpp b/clang/lib/Parse/Parser.cpp index 0fb0a52..0194c24 100644 --- a/clang/lib/Parse/Parser.cpp +++ b/clang/lib/Parse/Parser.cpp @@ -1810,7 +1810,7 @@ bool Parser::TryAnnotateTypeOrScopeToken() { /*EnteringContext=*/false, nullptr, /*IsTypename*/ true)) return true; - if (!SS.isSet()) { + if (SS.isEmpty()) { if (Tok.is(tok::identifier) || Tok.is(tok::annot_template_id) || Tok.is(tok::annot_decltype)) { // Attempt to recover by skipping the invalid 'typename' @@ -1983,7 +1983,7 @@ bool Parser::TryAnnotateTypeOrScopeTokenAfterScopeSpec(CXXScopeSpec &SS, // template-id annotation in a context where we weren't allowed // to produce a type annotation token. Update the template-id // annotation token to a type annotation token now. - AnnotateTemplateIdTokenAsType(); + AnnotateTemplateIdTokenAsType(SS); return false; } } |