diff options
author | Douglas Gregor <dgregor@apple.com> | 2009-04-17 16:34:57 +0000 |
---|---|---|
committer | Douglas Gregor <dgregor@apple.com> | 2009-04-17 16:34:57 +0000 |
commit | f961e5921f3027280b733362ffb2e9ac3497752c (patch) | |
tree | d1987a4977d2aa061f41df72408ab461cb4fea32 /clang/lib/Frontend/PCHReader.cpp | |
parent | 5775af1afd5059282fbe18f0075a9b22010ab37a (diff) | |
download | bcm5719-llvm-f961e5921f3027280b733362ffb2e9ac3497752c.tar.gz bcm5719-llvm-f961e5921f3027280b733362ffb2e9ac3497752c.zip |
PCH support for return statements.
Optimize PCH encoding for switch-case statements slightly, by making
the switch-case numbering local to a particular statement.
llvm-svn: 69355
Diffstat (limited to 'clang/lib/Frontend/PCHReader.cpp')
-rw-r--r-- | clang/lib/Frontend/PCHReader.cpp | 13 |
1 files changed, 13 insertions, 0 deletions
diff --git a/clang/lib/Frontend/PCHReader.cpp b/clang/lib/Frontend/PCHReader.cpp index d2fb8ab3cbd..0dcdf8d3fd8 100644 --- a/clang/lib/Frontend/PCHReader.cpp +++ b/clang/lib/Frontend/PCHReader.cpp @@ -256,6 +256,7 @@ namespace { unsigned VisitForStmt(ForStmt *S); unsigned VisitContinueStmt(ContinueStmt *S); unsigned VisitBreakStmt(BreakStmt *S); + unsigned VisitReturnStmt(ReturnStmt *S); unsigned VisitExpr(Expr *E); unsigned VisitPredefinedExpr(PredefinedExpr *E); unsigned VisitDeclRefExpr(DeclRefExpr *E); @@ -398,6 +399,13 @@ unsigned PCHStmtReader::VisitBreakStmt(BreakStmt *S) { return 0; } +unsigned PCHStmtReader::VisitReturnStmt(ReturnStmt *S) { + VisitStmt(S); + S->setRetValue(cast_or_null<Expr>(StmtStack.back())); + S->setReturnLoc(SourceLocation::getFromRawEncoding(Record[Idx++])); + return 1; +} + unsigned PCHStmtReader::VisitExpr(Expr *E) { VisitStmt(E); E->setType(Reader.GetType(Record[Idx++])); @@ -2172,6 +2180,10 @@ Stmt *PCHReader::ReadStmt() { S = new (Context) BreakStmt(Empty); break; + case pch::STMT_RETURN: + S = new (Context) ReturnStmt(Empty); + break; + case pch::EXPR_PREDEFINED: // FIXME: untested (until we can serialize function bodies). S = new (Context) PredefinedExpr(Empty); @@ -2311,6 +2323,7 @@ Stmt *PCHReader::ReadStmt() { StmtStack.push_back(S); } assert(StmtStack.size() == 1 && "Extra expressions on stack!"); + SwitchCaseStmts.clear(); return StmtStack.back(); } |