1 //===--- ASTReaderStmt.cpp - Stmt/Expr Deserialization ----------*- C++ -*-===//
2 //
3 //                     The LLVM Compiler Infrastructure
4 //
5 // This file is distributed under the University of Illinois Open Source
6 // License. See LICENSE.TXT for details.
7 //
8 //===----------------------------------------------------------------------===//
9 //
10 // Statement/expression deserialization.  This implements the
11 // ASTReader::ReadStmt method.
12 //
13 //===----------------------------------------------------------------------===//
14 
15 #include "clang/Serialization/ASTReader.h"
16 #include "clang/AST/ASTContext.h"
17 #include "clang/AST/DeclCXX.h"
18 #include "clang/AST/DeclTemplate.h"
19 #include "clang/AST/StmtVisitor.h"
20 #include "clang/Lex/Token.h"
21 #include "llvm/ADT/SmallString.h"
22 using namespace clang;
23 using namespace clang::serialization;
24 
25 namespace clang {
26 
27   class ASTStmtReader : public StmtVisitor<ASTStmtReader> {
28     typedef ASTReader::RecordData RecordData;
29 
30     ASTReader &Reader;
31     ModuleFile &F;
32     llvm::BitstreamCursor &DeclsCursor;
33     const ASTReader::RecordData &Record;
34     unsigned &Idx;
35 
36     Token ReadToken(const RecordData &R, unsigned &I) {
37       return Reader.ReadToken(F, R, I);
38     }
39 
40     SourceLocation ReadSourceLocation(const RecordData &R, unsigned &I) {
41       return Reader.ReadSourceLocation(F, R, I);
42     }
43 
44     SourceRange ReadSourceRange(const RecordData &R, unsigned &I) {
45       return Reader.ReadSourceRange(F, R, I);
46     }
47 
48     std::string ReadString(const RecordData &R, unsigned &I) {
49       return Reader.ReadString(R, I);
50     }
51 
52     TypeSourceInfo *GetTypeSourceInfo(const RecordData &R, unsigned &I) {
53       return Reader.GetTypeSourceInfo(F, R, I);
54     }
55 
56     serialization::DeclID ReadDeclID(const RecordData &R, unsigned &I) {
57       return Reader.ReadDeclID(F, R, I);
58     }
59 
60     Decl *ReadDecl(const RecordData &R, unsigned &I) {
61       return Reader.ReadDecl(F, R, I);
62     }
63 
64     template<typename T>
65     T *ReadDeclAs(const RecordData &R, unsigned &I) {
66       return Reader.ReadDeclAs<T>(F, R, I);
67     }
68 
69     void ReadDeclarationNameLoc(DeclarationNameLoc &DNLoc, DeclarationName Name,
70                                 const ASTReader::RecordData &R, unsigned &I) {
71       Reader.ReadDeclarationNameLoc(F, DNLoc, Name, R, I);
72     }
73 
74     void ReadDeclarationNameInfo(DeclarationNameInfo &NameInfo,
75                                 const ASTReader::RecordData &R, unsigned &I) {
76       Reader.ReadDeclarationNameInfo(F, NameInfo, R, I);
77     }
78 
79   public:
80     ASTStmtReader(ASTReader &Reader, ModuleFile &F,
81                   llvm::BitstreamCursor &Cursor,
82                   const ASTReader::RecordData &Record, unsigned &Idx)
83       : Reader(Reader), F(F), DeclsCursor(Cursor), Record(Record), Idx(Idx) { }
84 
85     /// \brief The number of record fields required for the Stmt class
86     /// itself.
87     static const unsigned NumStmtFields = 0;
88 
89     /// \brief The number of record fields required for the Expr class
90     /// itself.
91     static const unsigned NumExprFields = NumStmtFields + 7;
92 
93     /// \brief Read and initialize a ExplicitTemplateArgumentList structure.
94     void ReadTemplateKWAndArgsInfo(ASTTemplateKWAndArgsInfo &Args,
95                                    unsigned NumTemplateArgs);
96     /// \brief Read and initialize a ExplicitTemplateArgumentList structure.
97     void ReadExplicitTemplateArgumentList(ASTTemplateArgumentListInfo &ArgList,
98                                           unsigned NumTemplateArgs);
99 
100     void VisitStmt(Stmt *S);
101 #define STMT(Type, Base) \
102     void Visit##Type(Type *);
103 #include "clang/AST/StmtNodes.inc"
104   };
105 }
106 
107 void ASTStmtReader::
108 ReadTemplateKWAndArgsInfo(ASTTemplateKWAndArgsInfo &Args,
109                           unsigned NumTemplateArgs) {
110   SourceLocation TemplateKWLoc = ReadSourceLocation(Record, Idx);
111   TemplateArgumentListInfo ArgInfo;
112   ArgInfo.setLAngleLoc(ReadSourceLocation(Record, Idx));
113   ArgInfo.setRAngleLoc(ReadSourceLocation(Record, Idx));
114   for (unsigned i = 0; i != NumTemplateArgs; ++i)
115     ArgInfo.addArgument(
116         Reader.ReadTemplateArgumentLoc(F, Record, Idx));
117   Args.initializeFrom(TemplateKWLoc, ArgInfo);
118 }
119 
120 void ASTStmtReader::VisitStmt(Stmt *S) {
121   assert(Idx == NumStmtFields && "Incorrect statement field count");
122 }
123 
124 void ASTStmtReader::VisitNullStmt(NullStmt *S) {
125   VisitStmt(S);
126   S->setSemiLoc(ReadSourceLocation(Record, Idx));
127   S->HasLeadingEmptyMacro = Record[Idx++];
128 }
129 
130 void ASTStmtReader::VisitCompoundStmt(CompoundStmt *S) {
131   VisitStmt(S);
132   SmallVector<Stmt *, 16> Stmts;
133   unsigned NumStmts = Record[Idx++];
134   while (NumStmts--)
135     Stmts.push_back(Reader.ReadSubStmt());
136   S->setStmts(Reader.getContext(), Stmts.data(), Stmts.size());
137   S->setLBracLoc(ReadSourceLocation(Record, Idx));
138   S->setRBracLoc(ReadSourceLocation(Record, Idx));
139 }
140 
141 void ASTStmtReader::VisitSwitchCase(SwitchCase *S) {
142   VisitStmt(S);
143   Reader.RecordSwitchCaseID(S, Record[Idx++]);
144   S->setKeywordLoc(ReadSourceLocation(Record, Idx));
145   S->setColonLoc(ReadSourceLocation(Record, Idx));
146 }
147 
148 void ASTStmtReader::VisitCaseStmt(CaseStmt *S) {
149   VisitSwitchCase(S);
150   S->setLHS(Reader.ReadSubExpr());
151   S->setRHS(Reader.ReadSubExpr());
152   S->setSubStmt(Reader.ReadSubStmt());
153   S->setEllipsisLoc(ReadSourceLocation(Record, Idx));
154 }
155 
156 void ASTStmtReader::VisitDefaultStmt(DefaultStmt *S) {
157   VisitSwitchCase(S);
158   S->setSubStmt(Reader.ReadSubStmt());
159 }
160 
161 void ASTStmtReader::VisitLabelStmt(LabelStmt *S) {
162   VisitStmt(S);
163   LabelDecl *LD = ReadDeclAs<LabelDecl>(Record, Idx);
164   LD->setStmt(S);
165   S->setDecl(LD);
166   S->setSubStmt(Reader.ReadSubStmt());
167   S->setIdentLoc(ReadSourceLocation(Record, Idx));
168 }
169 
170 void ASTStmtReader::VisitAttributedStmt(AttributedStmt *S) {
171   VisitStmt(S);
172   uint64_t NumAttrs = Record[Idx++];
173   AttrVec Attrs;
174   Reader.ReadAttributes(F, Attrs, Record, Idx);
175   (void)NumAttrs;
176   assert(NumAttrs == S->NumAttrs);
177   assert(NumAttrs == Attrs.size());
178   std::copy(Attrs.begin(), Attrs.end(), S->Attrs);
179   S->SubStmt = Reader.ReadSubStmt();
180   S->AttrLoc = ReadSourceLocation(Record, Idx);
181 }
182 
183 void ASTStmtReader::VisitIfStmt(IfStmt *S) {
184   VisitStmt(S);
185   S->setConditionVariable(Reader.getContext(),
186                           ReadDeclAs<VarDecl>(Record, Idx));
187   S->setCond(Reader.ReadSubExpr());
188   S->setThen(Reader.ReadSubStmt());
189   S->setElse(Reader.ReadSubStmt());
190   S->setIfLoc(ReadSourceLocation(Record, Idx));
191   S->setElseLoc(ReadSourceLocation(Record, Idx));
192 }
193 
194 void ASTStmtReader::VisitSwitchStmt(SwitchStmt *S) {
195   VisitStmt(S);
196   S->setConditionVariable(Reader.getContext(),
197                           ReadDeclAs<VarDecl>(Record, Idx));
198   S->setCond(Reader.ReadSubExpr());
199   S->setBody(Reader.ReadSubStmt());
200   S->setSwitchLoc(ReadSourceLocation(Record, Idx));
201   if (Record[Idx++])
202     S->setAllEnumCasesCovered();
203 
204   SwitchCase *PrevSC = 0;
205   for (unsigned N = Record.size(); Idx != N; ++Idx) {
206     SwitchCase *SC = Reader.getSwitchCaseWithID(Record[Idx]);
207     if (PrevSC)
208       PrevSC->setNextSwitchCase(SC);
209     else
210       S->setSwitchCaseList(SC);
211 
212     PrevSC = SC;
213   }
214 }
215 
216 void ASTStmtReader::VisitWhileStmt(WhileStmt *S) {
217   VisitStmt(S);
218   S->setConditionVariable(Reader.getContext(),
219                           ReadDeclAs<VarDecl>(Record, Idx));
220 
221   S->setCond(Reader.ReadSubExpr());
222   S->setBody(Reader.ReadSubStmt());
223   S->setWhileLoc(ReadSourceLocation(Record, Idx));
224 }
225 
226 void ASTStmtReader::VisitDoStmt(DoStmt *S) {
227   VisitStmt(S);
228   S->setCond(Reader.ReadSubExpr());
229   S->setBody(Reader.ReadSubStmt());
230   S->setDoLoc(ReadSourceLocation(Record, Idx));
231   S->setWhileLoc(ReadSourceLocation(Record, Idx));
232   S->setRParenLoc(ReadSourceLocation(Record, Idx));
233 }
234 
235 void ASTStmtReader::VisitForStmt(ForStmt *S) {
236   VisitStmt(S);
237   S->setInit(Reader.ReadSubStmt());
238   S->setCond(Reader.ReadSubExpr());
239   S->setConditionVariable(Reader.getContext(),
240                           ReadDeclAs<VarDecl>(Record, Idx));
241   S->setInc(Reader.ReadSubExpr());
242   S->setBody(Reader.ReadSubStmt());
243   S->setForLoc(ReadSourceLocation(Record, Idx));
244   S->setLParenLoc(ReadSourceLocation(Record, Idx));
245   S->setRParenLoc(ReadSourceLocation(Record, Idx));
246 }
247 
248 void ASTStmtReader::VisitGotoStmt(GotoStmt *S) {
249   VisitStmt(S);
250   S->setLabel(ReadDeclAs<LabelDecl>(Record, Idx));
251   S->setGotoLoc(ReadSourceLocation(Record, Idx));
252   S->setLabelLoc(ReadSourceLocation(Record, Idx));
253 }
254 
255 void ASTStmtReader::VisitIndirectGotoStmt(IndirectGotoStmt *S) {
256   VisitStmt(S);
257   S->setGotoLoc(ReadSourceLocation(Record, Idx));
258   S->setStarLoc(ReadSourceLocation(Record, Idx));
259   S->setTarget(Reader.ReadSubExpr());
260 }
261 
262 void ASTStmtReader::VisitContinueStmt(ContinueStmt *S) {
263   VisitStmt(S);
264   S->setContinueLoc(ReadSourceLocation(Record, Idx));
265 }
266 
267 void ASTStmtReader::VisitBreakStmt(BreakStmt *S) {
268   VisitStmt(S);
269   S->setBreakLoc(ReadSourceLocation(Record, Idx));
270 }
271 
272 void ASTStmtReader::VisitReturnStmt(ReturnStmt *S) {
273   VisitStmt(S);
274   S->setRetValue(Reader.ReadSubExpr());
275   S->setReturnLoc(ReadSourceLocation(Record, Idx));
276   S->setNRVOCandidate(ReadDeclAs<VarDecl>(Record, Idx));
277 }
278 
279 void ASTStmtReader::VisitDeclStmt(DeclStmt *S) {
280   VisitStmt(S);
281   S->setStartLoc(ReadSourceLocation(Record, Idx));
282   S->setEndLoc(ReadSourceLocation(Record, Idx));
283 
284   if (Idx + 1 == Record.size()) {
285     // Single declaration
286     S->setDeclGroup(DeclGroupRef(ReadDecl(Record, Idx)));
287   } else {
288     SmallVector<Decl *, 16> Decls;
289     Decls.reserve(Record.size() - Idx);
290     for (unsigned N = Record.size(); Idx != N; )
291       Decls.push_back(ReadDecl(Record, Idx));
292     S->setDeclGroup(DeclGroupRef(DeclGroup::Create(Reader.getContext(),
293                                                    Decls.data(),
294                                                    Decls.size())));
295   }
296 }
297 
298 void ASTStmtReader::VisitAsmStmt(AsmStmt *S) {
299   VisitStmt(S);
300   S->NumOutputs = Record[Idx++];
301   S->NumInputs = Record[Idx++];
302   S->NumClobbers = Record[Idx++];
303   S->setAsmLoc(ReadSourceLocation(Record, Idx));
304   S->setVolatile(Record[Idx++]);
305   S->setSimple(Record[Idx++]);
306 }
307 
308 void ASTStmtReader::VisitGCCAsmStmt(GCCAsmStmt *S) {
309   VisitAsmStmt(S);
310   S->setRParenLoc(ReadSourceLocation(Record, Idx));
311   S->setAsmString(cast_or_null<StringLiteral>(Reader.ReadSubStmt()));
312 
313   unsigned NumOutputs = S->getNumOutputs();
314   unsigned NumInputs = S->getNumInputs();
315   unsigned NumClobbers = S->getNumClobbers();
316 
317   // Outputs and inputs
318   SmallVector<IdentifierInfo *, 16> Names;
319   SmallVector<StringLiteral*, 16> Constraints;
320   SmallVector<Stmt*, 16> Exprs;
321   for (unsigned I = 0, N = NumOutputs + NumInputs; I != N; ++I) {
322     Names.push_back(Reader.GetIdentifierInfo(F, Record, Idx));
323     Constraints.push_back(cast_or_null<StringLiteral>(Reader.ReadSubStmt()));
324     Exprs.push_back(Reader.ReadSubStmt());
325   }
326 
327   // Constraints
328   SmallVector<StringLiteral*, 16> Clobbers;
329   for (unsigned I = 0; I != NumClobbers; ++I)
330     Clobbers.push_back(cast_or_null<StringLiteral>(Reader.ReadSubStmt()));
331 
332   S->setOutputsAndInputsAndClobbers(Reader.getContext(),
333                                     Names.data(), Constraints.data(),
334                                     Exprs.data(), NumOutputs, NumInputs,
335                                     Clobbers.data(), NumClobbers);
336 }
337 
338 void ASTStmtReader::VisitMSAsmStmt(MSAsmStmt *S) {
339   VisitAsmStmt(S);
340   S->LBraceLoc = ReadSourceLocation(Record, Idx);
341   S->EndLoc = ReadSourceLocation(Record, Idx);
342   S->NumAsmToks = Record[Idx++];
343   std::string AsmStr = ReadString(Record, Idx);
344 
345   // Read the tokens.
346   SmallVector<Token, 16> AsmToks;
347   AsmToks.reserve(S->NumAsmToks);
348   for (unsigned i = 0, e = S->NumAsmToks; i != e; ++i) {
349     AsmToks.push_back(ReadToken(Record, Idx));
350   }
351 
352   // The calls to reserve() for the FooData vectors are mandatory to
353   // prevent dead StringRefs in the Foo vectors.
354 
355   // Read the clobbers.
356   SmallVector<std::string, 16> ClobbersData;
357   SmallVector<StringRef, 16> Clobbers;
358   ClobbersData.reserve(S->NumClobbers);
359   Clobbers.reserve(S->NumClobbers);
360   for (unsigned i = 0, e = S->NumClobbers; i != e; ++i) {
361     ClobbersData.push_back(ReadString(Record, Idx));
362     Clobbers.push_back(ClobbersData.back());
363   }
364 
365   // Read the operands.
366   unsigned NumOperands = S->NumOutputs + S->NumInputs;
367   SmallVector<Expr*, 16> Exprs;
368   SmallVector<std::string, 16> ConstraintsData;
369   SmallVector<StringRef, 16> Constraints;
370   Exprs.reserve(NumOperands);
371   ConstraintsData.reserve(NumOperands);
372   Constraints.reserve(NumOperands);
373   for (unsigned i = 0; i != NumOperands; ++i) {
374     Exprs.push_back(cast<Expr>(Reader.ReadSubStmt()));
375     ConstraintsData.push_back(ReadString(Record, Idx));
376     Constraints.push_back(ConstraintsData.back());
377   }
378 
379   S->initialize(Reader.getContext(), AsmStr, AsmToks,
380                 Constraints, Exprs, Clobbers);
381 }
382 
383 void ASTStmtReader::VisitCapturedStmt(CapturedStmt *S) {
384   VisitStmt(S);
385   S->setCapturedDecl(ReadDeclAs<CapturedDecl>(Record, Idx));
386   S->setCapturedRegionKind(static_cast<CapturedRegionKind>(Record[Idx++]));
387   S->setCapturedRecordDecl(ReadDeclAs<RecordDecl>(Record, Idx));
388 
389   // Capture inits
390   for (CapturedStmt::capture_init_iterator I = S->capture_init_begin(),
391                                            E = S->capture_init_end();
392        I != E; ++I)
393     *I = Reader.ReadSubExpr();
394 
395   // Body
396   S->setCapturedStmt(Reader.ReadSubStmt());
397   S->getCapturedDecl()->setBody(S->getCapturedStmt());
398 
399   // Captures
400   for (CapturedStmt::capture_iterator I = S->capture_begin(),
401                                       E = S->capture_end();
402        I != E; ++I) {
403     I->VarAndKind.setPointer(ReadDeclAs<VarDecl>(Record, Idx));
404     I->VarAndKind
405         .setInt(static_cast<CapturedStmt::VariableCaptureKind>(Record[Idx++]));
406     I->Loc = ReadSourceLocation(Record, Idx);
407   }
408 }
409 
410 void ASTStmtReader::VisitExpr(Expr *E) {
411   VisitStmt(E);
412   E->setType(Reader.readType(F, Record, Idx));
413   E->setTypeDependent(Record[Idx++]);
414   E->setValueDependent(Record[Idx++]);
415   E->setInstantiationDependent(Record[Idx++]);
416   E->ExprBits.ContainsUnexpandedParameterPack = Record[Idx++];
417   E->setValueKind(static_cast<ExprValueKind>(Record[Idx++]));
418   E->setObjectKind(static_cast<ExprObjectKind>(Record[Idx++]));
419   assert(Idx == NumExprFields && "Incorrect expression field count");
420 }
421 
422 void ASTStmtReader::VisitPredefinedExpr(PredefinedExpr *E) {
423   VisitExpr(E);
424   E->setLocation(ReadSourceLocation(Record, Idx));
425   E->setIdentType((PredefinedExpr::IdentType)Record[Idx++]);
426 }
427 
428 void ASTStmtReader::VisitDeclRefExpr(DeclRefExpr *E) {
429   VisitExpr(E);
430 
431   E->DeclRefExprBits.HasQualifier = Record[Idx++];
432   E->DeclRefExprBits.HasFoundDecl = Record[Idx++];
433   E->DeclRefExprBits.HasTemplateKWAndArgsInfo = Record[Idx++];
434   E->DeclRefExprBits.HadMultipleCandidates = Record[Idx++];
435   E->DeclRefExprBits.RefersToEnclosingLocal = Record[Idx++];
436   unsigned NumTemplateArgs = 0;
437   if (E->hasTemplateKWAndArgsInfo())
438     NumTemplateArgs = Record[Idx++];
439 
440   if (E->hasQualifier())
441     E->getInternalQualifierLoc()
442       = Reader.ReadNestedNameSpecifierLoc(F, Record, Idx);
443 
444   if (E->hasFoundDecl())
445     E->getInternalFoundDecl() = ReadDeclAs<NamedDecl>(Record, Idx);
446 
447   if (E->hasTemplateKWAndArgsInfo())
448     ReadTemplateKWAndArgsInfo(*E->getTemplateKWAndArgsInfo(),
449                               NumTemplateArgs);
450 
451   E->setDecl(ReadDeclAs<ValueDecl>(Record, Idx));
452   E->setLocation(ReadSourceLocation(Record, Idx));
453   ReadDeclarationNameLoc(E->DNLoc, E->getDecl()->getDeclName(), Record, Idx);
454 }
455 
456 void ASTStmtReader::VisitIntegerLiteral(IntegerLiteral *E) {
457   VisitExpr(E);
458   E->setLocation(ReadSourceLocation(Record, Idx));
459   E->setValue(Reader.getContext(), Reader.ReadAPInt(Record, Idx));
460 }
461 
462 void ASTStmtReader::VisitFloatingLiteral(FloatingLiteral *E) {
463   VisitExpr(E);
464   E->setRawSemantics(static_cast<Stmt::APFloatSemantics>(Record[Idx++]));
465   E->setExact(Record[Idx++]);
466   E->setValue(Reader.getContext(),
467               Reader.ReadAPFloat(Record, E->getSemantics(), Idx));
468   E->setLocation(ReadSourceLocation(Record, Idx));
469 }
470 
471 void ASTStmtReader::VisitImaginaryLiteral(ImaginaryLiteral *E) {
472   VisitExpr(E);
473   E->setSubExpr(Reader.ReadSubExpr());
474 }
475 
476 void ASTStmtReader::VisitStringLiteral(StringLiteral *E) {
477   VisitExpr(E);
478   unsigned Len = Record[Idx++];
479   assert(Record[Idx] == E->getNumConcatenated() &&
480          "Wrong number of concatenated tokens!");
481   ++Idx;
482   StringLiteral::StringKind kind =
483         static_cast<StringLiteral::StringKind>(Record[Idx++]);
484   bool isPascal = Record[Idx++];
485 
486   // Read string data
487   SmallString<16> Str(&Record[Idx], &Record[Idx] + Len);
488   E->setString(Reader.getContext(), Str.str(), kind, isPascal);
489   Idx += Len;
490 
491   // Read source locations
492   for (unsigned I = 0, N = E->getNumConcatenated(); I != N; ++I)
493     E->setStrTokenLoc(I, ReadSourceLocation(Record, Idx));
494 }
495 
496 void ASTStmtReader::VisitCharacterLiteral(CharacterLiteral *E) {
497   VisitExpr(E);
498   E->setValue(Record[Idx++]);
499   E->setLocation(ReadSourceLocation(Record, Idx));
500   E->setKind(static_cast<CharacterLiteral::CharacterKind>(Record[Idx++]));
501 }
502 
503 void ASTStmtReader::VisitParenExpr(ParenExpr *E) {
504   VisitExpr(E);
505   E->setLParen(ReadSourceLocation(Record, Idx));
506   E->setRParen(ReadSourceLocation(Record, Idx));
507   E->setSubExpr(Reader.ReadSubExpr());
508 }
509 
510 void ASTStmtReader::VisitParenListExpr(ParenListExpr *E) {
511   VisitExpr(E);
512   unsigned NumExprs = Record[Idx++];
513   E->Exprs = new (Reader.getContext()) Stmt*[NumExprs];
514   for (unsigned i = 0; i != NumExprs; ++i)
515     E->Exprs[i] = Reader.ReadSubStmt();
516   E->NumExprs = NumExprs;
517   E->LParenLoc = ReadSourceLocation(Record, Idx);
518   E->RParenLoc = ReadSourceLocation(Record, Idx);
519 }
520 
521 void ASTStmtReader::VisitUnaryOperator(UnaryOperator *E) {
522   VisitExpr(E);
523   E->setSubExpr(Reader.ReadSubExpr());
524   E->setOpcode((UnaryOperator::Opcode)Record[Idx++]);
525   E->setOperatorLoc(ReadSourceLocation(Record, Idx));
526 }
527 
528 void ASTStmtReader::VisitOffsetOfExpr(OffsetOfExpr *E) {
529   typedef OffsetOfExpr::OffsetOfNode Node;
530   VisitExpr(E);
531   assert(E->getNumComponents() == Record[Idx]);
532   ++Idx;
533   assert(E->getNumExpressions() == Record[Idx]);
534   ++Idx;
535   E->setOperatorLoc(ReadSourceLocation(Record, Idx));
536   E->setRParenLoc(ReadSourceLocation(Record, Idx));
537   E->setTypeSourceInfo(GetTypeSourceInfo(Record, Idx));
538   for (unsigned I = 0, N = E->getNumComponents(); I != N; ++I) {
539     Node::Kind Kind = static_cast<Node::Kind>(Record[Idx++]);
540     SourceLocation Start = ReadSourceLocation(Record, Idx);
541     SourceLocation End = ReadSourceLocation(Record, Idx);
542     switch (Kind) {
543     case Node::Array:
544       E->setComponent(I, Node(Start, Record[Idx++], End));
545       break;
546 
547     case Node::Field:
548       E->setComponent(I, Node(Start, ReadDeclAs<FieldDecl>(Record, Idx), End));
549       break;
550 
551     case Node::Identifier:
552       E->setComponent(I,
553                       Node(Start,
554                            Reader.GetIdentifierInfo(F, Record, Idx),
555                            End));
556       break;
557 
558     case Node::Base: {
559       CXXBaseSpecifier *Base = new (Reader.getContext()) CXXBaseSpecifier();
560       *Base = Reader.ReadCXXBaseSpecifier(F, Record, Idx);
561       E->setComponent(I, Node(Base));
562       break;
563     }
564     }
565   }
566 
567   for (unsigned I = 0, N = E->getNumExpressions(); I != N; ++I)
568     E->setIndexExpr(I, Reader.ReadSubExpr());
569 }
570 
571 void ASTStmtReader::VisitUnaryExprOrTypeTraitExpr(UnaryExprOrTypeTraitExpr *E) {
572   VisitExpr(E);
573   E->setKind(static_cast<UnaryExprOrTypeTrait>(Record[Idx++]));
574   if (Record[Idx] == 0) {
575     E->setArgument(Reader.ReadSubExpr());
576     ++Idx;
577   } else {
578     E->setArgument(GetTypeSourceInfo(Record, Idx));
579   }
580   E->setOperatorLoc(ReadSourceLocation(Record, Idx));
581   E->setRParenLoc(ReadSourceLocation(Record, Idx));
582 }
583 
584 void ASTStmtReader::VisitArraySubscriptExpr(ArraySubscriptExpr *E) {
585   VisitExpr(E);
586   E->setLHS(Reader.ReadSubExpr());
587   E->setRHS(Reader.ReadSubExpr());
588   E->setRBracketLoc(ReadSourceLocation(Record, Idx));
589 }
590 
591 void ASTStmtReader::VisitCallExpr(CallExpr *E) {
592   VisitExpr(E);
593   E->setNumArgs(Reader.getContext(), Record[Idx++]);
594   E->setRParenLoc(ReadSourceLocation(Record, Idx));
595   E->setCallee(Reader.ReadSubExpr());
596   for (unsigned I = 0, N = E->getNumArgs(); I != N; ++I)
597     E->setArg(I, Reader.ReadSubExpr());
598 }
599 
600 void ASTStmtReader::VisitCXXMemberCallExpr(CXXMemberCallExpr *E) {
601   VisitCallExpr(E);
602 }
603 
604 void ASTStmtReader::VisitMemberExpr(MemberExpr *E) {
605   // Don't call VisitExpr, this is fully initialized at creation.
606   assert(E->getStmtClass() == Stmt::MemberExprClass &&
607          "It's a subclass, we must advance Idx!");
608 }
609 
610 void ASTStmtReader::VisitObjCIsaExpr(ObjCIsaExpr *E) {
611   VisitExpr(E);
612   E->setBase(Reader.ReadSubExpr());
613   E->setIsaMemberLoc(ReadSourceLocation(Record, Idx));
614   E->setOpLoc(ReadSourceLocation(Record, Idx));
615   E->setArrow(Record[Idx++]);
616 }
617 
618 void ASTStmtReader::
619 VisitObjCIndirectCopyRestoreExpr(ObjCIndirectCopyRestoreExpr *E) {
620   VisitExpr(E);
621   E->Operand = Reader.ReadSubExpr();
622   E->setShouldCopy(Record[Idx++]);
623 }
624 
625 void ASTStmtReader::VisitObjCBridgedCastExpr(ObjCBridgedCastExpr *E) {
626   VisitExplicitCastExpr(E);
627   E->LParenLoc = ReadSourceLocation(Record, Idx);
628   E->BridgeKeywordLoc = ReadSourceLocation(Record, Idx);
629   E->Kind = Record[Idx++];
630 }
631 
632 void ASTStmtReader::VisitCastExpr(CastExpr *E) {
633   VisitExpr(E);
634   unsigned NumBaseSpecs = Record[Idx++];
635   assert(NumBaseSpecs == E->path_size());
636   E->setSubExpr(Reader.ReadSubExpr());
637   E->setCastKind((CastExpr::CastKind)Record[Idx++]);
638   CastExpr::path_iterator BaseI = E->path_begin();
639   while (NumBaseSpecs--) {
640     CXXBaseSpecifier *BaseSpec = new (Reader.getContext()) CXXBaseSpecifier;
641     *BaseSpec = Reader.ReadCXXBaseSpecifier(F, Record, Idx);
642     *BaseI++ = BaseSpec;
643   }
644 }
645 
646 void ASTStmtReader::VisitBinaryOperator(BinaryOperator *E) {
647   VisitExpr(E);
648   E->setLHS(Reader.ReadSubExpr());
649   E->setRHS(Reader.ReadSubExpr());
650   E->setOpcode((BinaryOperator::Opcode)Record[Idx++]);
651   E->setOperatorLoc(ReadSourceLocation(Record, Idx));
652   E->setFPContractable((bool)Record[Idx++]);
653 }
654 
655 void ASTStmtReader::VisitCompoundAssignOperator(CompoundAssignOperator *E) {
656   VisitBinaryOperator(E);
657   E->setComputationLHSType(Reader.readType(F, Record, Idx));
658   E->setComputationResultType(Reader.readType(F, Record, Idx));
659 }
660 
661 void ASTStmtReader::VisitConditionalOperator(ConditionalOperator *E) {
662   VisitExpr(E);
663   E->SubExprs[ConditionalOperator::COND] = Reader.ReadSubExpr();
664   E->SubExprs[ConditionalOperator::LHS] = Reader.ReadSubExpr();
665   E->SubExprs[ConditionalOperator::RHS] = Reader.ReadSubExpr();
666   E->QuestionLoc = ReadSourceLocation(Record, Idx);
667   E->ColonLoc = ReadSourceLocation(Record, Idx);
668 }
669 
670 void
671 ASTStmtReader::VisitBinaryConditionalOperator(BinaryConditionalOperator *E) {
672   VisitExpr(E);
673   E->OpaqueValue = cast<OpaqueValueExpr>(Reader.ReadSubExpr());
674   E->SubExprs[BinaryConditionalOperator::COMMON] = Reader.ReadSubExpr();
675   E->SubExprs[BinaryConditionalOperator::COND] = Reader.ReadSubExpr();
676   E->SubExprs[BinaryConditionalOperator::LHS] = Reader.ReadSubExpr();
677   E->SubExprs[BinaryConditionalOperator::RHS] = Reader.ReadSubExpr();
678   E->QuestionLoc = ReadSourceLocation(Record, Idx);
679   E->ColonLoc = ReadSourceLocation(Record, Idx);
680 }
681 
682 void ASTStmtReader::VisitImplicitCastExpr(ImplicitCastExpr *E) {
683   VisitCastExpr(E);
684 }
685 
686 void ASTStmtReader::VisitExplicitCastExpr(ExplicitCastExpr *E) {
687   VisitCastExpr(E);
688   E->setTypeInfoAsWritten(GetTypeSourceInfo(Record, Idx));
689 }
690 
691 void ASTStmtReader::VisitCStyleCastExpr(CStyleCastExpr *E) {
692   VisitExplicitCastExpr(E);
693   E->setLParenLoc(ReadSourceLocation(Record, Idx));
694   E->setRParenLoc(ReadSourceLocation(Record, Idx));
695 }
696 
697 void ASTStmtReader::VisitCompoundLiteralExpr(CompoundLiteralExpr *E) {
698   VisitExpr(E);
699   E->setLParenLoc(ReadSourceLocation(Record, Idx));
700   E->setTypeSourceInfo(GetTypeSourceInfo(Record, Idx));
701   E->setInitializer(Reader.ReadSubExpr());
702   E->setFileScope(Record[Idx++]);
703 }
704 
705 void ASTStmtReader::VisitExtVectorElementExpr(ExtVectorElementExpr *E) {
706   VisitExpr(E);
707   E->setBase(Reader.ReadSubExpr());
708   E->setAccessor(Reader.GetIdentifierInfo(F, Record, Idx));
709   E->setAccessorLoc(ReadSourceLocation(Record, Idx));
710 }
711 
712 void ASTStmtReader::VisitInitListExpr(InitListExpr *E) {
713   VisitExpr(E);
714   if (InitListExpr *SyntForm = cast_or_null<InitListExpr>(Reader.ReadSubStmt()))
715     E->setSyntacticForm(SyntForm);
716   E->setLBraceLoc(ReadSourceLocation(Record, Idx));
717   E->setRBraceLoc(ReadSourceLocation(Record, Idx));
718   bool isArrayFiller = Record[Idx++];
719   Expr *filler = 0;
720   if (isArrayFiller) {
721     filler = Reader.ReadSubExpr();
722     E->ArrayFillerOrUnionFieldInit = filler;
723   } else
724     E->ArrayFillerOrUnionFieldInit = ReadDeclAs<FieldDecl>(Record, Idx);
725   E->sawArrayRangeDesignator(Record[Idx++]);
726   unsigned NumInits = Record[Idx++];
727   E->reserveInits(Reader.getContext(), NumInits);
728   if (isArrayFiller) {
729     for (unsigned I = 0; I != NumInits; ++I) {
730       Expr *init = Reader.ReadSubExpr();
731       E->updateInit(Reader.getContext(), I, init ? init : filler);
732     }
733   } else {
734     for (unsigned I = 0; I != NumInits; ++I)
735       E->updateInit(Reader.getContext(), I, Reader.ReadSubExpr());
736   }
737 }
738 
739 void ASTStmtReader::VisitDesignatedInitExpr(DesignatedInitExpr *E) {
740   typedef DesignatedInitExpr::Designator Designator;
741 
742   VisitExpr(E);
743   unsigned NumSubExprs = Record[Idx++];
744   assert(NumSubExprs == E->getNumSubExprs() && "Wrong number of subexprs");
745   for (unsigned I = 0; I != NumSubExprs; ++I)
746     E->setSubExpr(I, Reader.ReadSubExpr());
747   E->setEqualOrColonLoc(ReadSourceLocation(Record, Idx));
748   E->setGNUSyntax(Record[Idx++]);
749 
750   SmallVector<Designator, 4> Designators;
751   while (Idx < Record.size()) {
752     switch ((DesignatorTypes)Record[Idx++]) {
753     case DESIG_FIELD_DECL: {
754       FieldDecl *Field = ReadDeclAs<FieldDecl>(Record, Idx);
755       SourceLocation DotLoc
756         = ReadSourceLocation(Record, Idx);
757       SourceLocation FieldLoc
758         = ReadSourceLocation(Record, Idx);
759       Designators.push_back(Designator(Field->getIdentifier(), DotLoc,
760                                        FieldLoc));
761       Designators.back().setField(Field);
762       break;
763     }
764 
765     case DESIG_FIELD_NAME: {
766       const IdentifierInfo *Name = Reader.GetIdentifierInfo(F, Record, Idx);
767       SourceLocation DotLoc
768         = ReadSourceLocation(Record, Idx);
769       SourceLocation FieldLoc
770         = ReadSourceLocation(Record, Idx);
771       Designators.push_back(Designator(Name, DotLoc, FieldLoc));
772       break;
773     }
774 
775     case DESIG_ARRAY: {
776       unsigned Index = Record[Idx++];
777       SourceLocation LBracketLoc
778         = ReadSourceLocation(Record, Idx);
779       SourceLocation RBracketLoc
780         = ReadSourceLocation(Record, Idx);
781       Designators.push_back(Designator(Index, LBracketLoc, RBracketLoc));
782       break;
783     }
784 
785     case DESIG_ARRAY_RANGE: {
786       unsigned Index = Record[Idx++];
787       SourceLocation LBracketLoc
788         = ReadSourceLocation(Record, Idx);
789       SourceLocation EllipsisLoc
790         = ReadSourceLocation(Record, Idx);
791       SourceLocation RBracketLoc
792         = ReadSourceLocation(Record, Idx);
793       Designators.push_back(Designator(Index, LBracketLoc, EllipsisLoc,
794                                        RBracketLoc));
795       break;
796     }
797     }
798   }
799   E->setDesignators(Reader.getContext(),
800                     Designators.data(), Designators.size());
801 }
802 
803 void ASTStmtReader::VisitImplicitValueInitExpr(ImplicitValueInitExpr *E) {
804   VisitExpr(E);
805 }
806 
807 void ASTStmtReader::VisitVAArgExpr(VAArgExpr *E) {
808   VisitExpr(E);
809   E->setSubExpr(Reader.ReadSubExpr());
810   E->setWrittenTypeInfo(GetTypeSourceInfo(Record, Idx));
811   E->setBuiltinLoc(ReadSourceLocation(Record, Idx));
812   E->setRParenLoc(ReadSourceLocation(Record, Idx));
813 }
814 
815 void ASTStmtReader::VisitAddrLabelExpr(AddrLabelExpr *E) {
816   VisitExpr(E);
817   E->setAmpAmpLoc(ReadSourceLocation(Record, Idx));
818   E->setLabelLoc(ReadSourceLocation(Record, Idx));
819   E->setLabel(ReadDeclAs<LabelDecl>(Record, Idx));
820 }
821 
822 void ASTStmtReader::VisitStmtExpr(StmtExpr *E) {
823   VisitExpr(E);
824   E->setLParenLoc(ReadSourceLocation(Record, Idx));
825   E->setRParenLoc(ReadSourceLocation(Record, Idx));
826   E->setSubStmt(cast_or_null<CompoundStmt>(Reader.ReadSubStmt()));
827 }
828 
829 void ASTStmtReader::VisitChooseExpr(ChooseExpr *E) {
830   VisitExpr(E);
831   E->setCond(Reader.ReadSubExpr());
832   E->setLHS(Reader.ReadSubExpr());
833   E->setRHS(Reader.ReadSubExpr());
834   E->setBuiltinLoc(ReadSourceLocation(Record, Idx));
835   E->setRParenLoc(ReadSourceLocation(Record, Idx));
836 }
837 
838 void ASTStmtReader::VisitGNUNullExpr(GNUNullExpr *E) {
839   VisitExpr(E);
840   E->setTokenLocation(ReadSourceLocation(Record, Idx));
841 }
842 
843 void ASTStmtReader::VisitShuffleVectorExpr(ShuffleVectorExpr *E) {
844   VisitExpr(E);
845   SmallVector<Expr *, 16> Exprs;
846   unsigned NumExprs = Record[Idx++];
847   while (NumExprs--)
848     Exprs.push_back(Reader.ReadSubExpr());
849   E->setExprs(Reader.getContext(), Exprs);
850   E->setBuiltinLoc(ReadSourceLocation(Record, Idx));
851   E->setRParenLoc(ReadSourceLocation(Record, Idx));
852 }
853 
854 void ASTStmtReader::VisitBlockExpr(BlockExpr *E) {
855   VisitExpr(E);
856   E->setBlockDecl(ReadDeclAs<BlockDecl>(Record, Idx));
857 }
858 
859 void ASTStmtReader::VisitGenericSelectionExpr(GenericSelectionExpr *E) {
860   VisitExpr(E);
861   E->NumAssocs = Record[Idx++];
862   E->AssocTypes = new (Reader.getContext()) TypeSourceInfo*[E->NumAssocs];
863   E->SubExprs =
864    new(Reader.getContext()) Stmt*[GenericSelectionExpr::END_EXPR+E->NumAssocs];
865 
866   E->SubExprs[GenericSelectionExpr::CONTROLLING] = Reader.ReadSubExpr();
867   for (unsigned I = 0, N = E->getNumAssocs(); I != N; ++I) {
868     E->AssocTypes[I] = GetTypeSourceInfo(Record, Idx);
869     E->SubExprs[GenericSelectionExpr::END_EXPR+I] = Reader.ReadSubExpr();
870   }
871   E->ResultIndex = Record[Idx++];
872 
873   E->GenericLoc = ReadSourceLocation(Record, Idx);
874   E->DefaultLoc = ReadSourceLocation(Record, Idx);
875   E->RParenLoc = ReadSourceLocation(Record, Idx);
876 }
877 
878 void ASTStmtReader::VisitPseudoObjectExpr(PseudoObjectExpr *E) {
879   VisitExpr(E);
880   unsigned numSemanticExprs = Record[Idx++];
881   assert(numSemanticExprs + 1 == E->PseudoObjectExprBits.NumSubExprs);
882   E->PseudoObjectExprBits.ResultIndex = Record[Idx++];
883 
884   // Read the syntactic expression.
885   E->getSubExprsBuffer()[0] = Reader.ReadSubExpr();
886 
887   // Read all the semantic expressions.
888   for (unsigned i = 0; i != numSemanticExprs; ++i) {
889     Expr *subExpr = Reader.ReadSubExpr();
890     E->getSubExprsBuffer()[i+1] = subExpr;
891   }
892 }
893 
894 void ASTStmtReader::VisitAtomicExpr(AtomicExpr *E) {
895   VisitExpr(E);
896   E->Op = AtomicExpr::AtomicOp(Record[Idx++]);
897   E->NumSubExprs = AtomicExpr::getNumSubExprs(E->Op);
898   for (unsigned I = 0; I != E->NumSubExprs; ++I)
899     E->SubExprs[I] = Reader.ReadSubExpr();
900   E->BuiltinLoc = ReadSourceLocation(Record, Idx);
901   E->RParenLoc = ReadSourceLocation(Record, Idx);
902 }
903 
904 //===----------------------------------------------------------------------===//
905 // Objective-C Expressions and Statements
906 
907 void ASTStmtReader::VisitObjCStringLiteral(ObjCStringLiteral *E) {
908   VisitExpr(E);
909   E->setString(cast<StringLiteral>(Reader.ReadSubStmt()));
910   E->setAtLoc(ReadSourceLocation(Record, Idx));
911 }
912 
913 void ASTStmtReader::VisitObjCBoxedExpr(ObjCBoxedExpr *E) {
914   VisitExpr(E);
915   // could be one of several IntegerLiteral, FloatLiteral, etc.
916   E->SubExpr = Reader.ReadSubStmt();
917   E->BoxingMethod = ReadDeclAs<ObjCMethodDecl>(Record, Idx);
918   E->Range = ReadSourceRange(Record, Idx);
919 }
920 
921 void ASTStmtReader::VisitObjCArrayLiteral(ObjCArrayLiteral *E) {
922   VisitExpr(E);
923   unsigned NumElements = Record[Idx++];
924   assert(NumElements == E->getNumElements() && "Wrong number of elements");
925   Expr **Elements = E->getElements();
926   for (unsigned I = 0, N = NumElements; I != N; ++I)
927     Elements[I] = Reader.ReadSubExpr();
928   E->ArrayWithObjectsMethod = ReadDeclAs<ObjCMethodDecl>(Record, Idx);
929   E->Range = ReadSourceRange(Record, Idx);
930 }
931 
932 void ASTStmtReader::VisitObjCDictionaryLiteral(ObjCDictionaryLiteral *E) {
933   VisitExpr(E);
934   unsigned NumElements = Record[Idx++];
935   assert(NumElements == E->getNumElements() && "Wrong number of elements");
936   bool HasPackExpansions = Record[Idx++];
937   assert(HasPackExpansions == E->HasPackExpansions &&"Pack expansion mismatch");
938   ObjCDictionaryLiteral::KeyValuePair *KeyValues = E->getKeyValues();
939   ObjCDictionaryLiteral::ExpansionData *Expansions = E->getExpansionData();
940   for (unsigned I = 0; I != NumElements; ++I) {
941     KeyValues[I].Key = Reader.ReadSubExpr();
942     KeyValues[I].Value = Reader.ReadSubExpr();
943     if (HasPackExpansions) {
944       Expansions[I].EllipsisLoc = ReadSourceLocation(Record, Idx);
945       Expansions[I].NumExpansionsPlusOne = Record[Idx++];
946     }
947   }
948   E->DictWithObjectsMethod = ReadDeclAs<ObjCMethodDecl>(Record, Idx);
949   E->Range = ReadSourceRange(Record, Idx);
950 }
951 
952 void ASTStmtReader::VisitObjCEncodeExpr(ObjCEncodeExpr *E) {
953   VisitExpr(E);
954   E->setEncodedTypeSourceInfo(GetTypeSourceInfo(Record, Idx));
955   E->setAtLoc(ReadSourceLocation(Record, Idx));
956   E->setRParenLoc(ReadSourceLocation(Record, Idx));
957 }
958 
959 void ASTStmtReader::VisitObjCSelectorExpr(ObjCSelectorExpr *E) {
960   VisitExpr(E);
961   E->setSelector(Reader.ReadSelector(F, Record, Idx));
962   E->setAtLoc(ReadSourceLocation(Record, Idx));
963   E->setRParenLoc(ReadSourceLocation(Record, Idx));
964 }
965 
966 void ASTStmtReader::VisitObjCProtocolExpr(ObjCProtocolExpr *E) {
967   VisitExpr(E);
968   E->setProtocol(ReadDeclAs<ObjCProtocolDecl>(Record, Idx));
969   E->setAtLoc(ReadSourceLocation(Record, Idx));
970   E->ProtoLoc = ReadSourceLocation(Record, Idx);
971   E->setRParenLoc(ReadSourceLocation(Record, Idx));
972 }
973 
974 void ASTStmtReader::VisitObjCIvarRefExpr(ObjCIvarRefExpr *E) {
975   VisitExpr(E);
976   E->setDecl(ReadDeclAs<ObjCIvarDecl>(Record, Idx));
977   E->setLocation(ReadSourceLocation(Record, Idx));
978   E->setOpLoc(ReadSourceLocation(Record, Idx));
979   E->setBase(Reader.ReadSubExpr());
980   E->setIsArrow(Record[Idx++]);
981   E->setIsFreeIvar(Record[Idx++]);
982 }
983 
984 void ASTStmtReader::VisitObjCPropertyRefExpr(ObjCPropertyRefExpr *E) {
985   VisitExpr(E);
986   unsigned MethodRefFlags = Record[Idx++];
987   bool Implicit = Record[Idx++] != 0;
988   if (Implicit) {
989     ObjCMethodDecl *Getter = ReadDeclAs<ObjCMethodDecl>(Record, Idx);
990     ObjCMethodDecl *Setter = ReadDeclAs<ObjCMethodDecl>(Record, Idx);
991     E->setImplicitProperty(Getter, Setter, MethodRefFlags);
992   } else {
993     E->setExplicitProperty(ReadDeclAs<ObjCPropertyDecl>(Record, Idx),
994                            MethodRefFlags);
995   }
996   E->setLocation(ReadSourceLocation(Record, Idx));
997   E->setReceiverLocation(ReadSourceLocation(Record, Idx));
998   switch (Record[Idx++]) {
999   case 0:
1000     E->setBase(Reader.ReadSubExpr());
1001     break;
1002   case 1:
1003     E->setSuperReceiver(Reader.readType(F, Record, Idx));
1004     break;
1005   case 2:
1006     E->setClassReceiver(ReadDeclAs<ObjCInterfaceDecl>(Record, Idx));
1007     break;
1008   }
1009 }
1010 
1011 void ASTStmtReader::VisitObjCSubscriptRefExpr(ObjCSubscriptRefExpr *E) {
1012   VisitExpr(E);
1013   E->setRBracket(ReadSourceLocation(Record, Idx));
1014   E->setBaseExpr(Reader.ReadSubExpr());
1015   E->setKeyExpr(Reader.ReadSubExpr());
1016   E->GetAtIndexMethodDecl = ReadDeclAs<ObjCMethodDecl>(Record, Idx);
1017   E->SetAtIndexMethodDecl = ReadDeclAs<ObjCMethodDecl>(Record, Idx);
1018 }
1019 
1020 void ASTStmtReader::VisitObjCMessageExpr(ObjCMessageExpr *E) {
1021   VisitExpr(E);
1022   assert(Record[Idx] == E->getNumArgs());
1023   ++Idx;
1024   unsigned NumStoredSelLocs = Record[Idx++];
1025   E->SelLocsKind = Record[Idx++];
1026   E->setDelegateInitCall(Record[Idx++]);
1027   E->IsImplicit = Record[Idx++];
1028   ObjCMessageExpr::ReceiverKind Kind
1029     = static_cast<ObjCMessageExpr::ReceiverKind>(Record[Idx++]);
1030   switch (Kind) {
1031   case ObjCMessageExpr::Instance:
1032     E->setInstanceReceiver(Reader.ReadSubExpr());
1033     break;
1034 
1035   case ObjCMessageExpr::Class:
1036     E->setClassReceiver(GetTypeSourceInfo(Record, Idx));
1037     break;
1038 
1039   case ObjCMessageExpr::SuperClass:
1040   case ObjCMessageExpr::SuperInstance: {
1041     QualType T = Reader.readType(F, Record, Idx);
1042     SourceLocation SuperLoc = ReadSourceLocation(Record, Idx);
1043     E->setSuper(SuperLoc, T, Kind == ObjCMessageExpr::SuperInstance);
1044     break;
1045   }
1046   }
1047 
1048   assert(Kind == E->getReceiverKind());
1049 
1050   if (Record[Idx++])
1051     E->setMethodDecl(ReadDeclAs<ObjCMethodDecl>(Record, Idx));
1052   else
1053     E->setSelector(Reader.ReadSelector(F, Record, Idx));
1054 
1055   E->LBracLoc = ReadSourceLocation(Record, Idx);
1056   E->RBracLoc = ReadSourceLocation(Record, Idx);
1057 
1058   for (unsigned I = 0, N = E->getNumArgs(); I != N; ++I)
1059     E->setArg(I, Reader.ReadSubExpr());
1060 
1061   SourceLocation *Locs = E->getStoredSelLocs();
1062   for (unsigned I = 0; I != NumStoredSelLocs; ++I)
1063     Locs[I] = ReadSourceLocation(Record, Idx);
1064 }
1065 
1066 void ASTStmtReader::VisitObjCForCollectionStmt(ObjCForCollectionStmt *S) {
1067   VisitStmt(S);
1068   S->setElement(Reader.ReadSubStmt());
1069   S->setCollection(Reader.ReadSubExpr());
1070   S->setBody(Reader.ReadSubStmt());
1071   S->setForLoc(ReadSourceLocation(Record, Idx));
1072   S->setRParenLoc(ReadSourceLocation(Record, Idx));
1073 }
1074 
1075 void ASTStmtReader::VisitObjCAtCatchStmt(ObjCAtCatchStmt *S) {
1076   VisitStmt(S);
1077   S->setCatchBody(Reader.ReadSubStmt());
1078   S->setCatchParamDecl(ReadDeclAs<VarDecl>(Record, Idx));
1079   S->setAtCatchLoc(ReadSourceLocation(Record, Idx));
1080   S->setRParenLoc(ReadSourceLocation(Record, Idx));
1081 }
1082 
1083 void ASTStmtReader::VisitObjCAtFinallyStmt(ObjCAtFinallyStmt *S) {
1084   VisitStmt(S);
1085   S->setFinallyBody(Reader.ReadSubStmt());
1086   S->setAtFinallyLoc(ReadSourceLocation(Record, Idx));
1087 }
1088 
1089 void ASTStmtReader::VisitObjCAutoreleasePoolStmt(ObjCAutoreleasePoolStmt *S) {
1090   VisitStmt(S);
1091   S->setSubStmt(Reader.ReadSubStmt());
1092   S->setAtLoc(ReadSourceLocation(Record, Idx));
1093 }
1094 
1095 void ASTStmtReader::VisitObjCAtTryStmt(ObjCAtTryStmt *S) {
1096   VisitStmt(S);
1097   assert(Record[Idx] == S->getNumCatchStmts());
1098   ++Idx;
1099   bool HasFinally = Record[Idx++];
1100   S->setTryBody(Reader.ReadSubStmt());
1101   for (unsigned I = 0, N = S->getNumCatchStmts(); I != N; ++I)
1102     S->setCatchStmt(I, cast_or_null<ObjCAtCatchStmt>(Reader.ReadSubStmt()));
1103 
1104   if (HasFinally)
1105     S->setFinallyStmt(Reader.ReadSubStmt());
1106   S->setAtTryLoc(ReadSourceLocation(Record, Idx));
1107 }
1108 
1109 void ASTStmtReader::VisitObjCAtSynchronizedStmt(ObjCAtSynchronizedStmt *S) {
1110   VisitStmt(S);
1111   S->setSynchExpr(Reader.ReadSubStmt());
1112   S->setSynchBody(Reader.ReadSubStmt());
1113   S->setAtSynchronizedLoc(ReadSourceLocation(Record, Idx));
1114 }
1115 
1116 void ASTStmtReader::VisitObjCAtThrowStmt(ObjCAtThrowStmt *S) {
1117   VisitStmt(S);
1118   S->setThrowExpr(Reader.ReadSubStmt());
1119   S->setThrowLoc(ReadSourceLocation(Record, Idx));
1120 }
1121 
1122 void ASTStmtReader::VisitObjCBoolLiteralExpr(ObjCBoolLiteralExpr *E) {
1123   VisitExpr(E);
1124   E->setValue(Record[Idx++]);
1125   E->setLocation(ReadSourceLocation(Record, Idx));
1126 }
1127 
1128 //===----------------------------------------------------------------------===//
1129 // C++ Expressions and Statements
1130 //===----------------------------------------------------------------------===//
1131 
1132 void ASTStmtReader::VisitCXXCatchStmt(CXXCatchStmt *S) {
1133   VisitStmt(S);
1134   S->CatchLoc = ReadSourceLocation(Record, Idx);
1135   S->ExceptionDecl = ReadDeclAs<VarDecl>(Record, Idx);
1136   S->HandlerBlock = Reader.ReadSubStmt();
1137 }
1138 
1139 void ASTStmtReader::VisitCXXTryStmt(CXXTryStmt *S) {
1140   VisitStmt(S);
1141   assert(Record[Idx] == S->getNumHandlers() && "NumStmtFields is wrong ?");
1142   ++Idx;
1143   S->TryLoc = ReadSourceLocation(Record, Idx);
1144   S->getStmts()[0] = Reader.ReadSubStmt();
1145   for (unsigned i = 0, e = S->getNumHandlers(); i != e; ++i)
1146     S->getStmts()[i + 1] = Reader.ReadSubStmt();
1147 }
1148 
1149 void ASTStmtReader::VisitCXXForRangeStmt(CXXForRangeStmt *S) {
1150   VisitStmt(S);
1151   S->setForLoc(ReadSourceLocation(Record, Idx));
1152   S->setColonLoc(ReadSourceLocation(Record, Idx));
1153   S->setRParenLoc(ReadSourceLocation(Record, Idx));
1154   S->setRangeStmt(Reader.ReadSubStmt());
1155   S->setBeginEndStmt(Reader.ReadSubStmt());
1156   S->setCond(Reader.ReadSubExpr());
1157   S->setInc(Reader.ReadSubExpr());
1158   S->setLoopVarStmt(Reader.ReadSubStmt());
1159   S->setBody(Reader.ReadSubStmt());
1160 }
1161 
1162 void ASTStmtReader::VisitMSDependentExistsStmt(MSDependentExistsStmt *S) {
1163   VisitStmt(S);
1164   S->KeywordLoc = ReadSourceLocation(Record, Idx);
1165   S->IsIfExists = Record[Idx++];
1166   S->QualifierLoc = Reader.ReadNestedNameSpecifierLoc(F, Record, Idx);
1167   ReadDeclarationNameInfo(S->NameInfo, Record, Idx);
1168   S->SubStmt = Reader.ReadSubStmt();
1169 }
1170 
1171 void ASTStmtReader::VisitCXXOperatorCallExpr(CXXOperatorCallExpr *E) {
1172   VisitCallExpr(E);
1173   E->Operator = (OverloadedOperatorKind)Record[Idx++];
1174   E->Range = Reader.ReadSourceRange(F, Record, Idx);
1175   E->setFPContractable((bool)Record[Idx++]);
1176 }
1177 
1178 void ASTStmtReader::VisitCXXConstructExpr(CXXConstructExpr *E) {
1179   VisitExpr(E);
1180   E->NumArgs = Record[Idx++];
1181   if (E->NumArgs)
1182     E->Args = new (Reader.getContext()) Stmt*[E->NumArgs];
1183   for (unsigned I = 0, N = E->getNumArgs(); I != N; ++I)
1184     E->setArg(I, Reader.ReadSubExpr());
1185   E->setConstructor(ReadDeclAs<CXXConstructorDecl>(Record, Idx));
1186   E->setLocation(ReadSourceLocation(Record, Idx));
1187   E->setElidable(Record[Idx++]);
1188   E->setHadMultipleCandidates(Record[Idx++]);
1189   E->setListInitialization(Record[Idx++]);
1190   E->setRequiresZeroInitialization(Record[Idx++]);
1191   E->setConstructionKind((CXXConstructExpr::ConstructionKind)Record[Idx++]);
1192   E->ParenRange = ReadSourceRange(Record, Idx);
1193 }
1194 
1195 void ASTStmtReader::VisitCXXTemporaryObjectExpr(CXXTemporaryObjectExpr *E) {
1196   VisitCXXConstructExpr(E);
1197   E->Type = GetTypeSourceInfo(Record, Idx);
1198 }
1199 
1200 void ASTStmtReader::VisitLambdaExpr(LambdaExpr *E) {
1201   VisitExpr(E);
1202   unsigned NumCaptures = Record[Idx++];
1203   assert(NumCaptures == E->NumCaptures);(void)NumCaptures;
1204   unsigned NumArrayIndexVars = Record[Idx++];
1205   E->IntroducerRange = ReadSourceRange(Record, Idx);
1206   E->CaptureDefault = static_cast<LambdaCaptureDefault>(Record[Idx++]);
1207   E->ExplicitParams = Record[Idx++];
1208   E->ExplicitResultType = Record[Idx++];
1209   E->ClosingBrace = ReadSourceLocation(Record, Idx);
1210 
1211   // Read capture initializers.
1212   for (LambdaExpr::capture_init_iterator C = E->capture_init_begin(),
1213                                       CEnd = E->capture_init_end();
1214        C != CEnd; ++C)
1215     *C = Reader.ReadSubExpr();
1216 
1217   // Read array capture index variables.
1218   if (NumArrayIndexVars > 0) {
1219     unsigned *ArrayIndexStarts = E->getArrayIndexStarts();
1220     for (unsigned I = 0; I != NumCaptures + 1; ++I)
1221       ArrayIndexStarts[I] = Record[Idx++];
1222 
1223     VarDecl **ArrayIndexVars = E->getArrayIndexVars();
1224     for (unsigned I = 0; I != NumArrayIndexVars; ++I)
1225       ArrayIndexVars[I] = ReadDeclAs<VarDecl>(Record, Idx);
1226   }
1227 }
1228 
1229 void
1230 ASTStmtReader::VisitCXXStdInitializerListExpr(CXXStdInitializerListExpr *E) {
1231   VisitExpr(E);
1232   E->SubExpr = Reader.ReadSubExpr();
1233 }
1234 
1235 void ASTStmtReader::VisitCXXNamedCastExpr(CXXNamedCastExpr *E) {
1236   VisitExplicitCastExpr(E);
1237   SourceRange R = ReadSourceRange(Record, Idx);
1238   E->Loc = R.getBegin();
1239   E->RParenLoc = R.getEnd();
1240   R = ReadSourceRange(Record, Idx);
1241   E->AngleBrackets = R;
1242 }
1243 
1244 void ASTStmtReader::VisitCXXStaticCastExpr(CXXStaticCastExpr *E) {
1245   return VisitCXXNamedCastExpr(E);
1246 }
1247 
1248 void ASTStmtReader::VisitCXXDynamicCastExpr(CXXDynamicCastExpr *E) {
1249   return VisitCXXNamedCastExpr(E);
1250 }
1251 
1252 void ASTStmtReader::VisitCXXReinterpretCastExpr(CXXReinterpretCastExpr *E) {
1253   return VisitCXXNamedCastExpr(E);
1254 }
1255 
1256 void ASTStmtReader::VisitCXXConstCastExpr(CXXConstCastExpr *E) {
1257   return VisitCXXNamedCastExpr(E);
1258 }
1259 
1260 void ASTStmtReader::VisitCXXFunctionalCastExpr(CXXFunctionalCastExpr *E) {
1261   VisitExplicitCastExpr(E);
1262   E->setTypeBeginLoc(ReadSourceLocation(Record, Idx));
1263   E->setRParenLoc(ReadSourceLocation(Record, Idx));
1264 }
1265 
1266 void ASTStmtReader::VisitUserDefinedLiteral(UserDefinedLiteral *E) {
1267   VisitCallExpr(E);
1268   E->UDSuffixLoc = ReadSourceLocation(Record, Idx);
1269 }
1270 
1271 void ASTStmtReader::VisitCXXBoolLiteralExpr(CXXBoolLiteralExpr *E) {
1272   VisitExpr(E);
1273   E->setValue(Record[Idx++]);
1274   E->setLocation(ReadSourceLocation(Record, Idx));
1275 }
1276 
1277 void ASTStmtReader::VisitCXXNullPtrLiteralExpr(CXXNullPtrLiteralExpr *E) {
1278   VisitExpr(E);
1279   E->setLocation(ReadSourceLocation(Record, Idx));
1280 }
1281 
1282 void ASTStmtReader::VisitCXXTypeidExpr(CXXTypeidExpr *E) {
1283   VisitExpr(E);
1284   E->setSourceRange(ReadSourceRange(Record, Idx));
1285   if (E->isTypeOperand()) { // typeid(int)
1286     E->setTypeOperandSourceInfo(
1287         GetTypeSourceInfo(Record, Idx));
1288     return;
1289   }
1290 
1291   // typeid(42+2)
1292   E->setExprOperand(Reader.ReadSubExpr());
1293 }
1294 
1295 void ASTStmtReader::VisitCXXThisExpr(CXXThisExpr *E) {
1296   VisitExpr(E);
1297   E->setLocation(ReadSourceLocation(Record, Idx));
1298   E->setImplicit(Record[Idx++]);
1299 }
1300 
1301 void ASTStmtReader::VisitCXXThrowExpr(CXXThrowExpr *E) {
1302   VisitExpr(E);
1303   E->ThrowLoc = ReadSourceLocation(Record, Idx);
1304   E->Op = Reader.ReadSubExpr();
1305   E->IsThrownVariableInScope = Record[Idx++];
1306 }
1307 
1308 void ASTStmtReader::VisitCXXDefaultArgExpr(CXXDefaultArgExpr *E) {
1309   VisitExpr(E);
1310 
1311   assert((bool)Record[Idx] == E->Param.getInt() && "We messed up at creation ?");
1312   ++Idx; // HasOtherExprStored and SubExpr was handled during creation.
1313   E->Param.setPointer(ReadDeclAs<ParmVarDecl>(Record, Idx));
1314   E->Loc = ReadSourceLocation(Record, Idx);
1315 }
1316 
1317 void ASTStmtReader::VisitCXXDefaultInitExpr(CXXDefaultInitExpr *E) {
1318   VisitExpr(E);
1319   E->Field = ReadDeclAs<FieldDecl>(Record, Idx);
1320   E->Loc = ReadSourceLocation(Record, Idx);
1321 }
1322 
1323 void ASTStmtReader::VisitCXXBindTemporaryExpr(CXXBindTemporaryExpr *E) {
1324   VisitExpr(E);
1325   E->setTemporary(Reader.ReadCXXTemporary(F, Record, Idx));
1326   E->setSubExpr(Reader.ReadSubExpr());
1327 }
1328 
1329 void ASTStmtReader::VisitCXXScalarValueInitExpr(CXXScalarValueInitExpr *E) {
1330   VisitExpr(E);
1331   E->TypeInfo = GetTypeSourceInfo(Record, Idx);
1332   E->RParenLoc = ReadSourceLocation(Record, Idx);
1333 }
1334 
1335 void ASTStmtReader::VisitCXXNewExpr(CXXNewExpr *E) {
1336   VisitExpr(E);
1337   E->GlobalNew = Record[Idx++];
1338   bool isArray = Record[Idx++];
1339   E->UsualArrayDeleteWantsSize = Record[Idx++];
1340   unsigned NumPlacementArgs = Record[Idx++];
1341   E->StoredInitializationStyle = Record[Idx++];
1342   E->setOperatorNew(ReadDeclAs<FunctionDecl>(Record, Idx));
1343   E->setOperatorDelete(ReadDeclAs<FunctionDecl>(Record, Idx));
1344   E->AllocatedTypeInfo = GetTypeSourceInfo(Record, Idx);
1345   E->TypeIdParens = ReadSourceRange(Record, Idx);
1346   E->Range = ReadSourceRange(Record, Idx);
1347   E->DirectInitRange = ReadSourceRange(Record, Idx);
1348 
1349   E->AllocateArgsArray(Reader.getContext(), isArray, NumPlacementArgs,
1350                        E->StoredInitializationStyle != 0);
1351 
1352   // Install all the subexpressions.
1353   for (CXXNewExpr::raw_arg_iterator I = E->raw_arg_begin(),e = E->raw_arg_end();
1354        I != e; ++I)
1355     *I = Reader.ReadSubStmt();
1356 }
1357 
1358 void ASTStmtReader::VisitCXXDeleteExpr(CXXDeleteExpr *E) {
1359   VisitExpr(E);
1360   E->GlobalDelete = Record[Idx++];
1361   E->ArrayForm = Record[Idx++];
1362   E->ArrayFormAsWritten = Record[Idx++];
1363   E->UsualArrayDeleteWantsSize = Record[Idx++];
1364   E->OperatorDelete = ReadDeclAs<FunctionDecl>(Record, Idx);
1365   E->Argument = Reader.ReadSubExpr();
1366   E->Loc = ReadSourceLocation(Record, Idx);
1367 }
1368 
1369 void ASTStmtReader::VisitCXXPseudoDestructorExpr(CXXPseudoDestructorExpr *E) {
1370   VisitExpr(E);
1371 
1372   E->Base = Reader.ReadSubExpr();
1373   E->IsArrow = Record[Idx++];
1374   E->OperatorLoc = ReadSourceLocation(Record, Idx);
1375   E->QualifierLoc = Reader.ReadNestedNameSpecifierLoc(F, Record, Idx);
1376   E->ScopeType = GetTypeSourceInfo(Record, Idx);
1377   E->ColonColonLoc = ReadSourceLocation(Record, Idx);
1378   E->TildeLoc = ReadSourceLocation(Record, Idx);
1379 
1380   IdentifierInfo *II = Reader.GetIdentifierInfo(F, Record, Idx);
1381   if (II)
1382     E->setDestroyedType(II, ReadSourceLocation(Record, Idx));
1383   else
1384     E->setDestroyedType(GetTypeSourceInfo(Record, Idx));
1385 }
1386 
1387 void ASTStmtReader::VisitExprWithCleanups(ExprWithCleanups *E) {
1388   VisitExpr(E);
1389 
1390   unsigned NumObjects = Record[Idx++];
1391   assert(NumObjects == E->getNumObjects());
1392   for (unsigned i = 0; i != NumObjects; ++i)
1393     E->getObjectsBuffer()[i] = ReadDeclAs<BlockDecl>(Record, Idx);
1394 
1395   E->SubExpr = Reader.ReadSubExpr();
1396 }
1397 
1398 void
1399 ASTStmtReader::VisitCXXDependentScopeMemberExpr(CXXDependentScopeMemberExpr *E){
1400   VisitExpr(E);
1401 
1402   if (Record[Idx++]) // HasTemplateKWAndArgsInfo
1403     ReadTemplateKWAndArgsInfo(*E->getTemplateKWAndArgsInfo(),
1404                               /*NumTemplateArgs=*/Record[Idx++]);
1405 
1406   E->Base = Reader.ReadSubExpr();
1407   E->BaseType = Reader.readType(F, Record, Idx);
1408   E->IsArrow = Record[Idx++];
1409   E->OperatorLoc = ReadSourceLocation(Record, Idx);
1410   E->QualifierLoc = Reader.ReadNestedNameSpecifierLoc(F, Record, Idx);
1411   E->FirstQualifierFoundInScope = ReadDeclAs<NamedDecl>(Record, Idx);
1412   ReadDeclarationNameInfo(E->MemberNameInfo, Record, Idx);
1413 }
1414 
1415 void
1416 ASTStmtReader::VisitDependentScopeDeclRefExpr(DependentScopeDeclRefExpr *E) {
1417   VisitExpr(E);
1418 
1419   if (Record[Idx++]) // HasTemplateKWAndArgsInfo
1420     ReadTemplateKWAndArgsInfo(*E->getTemplateKWAndArgsInfo(),
1421                               /*NumTemplateArgs=*/Record[Idx++]);
1422 
1423   E->QualifierLoc = Reader.ReadNestedNameSpecifierLoc(F, Record, Idx);
1424   ReadDeclarationNameInfo(E->NameInfo, Record, Idx);
1425 }
1426 
1427 void
1428 ASTStmtReader::VisitCXXUnresolvedConstructExpr(CXXUnresolvedConstructExpr *E) {
1429   VisitExpr(E);
1430   assert(Record[Idx] == E->arg_size() && "Read wrong record during creation ?");
1431   ++Idx; // NumArgs;
1432   for (unsigned I = 0, N = E->arg_size(); I != N; ++I)
1433     E->setArg(I, Reader.ReadSubExpr());
1434   E->Type = GetTypeSourceInfo(Record, Idx);
1435   E->setLParenLoc(ReadSourceLocation(Record, Idx));
1436   E->setRParenLoc(ReadSourceLocation(Record, Idx));
1437 }
1438 
1439 void ASTStmtReader::VisitOverloadExpr(OverloadExpr *E) {
1440   VisitExpr(E);
1441 
1442   if (Record[Idx++]) // HasTemplateKWAndArgsInfo
1443     ReadTemplateKWAndArgsInfo(*E->getTemplateKWAndArgsInfo(),
1444                               /*NumTemplateArgs=*/Record[Idx++]);
1445 
1446   unsigned NumDecls = Record[Idx++];
1447   UnresolvedSet<8> Decls;
1448   for (unsigned i = 0; i != NumDecls; ++i) {
1449     NamedDecl *D = ReadDeclAs<NamedDecl>(Record, Idx);
1450     AccessSpecifier AS = (AccessSpecifier)Record[Idx++];
1451     Decls.addDecl(D, AS);
1452   }
1453   E->initializeResults(Reader.getContext(), Decls.begin(), Decls.end());
1454 
1455   ReadDeclarationNameInfo(E->NameInfo, Record, Idx);
1456   E->QualifierLoc = Reader.ReadNestedNameSpecifierLoc(F, Record, Idx);
1457 }
1458 
1459 void ASTStmtReader::VisitUnresolvedMemberExpr(UnresolvedMemberExpr *E) {
1460   VisitOverloadExpr(E);
1461   E->IsArrow = Record[Idx++];
1462   E->HasUnresolvedUsing = Record[Idx++];
1463   E->Base = Reader.ReadSubExpr();
1464   E->BaseType = Reader.readType(F, Record, Idx);
1465   E->OperatorLoc = ReadSourceLocation(Record, Idx);
1466 }
1467 
1468 void ASTStmtReader::VisitUnresolvedLookupExpr(UnresolvedLookupExpr *E) {
1469   VisitOverloadExpr(E);
1470   E->RequiresADL = Record[Idx++];
1471   E->Overloaded = Record[Idx++];
1472   E->NamingClass = ReadDeclAs<CXXRecordDecl>(Record, Idx);
1473 }
1474 
1475 void ASTStmtReader::VisitUnaryTypeTraitExpr(UnaryTypeTraitExpr *E) {
1476   VisitExpr(E);
1477   E->UTT = (UnaryTypeTrait)Record[Idx++];
1478   E->Value = (bool)Record[Idx++];
1479   SourceRange Range = ReadSourceRange(Record, Idx);
1480   E->Loc = Range.getBegin();
1481   E->RParen = Range.getEnd();
1482   E->QueriedType = GetTypeSourceInfo(Record, Idx);
1483 }
1484 
1485 void ASTStmtReader::VisitBinaryTypeTraitExpr(BinaryTypeTraitExpr *E) {
1486   VisitExpr(E);
1487   E->BTT = (BinaryTypeTrait)Record[Idx++];
1488   E->Value = (bool)Record[Idx++];
1489   SourceRange Range = ReadSourceRange(Record, Idx);
1490   E->Loc = Range.getBegin();
1491   E->RParen = Range.getEnd();
1492   E->LhsType = GetTypeSourceInfo(Record, Idx);
1493   E->RhsType = GetTypeSourceInfo(Record, Idx);
1494 }
1495 
1496 void ASTStmtReader::VisitTypeTraitExpr(TypeTraitExpr *E) {
1497   VisitExpr(E);
1498   E->TypeTraitExprBits.NumArgs = Record[Idx++];
1499   E->TypeTraitExprBits.Kind = Record[Idx++];
1500   E->TypeTraitExprBits.Value = Record[Idx++];
1501 
1502   TypeSourceInfo **Args = E->getTypeSourceInfos();
1503   for (unsigned I = 0, N = E->getNumArgs(); I != N; ++I)
1504     Args[I] = GetTypeSourceInfo(Record, Idx);
1505 }
1506 
1507 void ASTStmtReader::VisitArrayTypeTraitExpr(ArrayTypeTraitExpr *E) {
1508   VisitExpr(E);
1509   E->ATT = (ArrayTypeTrait)Record[Idx++];
1510   E->Value = (unsigned int)Record[Idx++];
1511   SourceRange Range = ReadSourceRange(Record, Idx);
1512   E->Loc = Range.getBegin();
1513   E->RParen = Range.getEnd();
1514   E->QueriedType = GetTypeSourceInfo(Record, Idx);
1515 }
1516 
1517 void ASTStmtReader::VisitExpressionTraitExpr(ExpressionTraitExpr *E) {
1518   VisitExpr(E);
1519   E->ET = (ExpressionTrait)Record[Idx++];
1520   E->Value = (bool)Record[Idx++];
1521   SourceRange Range = ReadSourceRange(Record, Idx);
1522   E->QueriedExpression = Reader.ReadSubExpr();
1523   E->Loc = Range.getBegin();
1524   E->RParen = Range.getEnd();
1525 }
1526 
1527 void ASTStmtReader::VisitCXXNoexceptExpr(CXXNoexceptExpr *E) {
1528   VisitExpr(E);
1529   E->Value = (bool)Record[Idx++];
1530   E->Range = ReadSourceRange(Record, Idx);
1531   E->Operand = Reader.ReadSubExpr();
1532 }
1533 
1534 void ASTStmtReader::VisitPackExpansionExpr(PackExpansionExpr *E) {
1535   VisitExpr(E);
1536   E->EllipsisLoc = ReadSourceLocation(Record, Idx);
1537   E->NumExpansions = Record[Idx++];
1538   E->Pattern = Reader.ReadSubExpr();
1539 }
1540 
1541 void ASTStmtReader::VisitSizeOfPackExpr(SizeOfPackExpr *E) {
1542   VisitExpr(E);
1543   E->OperatorLoc = ReadSourceLocation(Record, Idx);
1544   E->PackLoc = ReadSourceLocation(Record, Idx);
1545   E->RParenLoc = ReadSourceLocation(Record, Idx);
1546   E->Length = Record[Idx++];
1547   E->Pack = ReadDeclAs<NamedDecl>(Record, Idx);
1548 }
1549 
1550 void ASTStmtReader::VisitSubstNonTypeTemplateParmExpr(
1551                                               SubstNonTypeTemplateParmExpr *E) {
1552   VisitExpr(E);
1553   E->Param = ReadDeclAs<NonTypeTemplateParmDecl>(Record, Idx);
1554   E->NameLoc = ReadSourceLocation(Record, Idx);
1555   E->Replacement = Reader.ReadSubExpr();
1556 }
1557 
1558 void ASTStmtReader::VisitSubstNonTypeTemplateParmPackExpr(
1559                                           SubstNonTypeTemplateParmPackExpr *E) {
1560   VisitExpr(E);
1561   E->Param = ReadDeclAs<NonTypeTemplateParmDecl>(Record, Idx);
1562   TemplateArgument ArgPack = Reader.ReadTemplateArgument(F, Record, Idx);
1563   if (ArgPack.getKind() != TemplateArgument::Pack)
1564     return;
1565 
1566   E->Arguments = ArgPack.pack_begin();
1567   E->NumArguments = ArgPack.pack_size();
1568   E->NameLoc = ReadSourceLocation(Record, Idx);
1569 }
1570 
1571 void ASTStmtReader::VisitFunctionParmPackExpr(FunctionParmPackExpr *E) {
1572   VisitExpr(E);
1573   E->NumParameters = Record[Idx++];
1574   E->ParamPack = ReadDeclAs<ParmVarDecl>(Record, Idx);
1575   E->NameLoc = ReadSourceLocation(Record, Idx);
1576   ParmVarDecl **Parms = reinterpret_cast<ParmVarDecl**>(E+1);
1577   for (unsigned i = 0, n = E->NumParameters; i != n; ++i)
1578     Parms[i] = ReadDeclAs<ParmVarDecl>(Record, Idx);
1579 }
1580 
1581 void ASTStmtReader::VisitMaterializeTemporaryExpr(MaterializeTemporaryExpr *E) {
1582   VisitExpr(E);
1583   E->Temporary = Reader.ReadSubExpr();
1584   E->ExtendingDecl = ReadDeclAs<ValueDecl>(Record, Idx);
1585 }
1586 
1587 void ASTStmtReader::VisitOpaqueValueExpr(OpaqueValueExpr *E) {
1588   VisitExpr(E);
1589   E->SourceExpr = Reader.ReadSubExpr();
1590   E->Loc = ReadSourceLocation(Record, Idx);
1591 }
1592 
1593 //===----------------------------------------------------------------------===//
1594 // Microsoft Expressions and Statements
1595 //===----------------------------------------------------------------------===//
1596 void ASTStmtReader::VisitMSPropertyRefExpr(MSPropertyRefExpr *E) {
1597   VisitExpr(E);
1598   E->IsArrow = (Record[Idx++] != 0);
1599   E->BaseExpr = Reader.ReadSubExpr();
1600   E->QualifierLoc = Reader.ReadNestedNameSpecifierLoc(F, Record, Idx);
1601   E->MemberLoc = ReadSourceLocation(Record, Idx);
1602   E->TheDecl = ReadDeclAs<MSPropertyDecl>(Record, Idx);
1603 }
1604 
1605 void ASTStmtReader::VisitCXXUuidofExpr(CXXUuidofExpr *E) {
1606   VisitExpr(E);
1607   E->setSourceRange(ReadSourceRange(Record, Idx));
1608   if (E->isTypeOperand()) { // __uuidof(ComType)
1609     E->setTypeOperandSourceInfo(
1610         GetTypeSourceInfo(Record, Idx));
1611     return;
1612   }
1613 
1614   // __uuidof(expr)
1615   E->setExprOperand(Reader.ReadSubExpr());
1616 }
1617 
1618 void ASTStmtReader::VisitSEHExceptStmt(SEHExceptStmt *S) {
1619   VisitStmt(S);
1620   S->Loc = ReadSourceLocation(Record, Idx);
1621   S->Children[SEHExceptStmt::FILTER_EXPR] = Reader.ReadSubStmt();
1622   S->Children[SEHExceptStmt::BLOCK] = Reader.ReadSubStmt();
1623 }
1624 
1625 void ASTStmtReader::VisitSEHFinallyStmt(SEHFinallyStmt *S) {
1626   VisitStmt(S);
1627   S->Loc = ReadSourceLocation(Record, Idx);
1628   S->Block = Reader.ReadSubStmt();
1629 }
1630 
1631 void ASTStmtReader::VisitSEHTryStmt(SEHTryStmt *S) {
1632   VisitStmt(S);
1633   S->IsCXXTry = Record[Idx++];
1634   S->TryLoc = ReadSourceLocation(Record, Idx);
1635   S->Children[SEHTryStmt::TRY] = Reader.ReadSubStmt();
1636   S->Children[SEHTryStmt::HANDLER] = Reader.ReadSubStmt();
1637 }
1638 
1639 //===----------------------------------------------------------------------===//
1640 // CUDA Expressions and Statements
1641 //===----------------------------------------------------------------------===//
1642 
1643 void ASTStmtReader::VisitCUDAKernelCallExpr(CUDAKernelCallExpr *E) {
1644   VisitCallExpr(E);
1645   E->setConfig(cast<CallExpr>(Reader.ReadSubExpr()));
1646 }
1647 
1648 //===----------------------------------------------------------------------===//
1649 // OpenCL Expressions and Statements.
1650 //===----------------------------------------------------------------------===//
1651 void ASTStmtReader::VisitAsTypeExpr(AsTypeExpr *E) {
1652   VisitExpr(E);
1653   E->BuiltinLoc = ReadSourceLocation(Record, Idx);
1654   E->RParenLoc = ReadSourceLocation(Record, Idx);
1655   E->SrcExpr = Reader.ReadSubExpr();
1656 }
1657 
1658 //===----------------------------------------------------------------------===//
1659 // ASTReader Implementation
1660 //===----------------------------------------------------------------------===//
1661 
1662 Stmt *ASTReader::ReadStmt(ModuleFile &F) {
1663   switch (ReadingKind) {
1664   case Read_Decl:
1665   case Read_Type:
1666     return ReadStmtFromStream(F);
1667   case Read_Stmt:
1668     return ReadSubStmt();
1669   }
1670 
1671   llvm_unreachable("ReadingKind not set ?");
1672 }
1673 
1674 Expr *ASTReader::ReadExpr(ModuleFile &F) {
1675   return cast_or_null<Expr>(ReadStmt(F));
1676 }
1677 
1678 Expr *ASTReader::ReadSubExpr() {
1679   return cast_or_null<Expr>(ReadSubStmt());
1680 }
1681 
1682 // Within the bitstream, expressions are stored in Reverse Polish
1683 // Notation, with each of the subexpressions preceding the
1684 // expression they are stored in. Subexpressions are stored from last to first.
1685 // To evaluate expressions, we continue reading expressions and placing them on
1686 // the stack, with expressions having operands removing those operands from the
1687 // stack. Evaluation terminates when we see a STMT_STOP record, and
1688 // the single remaining expression on the stack is our result.
1689 Stmt *ASTReader::ReadStmtFromStream(ModuleFile &F) {
1690 
1691   ReadingKindTracker ReadingKind(Read_Stmt, *this);
1692   llvm::BitstreamCursor &Cursor = F.DeclsCursor;
1693 
1694   // Map of offset to previously deserialized stmt. The offset points
1695   /// just after the stmt record.
1696   llvm::DenseMap<uint64_t, Stmt *> StmtEntries;
1697 
1698 #ifndef NDEBUG
1699   unsigned PrevNumStmts = StmtStack.size();
1700 #endif
1701 
1702   RecordData Record;
1703   unsigned Idx;
1704   ASTStmtReader Reader(*this, F, Cursor, Record, Idx);
1705   Stmt::EmptyShell Empty;
1706 
1707   while (true) {
1708     llvm::BitstreamEntry Entry = Cursor.advanceSkippingSubblocks();
1709 
1710     switch (Entry.Kind) {
1711     case llvm::BitstreamEntry::SubBlock: // Handled for us already.
1712     case llvm::BitstreamEntry::Error:
1713       Error("malformed block record in AST file");
1714       return 0;
1715     case llvm::BitstreamEntry::EndBlock:
1716       goto Done;
1717     case llvm::BitstreamEntry::Record:
1718       // The interesting case.
1719       break;
1720     }
1721 
1722 
1723     Stmt *S = 0;
1724     Idx = 0;
1725     Record.clear();
1726     bool Finished = false;
1727     bool IsStmtReference = false;
1728     switch ((StmtCode)Cursor.readRecord(Entry.ID, Record)) {
1729     case STMT_STOP:
1730       Finished = true;
1731       break;
1732 
1733     case STMT_REF_PTR:
1734       IsStmtReference = true;
1735       assert(StmtEntries.find(Record[0]) != StmtEntries.end() &&
1736              "No stmt was recorded for this offset reference!");
1737       S = StmtEntries[Record[Idx++]];
1738       break;
1739 
1740     case STMT_NULL_PTR:
1741       S = 0;
1742       break;
1743 
1744     case STMT_NULL:
1745       S = new (Context) NullStmt(Empty);
1746       break;
1747 
1748     case STMT_COMPOUND:
1749       S = new (Context) CompoundStmt(Empty);
1750       break;
1751 
1752     case STMT_CASE:
1753       S = new (Context) CaseStmt(Empty);
1754       break;
1755 
1756     case STMT_DEFAULT:
1757       S = new (Context) DefaultStmt(Empty);
1758       break;
1759 
1760     case STMT_LABEL:
1761       S = new (Context) LabelStmt(Empty);
1762       break;
1763 
1764     case STMT_ATTRIBUTED:
1765       S = AttributedStmt::CreateEmpty(
1766         Context,
1767         /*NumAttrs*/Record[ASTStmtReader::NumStmtFields]);
1768       break;
1769 
1770     case STMT_IF:
1771       S = new (Context) IfStmt(Empty);
1772       break;
1773 
1774     case STMT_SWITCH:
1775       S = new (Context) SwitchStmt(Empty);
1776       break;
1777 
1778     case STMT_WHILE:
1779       S = new (Context) WhileStmt(Empty);
1780       break;
1781 
1782     case STMT_DO:
1783       S = new (Context) DoStmt(Empty);
1784       break;
1785 
1786     case STMT_FOR:
1787       S = new (Context) ForStmt(Empty);
1788       break;
1789 
1790     case STMT_GOTO:
1791       S = new (Context) GotoStmt(Empty);
1792       break;
1793 
1794     case STMT_INDIRECT_GOTO:
1795       S = new (Context) IndirectGotoStmt(Empty);
1796       break;
1797 
1798     case STMT_CONTINUE:
1799       S = new (Context) ContinueStmt(Empty);
1800       break;
1801 
1802     case STMT_BREAK:
1803       S = new (Context) BreakStmt(Empty);
1804       break;
1805 
1806     case STMT_RETURN:
1807       S = new (Context) ReturnStmt(Empty);
1808       break;
1809 
1810     case STMT_DECL:
1811       S = new (Context) DeclStmt(Empty);
1812       break;
1813 
1814     case STMT_GCCASM:
1815       S = new (Context) GCCAsmStmt(Empty);
1816       break;
1817 
1818     case STMT_MSASM:
1819       S = new (Context) MSAsmStmt(Empty);
1820       break;
1821 
1822     case STMT_CAPTURED:
1823       S = CapturedStmt::CreateDeserialized(Context,
1824                                            Record[ASTStmtReader::NumExprFields]);
1825       break;
1826 
1827     case EXPR_PREDEFINED:
1828       S = new (Context) PredefinedExpr(Empty);
1829       break;
1830 
1831     case EXPR_DECL_REF:
1832       S = DeclRefExpr::CreateEmpty(
1833         Context,
1834         /*HasQualifier=*/Record[ASTStmtReader::NumExprFields],
1835         /*HasFoundDecl=*/Record[ASTStmtReader::NumExprFields + 1],
1836         /*HasTemplateKWAndArgsInfo=*/Record[ASTStmtReader::NumExprFields + 2],
1837         /*NumTemplateArgs=*/Record[ASTStmtReader::NumExprFields + 2] ?
1838           Record[ASTStmtReader::NumExprFields + 5] : 0);
1839       break;
1840 
1841     case EXPR_INTEGER_LITERAL:
1842       S = IntegerLiteral::Create(Context, Empty);
1843       break;
1844 
1845     case EXPR_FLOATING_LITERAL:
1846       S = FloatingLiteral::Create(Context, Empty);
1847       break;
1848 
1849     case EXPR_IMAGINARY_LITERAL:
1850       S = new (Context) ImaginaryLiteral(Empty);
1851       break;
1852 
1853     case EXPR_STRING_LITERAL:
1854       S = StringLiteral::CreateEmpty(Context,
1855                                      Record[ASTStmtReader::NumExprFields + 1]);
1856       break;
1857 
1858     case EXPR_CHARACTER_LITERAL:
1859       S = new (Context) CharacterLiteral(Empty);
1860       break;
1861 
1862     case EXPR_PAREN:
1863       S = new (Context) ParenExpr(Empty);
1864       break;
1865 
1866     case EXPR_PAREN_LIST:
1867       S = new (Context) ParenListExpr(Empty);
1868       break;
1869 
1870     case EXPR_UNARY_OPERATOR:
1871       S = new (Context) UnaryOperator(Empty);
1872       break;
1873 
1874     case EXPR_OFFSETOF:
1875       S = OffsetOfExpr::CreateEmpty(Context,
1876                                     Record[ASTStmtReader::NumExprFields],
1877                                     Record[ASTStmtReader::NumExprFields + 1]);
1878       break;
1879 
1880     case EXPR_SIZEOF_ALIGN_OF:
1881       S = new (Context) UnaryExprOrTypeTraitExpr(Empty);
1882       break;
1883 
1884     case EXPR_ARRAY_SUBSCRIPT:
1885       S = new (Context) ArraySubscriptExpr(Empty);
1886       break;
1887 
1888     case EXPR_CALL:
1889       S = new (Context) CallExpr(Context, Stmt::CallExprClass, Empty);
1890       break;
1891 
1892     case EXPR_MEMBER: {
1893       // We load everything here and fully initialize it at creation.
1894       // That way we can use MemberExpr::Create and don't have to duplicate its
1895       // logic with a MemberExpr::CreateEmpty.
1896 
1897       assert(Idx == 0);
1898       NestedNameSpecifierLoc QualifierLoc;
1899       if (Record[Idx++]) { // HasQualifier.
1900         QualifierLoc = ReadNestedNameSpecifierLoc(F, Record, Idx);
1901       }
1902 
1903       SourceLocation TemplateKWLoc;
1904       TemplateArgumentListInfo ArgInfo;
1905       bool HasTemplateKWAndArgsInfo = Record[Idx++];
1906       if (HasTemplateKWAndArgsInfo) {
1907         TemplateKWLoc = ReadSourceLocation(F, Record, Idx);
1908         unsigned NumTemplateArgs = Record[Idx++];
1909         ArgInfo.setLAngleLoc(ReadSourceLocation(F, Record, Idx));
1910         ArgInfo.setRAngleLoc(ReadSourceLocation(F, Record, Idx));
1911         for (unsigned i = 0; i != NumTemplateArgs; ++i)
1912           ArgInfo.addArgument(ReadTemplateArgumentLoc(F, Record, Idx));
1913       }
1914 
1915       bool HadMultipleCandidates = Record[Idx++];
1916 
1917       NamedDecl *FoundD = ReadDeclAs<NamedDecl>(F, Record, Idx);
1918       AccessSpecifier AS = (AccessSpecifier)Record[Idx++];
1919       DeclAccessPair FoundDecl = DeclAccessPair::make(FoundD, AS);
1920 
1921       QualType T = readType(F, Record, Idx);
1922       ExprValueKind VK = static_cast<ExprValueKind>(Record[Idx++]);
1923       ExprObjectKind OK = static_cast<ExprObjectKind>(Record[Idx++]);
1924       Expr *Base = ReadSubExpr();
1925       ValueDecl *MemberD = ReadDeclAs<ValueDecl>(F, Record, Idx);
1926       SourceLocation MemberLoc = ReadSourceLocation(F, Record, Idx);
1927       DeclarationNameInfo MemberNameInfo(MemberD->getDeclName(), MemberLoc);
1928       bool IsArrow = Record[Idx++];
1929 
1930       S = MemberExpr::Create(Context, Base, IsArrow, QualifierLoc,
1931                              TemplateKWLoc, MemberD, FoundDecl, MemberNameInfo,
1932                              HasTemplateKWAndArgsInfo ? &ArgInfo : 0,
1933                              T, VK, OK);
1934       ReadDeclarationNameLoc(F, cast<MemberExpr>(S)->MemberDNLoc,
1935                              MemberD->getDeclName(), Record, Idx);
1936       if (HadMultipleCandidates)
1937         cast<MemberExpr>(S)->setHadMultipleCandidates(true);
1938       break;
1939     }
1940 
1941     case EXPR_BINARY_OPERATOR:
1942       S = new (Context) BinaryOperator(Empty);
1943       break;
1944 
1945     case EXPR_COMPOUND_ASSIGN_OPERATOR:
1946       S = new (Context) CompoundAssignOperator(Empty);
1947       break;
1948 
1949     case EXPR_CONDITIONAL_OPERATOR:
1950       S = new (Context) ConditionalOperator(Empty);
1951       break;
1952 
1953     case EXPR_BINARY_CONDITIONAL_OPERATOR:
1954       S = new (Context) BinaryConditionalOperator(Empty);
1955       break;
1956 
1957     case EXPR_IMPLICIT_CAST:
1958       S = ImplicitCastExpr::CreateEmpty(Context,
1959                        /*PathSize*/ Record[ASTStmtReader::NumExprFields]);
1960       break;
1961 
1962     case EXPR_CSTYLE_CAST:
1963       S = CStyleCastExpr::CreateEmpty(Context,
1964                        /*PathSize*/ Record[ASTStmtReader::NumExprFields]);
1965       break;
1966 
1967     case EXPR_COMPOUND_LITERAL:
1968       S = new (Context) CompoundLiteralExpr(Empty);
1969       break;
1970 
1971     case EXPR_EXT_VECTOR_ELEMENT:
1972       S = new (Context) ExtVectorElementExpr(Empty);
1973       break;
1974 
1975     case EXPR_INIT_LIST:
1976       S = new (Context) InitListExpr(Empty);
1977       break;
1978 
1979     case EXPR_DESIGNATED_INIT:
1980       S = DesignatedInitExpr::CreateEmpty(Context,
1981                                      Record[ASTStmtReader::NumExprFields] - 1);
1982 
1983       break;
1984 
1985     case EXPR_IMPLICIT_VALUE_INIT:
1986       S = new (Context) ImplicitValueInitExpr(Empty);
1987       break;
1988 
1989     case EXPR_VA_ARG:
1990       S = new (Context) VAArgExpr(Empty);
1991       break;
1992 
1993     case EXPR_ADDR_LABEL:
1994       S = new (Context) AddrLabelExpr(Empty);
1995       break;
1996 
1997     case EXPR_STMT:
1998       S = new (Context) StmtExpr(Empty);
1999       break;
2000 
2001     case EXPR_CHOOSE:
2002       S = new (Context) ChooseExpr(Empty);
2003       break;
2004 
2005     case EXPR_GNU_NULL:
2006       S = new (Context) GNUNullExpr(Empty);
2007       break;
2008 
2009     case EXPR_SHUFFLE_VECTOR:
2010       S = new (Context) ShuffleVectorExpr(Empty);
2011       break;
2012 
2013     case EXPR_BLOCK:
2014       S = new (Context) BlockExpr(Empty);
2015       break;
2016 
2017     case EXPR_GENERIC_SELECTION:
2018       S = new (Context) GenericSelectionExpr(Empty);
2019       break;
2020 
2021     case EXPR_OBJC_STRING_LITERAL:
2022       S = new (Context) ObjCStringLiteral(Empty);
2023       break;
2024     case EXPR_OBJC_BOXED_EXPRESSION:
2025       S = new (Context) ObjCBoxedExpr(Empty);
2026       break;
2027     case EXPR_OBJC_ARRAY_LITERAL:
2028       S = ObjCArrayLiteral::CreateEmpty(Context,
2029                                         Record[ASTStmtReader::NumExprFields]);
2030       break;
2031     case EXPR_OBJC_DICTIONARY_LITERAL:
2032       S = ObjCDictionaryLiteral::CreateEmpty(Context,
2033             Record[ASTStmtReader::NumExprFields],
2034             Record[ASTStmtReader::NumExprFields + 1]);
2035       break;
2036     case EXPR_OBJC_ENCODE:
2037       S = new (Context) ObjCEncodeExpr(Empty);
2038       break;
2039     case EXPR_OBJC_SELECTOR_EXPR:
2040       S = new (Context) ObjCSelectorExpr(Empty);
2041       break;
2042     case EXPR_OBJC_PROTOCOL_EXPR:
2043       S = new (Context) ObjCProtocolExpr(Empty);
2044       break;
2045     case EXPR_OBJC_IVAR_REF_EXPR:
2046       S = new (Context) ObjCIvarRefExpr(Empty);
2047       break;
2048     case EXPR_OBJC_PROPERTY_REF_EXPR:
2049       S = new (Context) ObjCPropertyRefExpr(Empty);
2050       break;
2051     case EXPR_OBJC_SUBSCRIPT_REF_EXPR:
2052       S = new (Context) ObjCSubscriptRefExpr(Empty);
2053       break;
2054     case EXPR_OBJC_KVC_REF_EXPR:
2055       llvm_unreachable("mismatching AST file");
2056     case EXPR_OBJC_MESSAGE_EXPR:
2057       S = ObjCMessageExpr::CreateEmpty(Context,
2058                                      Record[ASTStmtReader::NumExprFields],
2059                                      Record[ASTStmtReader::NumExprFields + 1]);
2060       break;
2061     case EXPR_OBJC_ISA:
2062       S = new (Context) ObjCIsaExpr(Empty);
2063       break;
2064     case EXPR_OBJC_INDIRECT_COPY_RESTORE:
2065       S = new (Context) ObjCIndirectCopyRestoreExpr(Empty);
2066       break;
2067     case EXPR_OBJC_BRIDGED_CAST:
2068       S = new (Context) ObjCBridgedCastExpr(Empty);
2069       break;
2070     case STMT_OBJC_FOR_COLLECTION:
2071       S = new (Context) ObjCForCollectionStmt(Empty);
2072       break;
2073     case STMT_OBJC_CATCH:
2074       S = new (Context) ObjCAtCatchStmt(Empty);
2075       break;
2076     case STMT_OBJC_FINALLY:
2077       S = new (Context) ObjCAtFinallyStmt(Empty);
2078       break;
2079     case STMT_OBJC_AT_TRY:
2080       S = ObjCAtTryStmt::CreateEmpty(Context,
2081                                      Record[ASTStmtReader::NumStmtFields],
2082                                      Record[ASTStmtReader::NumStmtFields + 1]);
2083       break;
2084     case STMT_OBJC_AT_SYNCHRONIZED:
2085       S = new (Context) ObjCAtSynchronizedStmt(Empty);
2086       break;
2087     case STMT_OBJC_AT_THROW:
2088       S = new (Context) ObjCAtThrowStmt(Empty);
2089       break;
2090     case STMT_OBJC_AUTORELEASE_POOL:
2091       S = new (Context) ObjCAutoreleasePoolStmt(Empty);
2092       break;
2093     case EXPR_OBJC_BOOL_LITERAL:
2094       S = new (Context) ObjCBoolLiteralExpr(Empty);
2095       break;
2096     case STMT_SEH_EXCEPT:
2097       S = new (Context) SEHExceptStmt(Empty);
2098       break;
2099     case STMT_SEH_FINALLY:
2100       S = new (Context) SEHFinallyStmt(Empty);
2101       break;
2102     case STMT_SEH_TRY:
2103       S = new (Context) SEHTryStmt(Empty);
2104       break;
2105     case STMT_CXX_CATCH:
2106       S = new (Context) CXXCatchStmt(Empty);
2107       break;
2108 
2109     case STMT_CXX_TRY:
2110       S = CXXTryStmt::Create(Context, Empty,
2111              /*NumHandlers=*/Record[ASTStmtReader::NumStmtFields]);
2112       break;
2113 
2114     case STMT_CXX_FOR_RANGE:
2115       S = new (Context) CXXForRangeStmt(Empty);
2116       break;
2117 
2118     case STMT_MS_DEPENDENT_EXISTS:
2119       S = new (Context) MSDependentExistsStmt(SourceLocation(), true,
2120                                               NestedNameSpecifierLoc(),
2121                                               DeclarationNameInfo(),
2122                                               0);
2123       break;
2124 
2125     case EXPR_CXX_OPERATOR_CALL:
2126       S = new (Context) CXXOperatorCallExpr(Context, Empty);
2127       break;
2128 
2129     case EXPR_CXX_MEMBER_CALL:
2130       S = new (Context) CXXMemberCallExpr(Context, Empty);
2131       break;
2132 
2133     case EXPR_CXX_CONSTRUCT:
2134       S = new (Context) CXXConstructExpr(Empty);
2135       break;
2136 
2137     case EXPR_CXX_TEMPORARY_OBJECT:
2138       S = new (Context) CXXTemporaryObjectExpr(Empty);
2139       break;
2140 
2141     case EXPR_CXX_STATIC_CAST:
2142       S = CXXStaticCastExpr::CreateEmpty(Context,
2143                        /*PathSize*/ Record[ASTStmtReader::NumExprFields]);
2144       break;
2145 
2146     case EXPR_CXX_DYNAMIC_CAST:
2147       S = CXXDynamicCastExpr::CreateEmpty(Context,
2148                        /*PathSize*/ Record[ASTStmtReader::NumExprFields]);
2149       break;
2150 
2151     case EXPR_CXX_REINTERPRET_CAST:
2152       S = CXXReinterpretCastExpr::CreateEmpty(Context,
2153                        /*PathSize*/ Record[ASTStmtReader::NumExprFields]);
2154       break;
2155 
2156     case EXPR_CXX_CONST_CAST:
2157       S = CXXConstCastExpr::CreateEmpty(Context);
2158       break;
2159 
2160     case EXPR_CXX_FUNCTIONAL_CAST:
2161       S = CXXFunctionalCastExpr::CreateEmpty(Context,
2162                        /*PathSize*/ Record[ASTStmtReader::NumExprFields]);
2163       break;
2164 
2165     case EXPR_USER_DEFINED_LITERAL:
2166       S = new (Context) UserDefinedLiteral(Context, Empty);
2167       break;
2168 
2169     case EXPR_CXX_STD_INITIALIZER_LIST:
2170       S = new (Context) CXXStdInitializerListExpr(Empty);
2171       break;
2172 
2173     case EXPR_CXX_BOOL_LITERAL:
2174       S = new (Context) CXXBoolLiteralExpr(Empty);
2175       break;
2176 
2177     case EXPR_CXX_NULL_PTR_LITERAL:
2178       S = new (Context) CXXNullPtrLiteralExpr(Empty);
2179       break;
2180     case EXPR_CXX_TYPEID_EXPR:
2181       S = new (Context) CXXTypeidExpr(Empty, true);
2182       break;
2183     case EXPR_CXX_TYPEID_TYPE:
2184       S = new (Context) CXXTypeidExpr(Empty, false);
2185       break;
2186     case EXPR_CXX_UUIDOF_EXPR:
2187       S = new (Context) CXXUuidofExpr(Empty, true);
2188       break;
2189     case EXPR_CXX_PROPERTY_REF_EXPR:
2190       S = new (Context) MSPropertyRefExpr(Empty);
2191       break;
2192     case EXPR_CXX_UUIDOF_TYPE:
2193       S = new (Context) CXXUuidofExpr(Empty, false);
2194       break;
2195     case EXPR_CXX_THIS:
2196       S = new (Context) CXXThisExpr(Empty);
2197       break;
2198     case EXPR_CXX_THROW:
2199       S = new (Context) CXXThrowExpr(Empty);
2200       break;
2201     case EXPR_CXX_DEFAULT_ARG: {
2202       bool HasOtherExprStored = Record[ASTStmtReader::NumExprFields];
2203       if (HasOtherExprStored) {
2204         Expr *SubExpr = ReadSubExpr();
2205         S = CXXDefaultArgExpr::Create(Context, SourceLocation(), 0, SubExpr);
2206       } else
2207         S = new (Context) CXXDefaultArgExpr(Empty);
2208       break;
2209     }
2210     case EXPR_CXX_DEFAULT_INIT:
2211       S = new (Context) CXXDefaultInitExpr(Empty);
2212       break;
2213     case EXPR_CXX_BIND_TEMPORARY:
2214       S = new (Context) CXXBindTemporaryExpr(Empty);
2215       break;
2216 
2217     case EXPR_CXX_SCALAR_VALUE_INIT:
2218       S = new (Context) CXXScalarValueInitExpr(Empty);
2219       break;
2220     case EXPR_CXX_NEW:
2221       S = new (Context) CXXNewExpr(Empty);
2222       break;
2223     case EXPR_CXX_DELETE:
2224       S = new (Context) CXXDeleteExpr(Empty);
2225       break;
2226     case EXPR_CXX_PSEUDO_DESTRUCTOR:
2227       S = new (Context) CXXPseudoDestructorExpr(Empty);
2228       break;
2229 
2230     case EXPR_EXPR_WITH_CLEANUPS:
2231       S = ExprWithCleanups::Create(Context, Empty,
2232                                    Record[ASTStmtReader::NumExprFields]);
2233       break;
2234 
2235     case EXPR_CXX_DEPENDENT_SCOPE_MEMBER:
2236       S = CXXDependentScopeMemberExpr::CreateEmpty(Context,
2237          /*HasTemplateKWAndArgsInfo=*/Record[ASTStmtReader::NumExprFields],
2238                   /*NumTemplateArgs=*/Record[ASTStmtReader::NumExprFields]
2239                                    ? Record[ASTStmtReader::NumExprFields + 1]
2240                                    : 0);
2241       break;
2242 
2243     case EXPR_CXX_DEPENDENT_SCOPE_DECL_REF:
2244       S = DependentScopeDeclRefExpr::CreateEmpty(Context,
2245          /*HasTemplateKWAndArgsInfo=*/Record[ASTStmtReader::NumExprFields],
2246                   /*NumTemplateArgs=*/Record[ASTStmtReader::NumExprFields]
2247                                    ? Record[ASTStmtReader::NumExprFields + 1]
2248                                    : 0);
2249       break;
2250 
2251     case EXPR_CXX_UNRESOLVED_CONSTRUCT:
2252       S = CXXUnresolvedConstructExpr::CreateEmpty(Context,
2253                               /*NumArgs=*/Record[ASTStmtReader::NumExprFields]);
2254       break;
2255 
2256     case EXPR_CXX_UNRESOLVED_MEMBER:
2257       S = UnresolvedMemberExpr::CreateEmpty(Context,
2258          /*HasTemplateKWAndArgsInfo=*/Record[ASTStmtReader::NumExprFields],
2259                   /*NumTemplateArgs=*/Record[ASTStmtReader::NumExprFields]
2260                                    ? Record[ASTStmtReader::NumExprFields + 1]
2261                                    : 0);
2262       break;
2263 
2264     case EXPR_CXX_UNRESOLVED_LOOKUP:
2265       S = UnresolvedLookupExpr::CreateEmpty(Context,
2266          /*HasTemplateKWAndArgsInfo=*/Record[ASTStmtReader::NumExprFields],
2267                   /*NumTemplateArgs=*/Record[ASTStmtReader::NumExprFields]
2268                                    ? Record[ASTStmtReader::NumExprFields + 1]
2269                                    : 0);
2270       break;
2271 
2272     case EXPR_CXX_UNARY_TYPE_TRAIT:
2273       S = new (Context) UnaryTypeTraitExpr(Empty);
2274       break;
2275 
2276     case EXPR_BINARY_TYPE_TRAIT:
2277       S = new (Context) BinaryTypeTraitExpr(Empty);
2278       break;
2279 
2280     case EXPR_TYPE_TRAIT:
2281       S = TypeTraitExpr::CreateDeserialized(Context,
2282             Record[ASTStmtReader::NumExprFields]);
2283       break;
2284 
2285     case EXPR_ARRAY_TYPE_TRAIT:
2286       S = new (Context) ArrayTypeTraitExpr(Empty);
2287       break;
2288 
2289     case EXPR_CXX_EXPRESSION_TRAIT:
2290       S = new (Context) ExpressionTraitExpr(Empty);
2291       break;
2292 
2293     case EXPR_CXX_NOEXCEPT:
2294       S = new (Context) CXXNoexceptExpr(Empty);
2295       break;
2296 
2297     case EXPR_PACK_EXPANSION:
2298       S = new (Context) PackExpansionExpr(Empty);
2299       break;
2300 
2301     case EXPR_SIZEOF_PACK:
2302       S = new (Context) SizeOfPackExpr(Empty);
2303       break;
2304 
2305     case EXPR_SUBST_NON_TYPE_TEMPLATE_PARM:
2306       S = new (Context) SubstNonTypeTemplateParmExpr(Empty);
2307       break;
2308 
2309     case EXPR_SUBST_NON_TYPE_TEMPLATE_PARM_PACK:
2310       S = new (Context) SubstNonTypeTemplateParmPackExpr(Empty);
2311       break;
2312 
2313     case EXPR_FUNCTION_PARM_PACK:
2314       S = FunctionParmPackExpr::CreateEmpty(Context,
2315                                           Record[ASTStmtReader::NumExprFields]);
2316       break;
2317 
2318     case EXPR_MATERIALIZE_TEMPORARY:
2319       S = new (Context) MaterializeTemporaryExpr(Empty);
2320       break;
2321 
2322     case EXPR_OPAQUE_VALUE:
2323       S = new (Context) OpaqueValueExpr(Empty);
2324       break;
2325 
2326     case EXPR_CUDA_KERNEL_CALL:
2327       S = new (Context) CUDAKernelCallExpr(Context, Empty);
2328       break;
2329 
2330     case EXPR_ASTYPE:
2331       S = new (Context) AsTypeExpr(Empty);
2332       break;
2333 
2334     case EXPR_PSEUDO_OBJECT: {
2335       unsigned numSemanticExprs = Record[ASTStmtReader::NumExprFields];
2336       S = PseudoObjectExpr::Create(Context, Empty, numSemanticExprs);
2337       break;
2338     }
2339 
2340     case EXPR_ATOMIC:
2341       S = new (Context) AtomicExpr(Empty);
2342       break;
2343 
2344     case EXPR_LAMBDA: {
2345       unsigned NumCaptures = Record[ASTStmtReader::NumExprFields];
2346       unsigned NumArrayIndexVars = Record[ASTStmtReader::NumExprFields + 1];
2347       S = LambdaExpr::CreateDeserialized(Context, NumCaptures,
2348                                          NumArrayIndexVars);
2349       break;
2350     }
2351     }
2352 
2353     // We hit a STMT_STOP, so we're done with this expression.
2354     if (Finished)
2355       break;
2356 
2357     ++NumStatementsRead;
2358 
2359     if (S && !IsStmtReference) {
2360       Reader.Visit(S);
2361       StmtEntries[Cursor.GetCurrentBitNo()] = S;
2362     }
2363 
2364 
2365     assert(Idx == Record.size() && "Invalid deserialization of statement");
2366     StmtStack.push_back(S);
2367   }
2368 Done:
2369   assert(StmtStack.size() > PrevNumStmts && "Read too many sub stmts!");
2370   assert(StmtStack.size() == PrevNumStmts + 1 && "Extra expressions on stack!");
2371   return StmtStack.pop_back_val();
2372 }
2373