summaryrefslogtreecommitdiffstats
path: root/clang/lib/Parse/ParseStmt.cpp
diff options
context:
space:
mode:
authorReid Kleckner <reid@kleckner.net>2014-06-25 00:28:35 +0000
committerReid Kleckner <reid@kleckner.net>2014-06-25 00:28:35 +0000
commit6d8d22ae404cc857782c422e1f53c7d4a3d9311f (patch)
tree862a9cb7845ce4b8109f22f7d7df4f9bb62c91a7 /clang/lib/Parse/ParseStmt.cpp
parent624ac24da95211b7883362acbce37594aeccc3b7 (diff)
downloadbcm5719-llvm-6d8d22ae404cc857782c422e1f53c7d4a3d9311f.tar.gz
bcm5719-llvm-6d8d22ae404cc857782c422e1f53c7d4a3d9311f.zip
Fix parsing nested __if_exists blocks
Rather than having kw___if_exists be a special case of ParseCompoundStatementBody, we can look for kw___if_exists in the big switch over for valid statement tokens in ParseStatementOrDeclaration. Nested __if_exists blocks are used in the DECLARE_REGISTRY_RESOURCEID macro from atlcom.h. llvm-svn: 211654
Diffstat (limited to 'clang/lib/Parse/ParseStmt.cpp')
-rw-r--r--clang/lib/Parse/ParseStmt.cpp14
1 files changed, 8 insertions, 6 deletions
diff --git a/clang/lib/Parse/ParseStmt.cpp b/clang/lib/Parse/ParseStmt.cpp
index 536e92c0cc6..f27634cb2ae 100644
--- a/clang/lib/Parse/ParseStmt.cpp
+++ b/clang/lib/Parse/ParseStmt.cpp
@@ -273,6 +273,14 @@ Retry:
break;
}
+ case tok::kw___if_exists:
+ case tok::kw___if_not_exists:
+ ProhibitAttributes(Attrs);
+ ParseMicrosoftIfExistsStatement(Stmts);
+ // An __if_exists block is like a compound statement, but it doesn't create
+ // a new scope.
+ return StmtEmpty();
+
case tok::kw_try: // C++ 15: try-block
return ParseCXXTryBlock();
@@ -914,12 +922,6 @@ StmtResult Parser::ParseCompoundStatementBody(bool isStmtExpr) {
continue;
}
- if (getLangOpts().MicrosoftExt && (Tok.is(tok::kw___if_exists) ||
- Tok.is(tok::kw___if_not_exists))) {
- ParseMicrosoftIfExistsStatement(Stmts);
- continue;
- }
-
StmtResult R;
if (Tok.isNot(tok::kw___extension__)) {
R = ParseStatementOrDeclaration(Stmts, false);
OpenPOWER on IntegriCloud