summaryrefslogtreecommitdiffstats
path: root/clang/lib/Parse/ParseStmt.cpp
diff options
context:
space:
mode:
authorRichard Smith <richard-llvm@metafoo.co.uk>2018-06-26 23:20:26 +0000
committerRichard Smith <richard-llvm@metafoo.co.uk>2018-06-26 23:20:26 +0000
commitbf5bcf2c15c50381ad84d1ac9bbb171c91188b56 (patch)
treee101c340b1b367af47e9570d0eefdf5407830ac4 /clang/lib/Parse/ParseStmt.cpp
parent69b859c2d8d9a0500cf8164c332b378c927f059e (diff)
downloadbcm5719-llvm-bf5bcf2c15c50381ad84d1ac9bbb171c91188b56.tar.gz
bcm5719-llvm-bf5bcf2c15c50381ad84d1ac9bbb171c91188b56.zip
Diagnose missing 'template' keywords in more cases.
We track when we see a name-shaped expression followed by a '<' token and parse the '<' as a comparison. Then: * if we see a token sequence that cannot possibly be an expression but can be a template argument (in particular, a type-id) that follows either a ',' or the '<', diagnose that the '<' was supposed to start a template argument list, and * if we see '>()', diagnose that the '<' was supposed to start a template argument list. This only changes the diagnostic for error cases, and in practice appears to catch the most common cases where a missing 'template' keyword leads to parse errors within a template. Differential Revision: https://reviews.llvm.org/D48571 llvm-svn: 335687
Diffstat (limited to 'clang/lib/Parse/ParseStmt.cpp')
-rw-r--r--clang/lib/Parse/ParseStmt.cpp2
1 files changed, 2 insertions, 0 deletions
diff --git a/clang/lib/Parse/ParseStmt.cpp b/clang/lib/Parse/ParseStmt.cpp
index 44406002c0d..8c4a3056ec0 100644
--- a/clang/lib/Parse/ParseStmt.cpp
+++ b/clang/lib/Parse/ParseStmt.cpp
@@ -1621,6 +1621,8 @@ StmtResult Parser::ParseForStatement(SourceLocation *TrailingElseLoc) {
attrs, attrs.Range.getEnd());
ForRange = true;
} else if (isForInitDeclaration()) { // for (int X = 4;
+ ParenBraceBracketBalancer BalancerRAIIObj(*this);
+
// Parse declaration, which eats the ';'.
if (!C99orCXXorObjC) // Use of C99-style for loops in C90 mode?
Diag(Tok, diag::ext_c99_variable_decl_in_for_loop);
OpenPOWER on IntegriCloud