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