diff options
author | Douglas Gregor <dgregor@apple.com> | 2009-04-17 16:55:36 +0000 |
---|---|---|
committer | Douglas Gregor <dgregor@apple.com> | 2009-04-17 16:55:36 +0000 |
commit | 915b6c663d0ce51b429d40d22de7dfa0524b1a3f (patch) | |
tree | 523bbaf07b9d8103fc6470e59428aa7149658942 /clang/lib/Frontend/PCHReader.cpp | |
parent | f961e5921f3027280b733362ffb2e9ac3497752c (diff) | |
download | bcm5719-llvm-915b6c663d0ce51b429d40d22de7dfa0524b1a3f.tar.gz bcm5719-llvm-915b6c663d0ce51b429d40d22de7dfa0524b1a3f.zip |
PCH support for declaration statements, and a test for PredefinedExpr
llvm-svn: 69356
Diffstat (limited to 'clang/lib/Frontend/PCHReader.cpp')
-rw-r--r-- | clang/lib/Frontend/PCHReader.cpp | 25 |
1 files changed, 24 insertions, 1 deletions
diff --git a/clang/lib/Frontend/PCHReader.cpp b/clang/lib/Frontend/PCHReader.cpp index 0dcdf8d3fd8..50378966e16 100644 --- a/clang/lib/Frontend/PCHReader.cpp +++ b/clang/lib/Frontend/PCHReader.cpp @@ -257,6 +257,7 @@ namespace { unsigned VisitContinueStmt(ContinueStmt *S); unsigned VisitBreakStmt(BreakStmt *S); unsigned VisitReturnStmt(ReturnStmt *S); + unsigned VisitDeclStmt(DeclStmt *S); unsigned VisitExpr(Expr *E); unsigned VisitPredefinedExpr(PredefinedExpr *E); unsigned VisitDeclRefExpr(DeclRefExpr *E); @@ -406,6 +407,25 @@ unsigned PCHStmtReader::VisitReturnStmt(ReturnStmt *S) { return 1; } +unsigned PCHStmtReader::VisitDeclStmt(DeclStmt *S) { + VisitStmt(S); + S->setStartLoc(SourceLocation::getFromRawEncoding(Record[Idx++])); + S->setEndLoc(SourceLocation::getFromRawEncoding(Record[Idx++])); + + if (Idx + 1 == Record.size()) { + // Single declaration + S->setDeclGroup(DeclGroupRef(Reader.GetDecl(Record[Idx++]))); + } else { + llvm::SmallVector<Decl *, 16> Decls; + Decls.reserve(Record.size() - Idx); + for (unsigned N = Record.size(); Idx != N; ++Idx) + Decls.push_back(Reader.GetDecl(Record[Idx])); + S->setDeclGroup(DeclGroupRef(DeclGroup::Create(Reader.getContext(), + &Decls[0], Decls.size()))); + } + return 0; +} + unsigned PCHStmtReader::VisitExpr(Expr *E) { VisitStmt(E); E->setType(Reader.GetType(Record[Idx++])); @@ -2184,8 +2204,11 @@ Stmt *PCHReader::ReadStmt() { S = new (Context) ReturnStmt(Empty); break; + case pch::STMT_DECL: + S = new (Context) DeclStmt(Empty); + break; + case pch::EXPR_PREDEFINED: - // FIXME: untested (until we can serialize function bodies). S = new (Context) PredefinedExpr(Empty); break; |