diff options
author | Douglas Gregor <dgregor@apple.com> | 2009-04-15 16:35:07 +0000 |
---|---|---|
committer | Douglas Gregor <dgregor@apple.com> | 2009-04-15 16:35:07 +0000 |
commit | 673ecd6a4a9f7c12fb6f76f84f654dbdcdc89e76 (patch) | |
tree | c7b9929fc8f06ced9e70c6e2e9ddf3a07a483a9b /lib/Frontend/PCHReader.cpp | |
parent | c35d71f1e0a0c72fd43a73ddecd408bf43d501de (diff) |
PCH support for string literals
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@69172 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Frontend/PCHReader.cpp')
-rw-r--r-- | lib/Frontend/PCHReader.cpp | 31 |
1 files changed, 31 insertions, 0 deletions
diff --git a/lib/Frontend/PCHReader.cpp b/lib/Frontend/PCHReader.cpp index 96c383b49f..2da21023c7 100644 --- a/lib/Frontend/PCHReader.cpp +++ b/lib/Frontend/PCHReader.cpp @@ -226,6 +226,10 @@ namespace { unsigned &Idx, llvm::SmallVectorImpl<Expr *> &ExprStack) : Reader(Reader), Record(Record), Idx(Idx), ExprStack(ExprStack) { } + /// \brief The number of record fields required for the Expr class + /// itself. + static const unsigned NumExprFields = 3; + // Each of the Visit* functions reads in part of the expression // from the given record and the current expression stack, then // return the total number of operands that it read from the @@ -236,6 +240,7 @@ namespace { unsigned VisitDeclRefExpr(DeclRefExpr *E); unsigned VisitIntegerLiteral(IntegerLiteral *E); unsigned VisitFloatingLiteral(FloatingLiteral *E); + unsigned VisitStringLiteral(StringLiteral *E); unsigned VisitCharacterLiteral(CharacterLiteral *E); unsigned VisitParenExpr(ParenExpr *E); unsigned VisitUnaryOperator(UnaryOperator *E); @@ -252,6 +257,7 @@ unsigned PCHStmtReader::VisitExpr(Expr *E) { E->setType(Reader.GetType(Record[Idx++])); E->setTypeDependent(Record[Idx++]); E->setValueDependent(Record[Idx++]); + assert(Idx == NumExprFields && "Incorrect expression field count"); return 0; } @@ -284,6 +290,26 @@ unsigned PCHStmtReader::VisitFloatingLiteral(FloatingLiteral *E) { return 0; } +unsigned PCHStmtReader::VisitStringLiteral(StringLiteral *E) { + VisitExpr(E); + unsigned Len = Record[Idx++]; + assert(Record[Idx] == E->getNumConcatenated() && + "Wrong number of concatenated tokens!"); + ++Idx; + E->setWide(Record[Idx++]); + + // Read string data + llvm::SmallVector<char, 16> Str(&Record[Idx], &Record[Idx] + Len); + E->setStrData(Reader.getContext(), &Str[0], Len); + Idx += Len; + + // Read source locations + for (unsigned I = 0, N = E->getNumConcatenated(); I != N; ++I) + E->setStrTokenLoc(I, SourceLocation::getFromRawEncoding(Record[Idx++])); + + return 0; +} + unsigned PCHStmtReader::VisitCharacterLiteral(CharacterLiteral *E) { VisitExpr(E); E->setValue(Record[Idx++]); @@ -1656,6 +1682,11 @@ Expr *PCHReader::ReadExpr() { E = new (Context) FloatingLiteral(Empty); break; + case pch::EXPR_STRING_LITERAL: + E = StringLiteral::CreateEmpty(Context, + Record[PCHStmtReader::NumExprFields + 1]); + break; + case pch::EXPR_CHARACTER_LITERAL: E = new (Context) CharacterLiteral(Empty); break; |