1 //===--- ASTWriterStmt.cpp - Statement and Expression Serialization -------===//
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 /// \file
11 /// \brief Implements serialization for Statements and Expressions.
12 ///
13 //===----------------------------------------------------------------------===//
14 
15 #include "clang/Serialization/ASTWriter.h"
16 #include "clang/AST/ASTContext.h"
17 #include "clang/AST/DeclCXX.h"
18 #include "clang/AST/DeclObjC.h"
19 #include "clang/AST/DeclTemplate.h"
20 #include "clang/AST/StmtVisitor.h"
21 #include "clang/Lex/Token.h"
22 #include "llvm/Bitcode/BitstreamWriter.h"
23 using namespace clang;
24 
25 //===----------------------------------------------------------------------===//
26 // Statement/expression serialization
27 //===----------------------------------------------------------------------===//
28 
29 namespace clang {
30 
31   class ASTStmtWriter : public StmtVisitor<ASTStmtWriter, void> {
32     friend class OMPClauseWriter;
33     ASTWriter &Writer;
34     ASTWriter::RecordData &Record;
35 
36   public:
37     serialization::StmtCode Code;
38     unsigned AbbrevToUse;
39 
40     ASTStmtWriter(ASTWriter &Writer, ASTWriter::RecordData &Record)
41       : Writer(Writer), Record(Record) { }
42 
43     void AddTemplateKWAndArgsInfo(const ASTTemplateKWAndArgsInfo &Args);
44 
45     void VisitStmt(Stmt *S);
46 #define STMT(Type, Base) \
47     void Visit##Type(Type *);
48 #include "clang/AST/StmtNodes.inc"
49   };
50 }
51 
52 void ASTStmtWriter::
53 AddTemplateKWAndArgsInfo(const ASTTemplateKWAndArgsInfo &Args) {
54   Writer.AddSourceLocation(Args.getTemplateKeywordLoc(), Record);
55   Writer.AddSourceLocation(Args.LAngleLoc, Record);
56   Writer.AddSourceLocation(Args.RAngleLoc, Record);
57   for (unsigned i=0; i != Args.NumTemplateArgs; ++i)
58     Writer.AddTemplateArgumentLoc(Args.getTemplateArgs()[i], Record);
59 }
60 
61 void ASTStmtWriter::VisitStmt(Stmt *S) {
62 }
63 
64 void ASTStmtWriter::VisitNullStmt(NullStmt *S) {
65   VisitStmt(S);
66   Writer.AddSourceLocation(S->getSemiLoc(), Record);
67   Record.push_back(S->HasLeadingEmptyMacro);
68   Code = serialization::STMT_NULL;
69 }
70 
71 void ASTStmtWriter::VisitCompoundStmt(CompoundStmt *S) {
72   VisitStmt(S);
73   Record.push_back(S->size());
74   for (auto *CS : S->body())
75     Writer.AddStmt(CS);
76   Writer.AddSourceLocation(S->getLBracLoc(), Record);
77   Writer.AddSourceLocation(S->getRBracLoc(), Record);
78   Code = serialization::STMT_COMPOUND;
79 }
80 
81 void ASTStmtWriter::VisitSwitchCase(SwitchCase *S) {
82   VisitStmt(S);
83   Record.push_back(Writer.getSwitchCaseID(S));
84   Writer.AddSourceLocation(S->getKeywordLoc(), Record);
85   Writer.AddSourceLocation(S->getColonLoc(), Record);
86 }
87 
88 void ASTStmtWriter::VisitCaseStmt(CaseStmt *S) {
89   VisitSwitchCase(S);
90   Writer.AddStmt(S->getLHS());
91   Writer.AddStmt(S->getRHS());
92   Writer.AddStmt(S->getSubStmt());
93   Writer.AddSourceLocation(S->getEllipsisLoc(), Record);
94   Code = serialization::STMT_CASE;
95 }
96 
97 void ASTStmtWriter::VisitDefaultStmt(DefaultStmt *S) {
98   VisitSwitchCase(S);
99   Writer.AddStmt(S->getSubStmt());
100   Code = serialization::STMT_DEFAULT;
101 }
102 
103 void ASTStmtWriter::VisitLabelStmt(LabelStmt *S) {
104   VisitStmt(S);
105   Writer.AddDeclRef(S->getDecl(), Record);
106   Writer.AddStmt(S->getSubStmt());
107   Writer.AddSourceLocation(S->getIdentLoc(), Record);
108   Code = serialization::STMT_LABEL;
109 }
110 
111 void ASTStmtWriter::VisitAttributedStmt(AttributedStmt *S) {
112   VisitStmt(S);
113   Record.push_back(S->getAttrs().size());
114   Writer.WriteAttributes(S->getAttrs(), Record);
115   Writer.AddStmt(S->getSubStmt());
116   Writer.AddSourceLocation(S->getAttrLoc(), Record);
117   Code = serialization::STMT_ATTRIBUTED;
118 }
119 
120 void ASTStmtWriter::VisitIfStmt(IfStmt *S) {
121   VisitStmt(S);
122   Writer.AddDeclRef(S->getConditionVariable(), Record);
123   Writer.AddStmt(S->getCond());
124   Writer.AddStmt(S->getThen());
125   Writer.AddStmt(S->getElse());
126   Writer.AddSourceLocation(S->getIfLoc(), Record);
127   Writer.AddSourceLocation(S->getElseLoc(), Record);
128   Code = serialization::STMT_IF;
129 }
130 
131 void ASTStmtWriter::VisitSwitchStmt(SwitchStmt *S) {
132   VisitStmt(S);
133   Writer.AddDeclRef(S->getConditionVariable(), Record);
134   Writer.AddStmt(S->getCond());
135   Writer.AddStmt(S->getBody());
136   Writer.AddSourceLocation(S->getSwitchLoc(), Record);
137   Record.push_back(S->isAllEnumCasesCovered());
138   for (SwitchCase *SC = S->getSwitchCaseList(); SC;
139        SC = SC->getNextSwitchCase())
140     Record.push_back(Writer.RecordSwitchCaseID(SC));
141   Code = serialization::STMT_SWITCH;
142 }
143 
144 void ASTStmtWriter::VisitWhileStmt(WhileStmt *S) {
145   VisitStmt(S);
146   Writer.AddDeclRef(S->getConditionVariable(), Record);
147   Writer.AddStmt(S->getCond());
148   Writer.AddStmt(S->getBody());
149   Writer.AddSourceLocation(S->getWhileLoc(), Record);
150   Code = serialization::STMT_WHILE;
151 }
152 
153 void ASTStmtWriter::VisitDoStmt(DoStmt *S) {
154   VisitStmt(S);
155   Writer.AddStmt(S->getCond());
156   Writer.AddStmt(S->getBody());
157   Writer.AddSourceLocation(S->getDoLoc(), Record);
158   Writer.AddSourceLocation(S->getWhileLoc(), Record);
159   Writer.AddSourceLocation(S->getRParenLoc(), Record);
160   Code = serialization::STMT_DO;
161 }
162 
163 void ASTStmtWriter::VisitForStmt(ForStmt *S) {
164   VisitStmt(S);
165   Writer.AddStmt(S->getInit());
166   Writer.AddStmt(S->getCond());
167   Writer.AddDeclRef(S->getConditionVariable(), Record);
168   Writer.AddStmt(S->getInc());
169   Writer.AddStmt(S->getBody());
170   Writer.AddSourceLocation(S->getForLoc(), Record);
171   Writer.AddSourceLocation(S->getLParenLoc(), Record);
172   Writer.AddSourceLocation(S->getRParenLoc(), Record);
173   Code = serialization::STMT_FOR;
174 }
175 
176 void ASTStmtWriter::VisitGotoStmt(GotoStmt *S) {
177   VisitStmt(S);
178   Writer.AddDeclRef(S->getLabel(), Record);
179   Writer.AddSourceLocation(S->getGotoLoc(), Record);
180   Writer.AddSourceLocation(S->getLabelLoc(), Record);
181   Code = serialization::STMT_GOTO;
182 }
183 
184 void ASTStmtWriter::VisitIndirectGotoStmt(IndirectGotoStmt *S) {
185   VisitStmt(S);
186   Writer.AddSourceLocation(S->getGotoLoc(), Record);
187   Writer.AddSourceLocation(S->getStarLoc(), Record);
188   Writer.AddStmt(S->getTarget());
189   Code = serialization::STMT_INDIRECT_GOTO;
190 }
191 
192 void ASTStmtWriter::VisitContinueStmt(ContinueStmt *S) {
193   VisitStmt(S);
194   Writer.AddSourceLocation(S->getContinueLoc(), Record);
195   Code = serialization::STMT_CONTINUE;
196 }
197 
198 void ASTStmtWriter::VisitBreakStmt(BreakStmt *S) {
199   VisitStmt(S);
200   Writer.AddSourceLocation(S->getBreakLoc(), Record);
201   Code = serialization::STMT_BREAK;
202 }
203 
204 void ASTStmtWriter::VisitReturnStmt(ReturnStmt *S) {
205   VisitStmt(S);
206   Writer.AddStmt(S->getRetValue());
207   Writer.AddSourceLocation(S->getReturnLoc(), Record);
208   Writer.AddDeclRef(S->getNRVOCandidate(), Record);
209   Code = serialization::STMT_RETURN;
210 }
211 
212 void ASTStmtWriter::VisitDeclStmt(DeclStmt *S) {
213   VisitStmt(S);
214   Writer.AddSourceLocation(S->getStartLoc(), Record);
215   Writer.AddSourceLocation(S->getEndLoc(), Record);
216   DeclGroupRef DG = S->getDeclGroup();
217   for (DeclGroupRef::iterator D = DG.begin(), DEnd = DG.end(); D != DEnd; ++D)
218     Writer.AddDeclRef(*D, Record);
219   Code = serialization::STMT_DECL;
220 }
221 
222 void ASTStmtWriter::VisitAsmStmt(AsmStmt *S) {
223   VisitStmt(S);
224   Record.push_back(S->getNumOutputs());
225   Record.push_back(S->getNumInputs());
226   Record.push_back(S->getNumClobbers());
227   Writer.AddSourceLocation(S->getAsmLoc(), Record);
228   Record.push_back(S->isVolatile());
229   Record.push_back(S->isSimple());
230 }
231 
232 void ASTStmtWriter::VisitGCCAsmStmt(GCCAsmStmt *S) {
233   VisitAsmStmt(S);
234   Writer.AddSourceLocation(S->getRParenLoc(), Record);
235   Writer.AddStmt(S->getAsmString());
236 
237   // Outputs
238   for (unsigned I = 0, N = S->getNumOutputs(); I != N; ++I) {
239     Writer.AddIdentifierRef(S->getOutputIdentifier(I), Record);
240     Writer.AddStmt(S->getOutputConstraintLiteral(I));
241     Writer.AddStmt(S->getOutputExpr(I));
242   }
243 
244   // Inputs
245   for (unsigned I = 0, N = S->getNumInputs(); I != N; ++I) {
246     Writer.AddIdentifierRef(S->getInputIdentifier(I), Record);
247     Writer.AddStmt(S->getInputConstraintLiteral(I));
248     Writer.AddStmt(S->getInputExpr(I));
249   }
250 
251   // Clobbers
252   for (unsigned I = 0, N = S->getNumClobbers(); I != N; ++I)
253     Writer.AddStmt(S->getClobberStringLiteral(I));
254 
255   Code = serialization::STMT_GCCASM;
256 }
257 
258 void ASTStmtWriter::VisitMSAsmStmt(MSAsmStmt *S) {
259   VisitAsmStmt(S);
260   Writer.AddSourceLocation(S->getLBraceLoc(), Record);
261   Writer.AddSourceLocation(S->getEndLoc(), Record);
262   Record.push_back(S->getNumAsmToks());
263   Writer.AddString(S->getAsmString(), Record);
264 
265   // Tokens
266   for (unsigned I = 0, N = S->getNumAsmToks(); I != N; ++I) {
267     Writer.AddToken(S->getAsmToks()[I], Record);
268   }
269 
270   // Clobbers
271   for (unsigned I = 0, N = S->getNumClobbers(); I != N; ++I) {
272     Writer.AddString(S->getClobber(I), Record);
273   }
274 
275   // Outputs
276   for (unsigned I = 0, N = S->getNumOutputs(); I != N; ++I) {
277     Writer.AddStmt(S->getOutputExpr(I));
278     Writer.AddString(S->getOutputConstraint(I), Record);
279   }
280 
281   // Inputs
282   for (unsigned I = 0, N = S->getNumInputs(); I != N; ++I) {
283     Writer.AddStmt(S->getInputExpr(I));
284     Writer.AddString(S->getInputConstraint(I), Record);
285   }
286 
287   Code = serialization::STMT_MSASM;
288 }
289 
290 void ASTStmtWriter::VisitCapturedStmt(CapturedStmt *S) {
291   VisitStmt(S);
292   // NumCaptures
293   Record.push_back(std::distance(S->capture_begin(), S->capture_end()));
294 
295   // CapturedDecl and captured region kind
296   Writer.AddDeclRef(S->getCapturedDecl(), Record);
297   Record.push_back(S->getCapturedRegionKind());
298 
299   Writer.AddDeclRef(S->getCapturedRecordDecl(), Record);
300 
301   // Capture inits
302   for (auto *I : S->capture_inits())
303     Writer.AddStmt(I);
304 
305   // Body
306   Writer.AddStmt(S->getCapturedStmt());
307 
308   // Captures
309   for (const auto &I : S->captures()) {
310     if (I.capturesThis())
311       Writer.AddDeclRef(nullptr, Record);
312     else
313       Writer.AddDeclRef(I.getCapturedVar(), Record);
314     Record.push_back(I.getCaptureKind());
315     Writer.AddSourceLocation(I.getLocation(), Record);
316   }
317 
318   Code = serialization::STMT_CAPTURED;
319 }
320 
321 void ASTStmtWriter::VisitExpr(Expr *E) {
322   VisitStmt(E);
323   Writer.AddTypeRef(E->getType(), Record);
324   Record.push_back(E->isTypeDependent());
325   Record.push_back(E->isValueDependent());
326   Record.push_back(E->isInstantiationDependent());
327   Record.push_back(E->containsUnexpandedParameterPack());
328   Record.push_back(E->getValueKind());
329   Record.push_back(E->getObjectKind());
330 }
331 
332 void ASTStmtWriter::VisitPredefinedExpr(PredefinedExpr *E) {
333   VisitExpr(E);
334   Writer.AddSourceLocation(E->getLocation(), Record);
335   Record.push_back(E->getIdentType()); // FIXME: stable encoding
336   Code = serialization::EXPR_PREDEFINED;
337 }
338 
339 void ASTStmtWriter::VisitDeclRefExpr(DeclRefExpr *E) {
340   VisitExpr(E);
341 
342   Record.push_back(E->hasQualifier());
343   Record.push_back(E->getDecl() != E->getFoundDecl());
344   Record.push_back(E->hasTemplateKWAndArgsInfo());
345   Record.push_back(E->hadMultipleCandidates());
346   Record.push_back(E->refersToEnclosingLocal());
347 
348   if (E->hasTemplateKWAndArgsInfo()) {
349     unsigned NumTemplateArgs = E->getNumTemplateArgs();
350     Record.push_back(NumTemplateArgs);
351   }
352 
353   DeclarationName::NameKind nk = (E->getDecl()->getDeclName().getNameKind());
354 
355   if ((!E->hasTemplateKWAndArgsInfo()) && (!E->hasQualifier()) &&
356       (E->getDecl() == E->getFoundDecl()) &&
357       nk == DeclarationName::Identifier) {
358     AbbrevToUse = Writer.getDeclRefExprAbbrev();
359   }
360 
361   if (E->hasQualifier())
362     Writer.AddNestedNameSpecifierLoc(E->getQualifierLoc(), Record);
363 
364   if (E->getDecl() != E->getFoundDecl())
365     Writer.AddDeclRef(E->getFoundDecl(), Record);
366 
367   if (E->hasTemplateKWAndArgsInfo())
368     AddTemplateKWAndArgsInfo(*E->getTemplateKWAndArgsInfo());
369 
370   Writer.AddDeclRef(E->getDecl(), Record);
371   Writer.AddSourceLocation(E->getLocation(), Record);
372   Writer.AddDeclarationNameLoc(E->DNLoc, E->getDecl()->getDeclName(), Record);
373   Code = serialization::EXPR_DECL_REF;
374 }
375 
376 void ASTStmtWriter::VisitIntegerLiteral(IntegerLiteral *E) {
377   VisitExpr(E);
378   Writer.AddSourceLocation(E->getLocation(), Record);
379   Writer.AddAPInt(E->getValue(), Record);
380 
381   if (E->getValue().getBitWidth() == 32) {
382     AbbrevToUse = Writer.getIntegerLiteralAbbrev();
383   }
384 
385   Code = serialization::EXPR_INTEGER_LITERAL;
386 }
387 
388 void ASTStmtWriter::VisitFloatingLiteral(FloatingLiteral *E) {
389   VisitExpr(E);
390   Record.push_back(E->getRawSemantics());
391   Record.push_back(E->isExact());
392   Writer.AddAPFloat(E->getValue(), Record);
393   Writer.AddSourceLocation(E->getLocation(), Record);
394   Code = serialization::EXPR_FLOATING_LITERAL;
395 }
396 
397 void ASTStmtWriter::VisitImaginaryLiteral(ImaginaryLiteral *E) {
398   VisitExpr(E);
399   Writer.AddStmt(E->getSubExpr());
400   Code = serialization::EXPR_IMAGINARY_LITERAL;
401 }
402 
403 void ASTStmtWriter::VisitStringLiteral(StringLiteral *E) {
404   VisitExpr(E);
405   Record.push_back(E->getByteLength());
406   Record.push_back(E->getNumConcatenated());
407   Record.push_back(E->getKind());
408   Record.push_back(E->isPascal());
409   // FIXME: String data should be stored as a blob at the end of the
410   // StringLiteral. However, we can't do so now because we have no
411   // provision for coping with abbreviations when we're jumping around
412   // the AST file during deserialization.
413   Record.append(E->getBytes().begin(), E->getBytes().end());
414   for (unsigned I = 0, N = E->getNumConcatenated(); I != N; ++I)
415     Writer.AddSourceLocation(E->getStrTokenLoc(I), Record);
416   Code = serialization::EXPR_STRING_LITERAL;
417 }
418 
419 void ASTStmtWriter::VisitCharacterLiteral(CharacterLiteral *E) {
420   VisitExpr(E);
421   Record.push_back(E->getValue());
422   Writer.AddSourceLocation(E->getLocation(), Record);
423   Record.push_back(E->getKind());
424 
425   AbbrevToUse = Writer.getCharacterLiteralAbbrev();
426 
427   Code = serialization::EXPR_CHARACTER_LITERAL;
428 }
429 
430 void ASTStmtWriter::VisitParenExpr(ParenExpr *E) {
431   VisitExpr(E);
432   Writer.AddSourceLocation(E->getLParen(), Record);
433   Writer.AddSourceLocation(E->getRParen(), Record);
434   Writer.AddStmt(E->getSubExpr());
435   Code = serialization::EXPR_PAREN;
436 }
437 
438 void ASTStmtWriter::VisitParenListExpr(ParenListExpr *E) {
439   VisitExpr(E);
440   Record.push_back(E->NumExprs);
441   for (unsigned i=0; i != E->NumExprs; ++i)
442     Writer.AddStmt(E->Exprs[i]);
443   Writer.AddSourceLocation(E->LParenLoc, Record);
444   Writer.AddSourceLocation(E->RParenLoc, Record);
445   Code = serialization::EXPR_PAREN_LIST;
446 }
447 
448 void ASTStmtWriter::VisitUnaryOperator(UnaryOperator *E) {
449   VisitExpr(E);
450   Writer.AddStmt(E->getSubExpr());
451   Record.push_back(E->getOpcode()); // FIXME: stable encoding
452   Writer.AddSourceLocation(E->getOperatorLoc(), Record);
453   Code = serialization::EXPR_UNARY_OPERATOR;
454 }
455 
456 void ASTStmtWriter::VisitOffsetOfExpr(OffsetOfExpr *E) {
457   VisitExpr(E);
458   Record.push_back(E->getNumComponents());
459   Record.push_back(E->getNumExpressions());
460   Writer.AddSourceLocation(E->getOperatorLoc(), Record);
461   Writer.AddSourceLocation(E->getRParenLoc(), Record);
462   Writer.AddTypeSourceInfo(E->getTypeSourceInfo(), Record);
463   for (unsigned I = 0, N = E->getNumComponents(); I != N; ++I) {
464     const OffsetOfExpr::OffsetOfNode &ON = E->getComponent(I);
465     Record.push_back(ON.getKind()); // FIXME: Stable encoding
466     Writer.AddSourceLocation(ON.getSourceRange().getBegin(), Record);
467     Writer.AddSourceLocation(ON.getSourceRange().getEnd(), Record);
468     switch (ON.getKind()) {
469     case OffsetOfExpr::OffsetOfNode::Array:
470       Record.push_back(ON.getArrayExprIndex());
471       break;
472 
473     case OffsetOfExpr::OffsetOfNode::Field:
474       Writer.AddDeclRef(ON.getField(), Record);
475       break;
476 
477     case OffsetOfExpr::OffsetOfNode::Identifier:
478       Writer.AddIdentifierRef(ON.getFieldName(), Record);
479       break;
480 
481     case OffsetOfExpr::OffsetOfNode::Base:
482       Writer.AddCXXBaseSpecifier(*ON.getBase(), Record);
483       break;
484     }
485   }
486   for (unsigned I = 0, N = E->getNumExpressions(); I != N; ++I)
487     Writer.AddStmt(E->getIndexExpr(I));
488   Code = serialization::EXPR_OFFSETOF;
489 }
490 
491 void ASTStmtWriter::VisitUnaryExprOrTypeTraitExpr(UnaryExprOrTypeTraitExpr *E) {
492   VisitExpr(E);
493   Record.push_back(E->getKind());
494   if (E->isArgumentType())
495     Writer.AddTypeSourceInfo(E->getArgumentTypeInfo(), Record);
496   else {
497     Record.push_back(0);
498     Writer.AddStmt(E->getArgumentExpr());
499   }
500   Writer.AddSourceLocation(E->getOperatorLoc(), Record);
501   Writer.AddSourceLocation(E->getRParenLoc(), Record);
502   Code = serialization::EXPR_SIZEOF_ALIGN_OF;
503 }
504 
505 void ASTStmtWriter::VisitArraySubscriptExpr(ArraySubscriptExpr *E) {
506   VisitExpr(E);
507   Writer.AddStmt(E->getLHS());
508   Writer.AddStmt(E->getRHS());
509   Writer.AddSourceLocation(E->getRBracketLoc(), Record);
510   Code = serialization::EXPR_ARRAY_SUBSCRIPT;
511 }
512 
513 void ASTStmtWriter::VisitCallExpr(CallExpr *E) {
514   VisitExpr(E);
515   Record.push_back(E->getNumArgs());
516   Writer.AddSourceLocation(E->getRParenLoc(), Record);
517   Writer.AddStmt(E->getCallee());
518   for (CallExpr::arg_iterator Arg = E->arg_begin(), ArgEnd = E->arg_end();
519        Arg != ArgEnd; ++Arg)
520     Writer.AddStmt(*Arg);
521   Code = serialization::EXPR_CALL;
522 }
523 
524 void ASTStmtWriter::VisitMemberExpr(MemberExpr *E) {
525   // Don't call VisitExpr, we'll write everything here.
526 
527   Record.push_back(E->hasQualifier());
528   if (E->hasQualifier())
529     Writer.AddNestedNameSpecifierLoc(E->getQualifierLoc(), Record);
530 
531   Record.push_back(E->HasTemplateKWAndArgsInfo);
532   if (E->HasTemplateKWAndArgsInfo) {
533     Writer.AddSourceLocation(E->getTemplateKeywordLoc(), Record);
534     unsigned NumTemplateArgs = E->getNumTemplateArgs();
535     Record.push_back(NumTemplateArgs);
536     Writer.AddSourceLocation(E->getLAngleLoc(), Record);
537     Writer.AddSourceLocation(E->getRAngleLoc(), Record);
538     for (unsigned i=0; i != NumTemplateArgs; ++i)
539       Writer.AddTemplateArgumentLoc(E->getTemplateArgs()[i], Record);
540   }
541 
542   Record.push_back(E->hadMultipleCandidates());
543 
544   DeclAccessPair FoundDecl = E->getFoundDecl();
545   Writer.AddDeclRef(FoundDecl.getDecl(), Record);
546   Record.push_back(FoundDecl.getAccess());
547 
548   Writer.AddTypeRef(E->getType(), Record);
549   Record.push_back(E->getValueKind());
550   Record.push_back(E->getObjectKind());
551   Writer.AddStmt(E->getBase());
552   Writer.AddDeclRef(E->getMemberDecl(), Record);
553   Writer.AddSourceLocation(E->getMemberLoc(), Record);
554   Record.push_back(E->isArrow());
555   Writer.AddDeclarationNameLoc(E->MemberDNLoc,
556                                E->getMemberDecl()->getDeclName(), Record);
557   Code = serialization::EXPR_MEMBER;
558 }
559 
560 void ASTStmtWriter::VisitObjCIsaExpr(ObjCIsaExpr *E) {
561   VisitExpr(E);
562   Writer.AddStmt(E->getBase());
563   Writer.AddSourceLocation(E->getIsaMemberLoc(), Record);
564   Writer.AddSourceLocation(E->getOpLoc(), Record);
565   Record.push_back(E->isArrow());
566   Code = serialization::EXPR_OBJC_ISA;
567 }
568 
569 void ASTStmtWriter::
570 VisitObjCIndirectCopyRestoreExpr(ObjCIndirectCopyRestoreExpr *E) {
571   VisitExpr(E);
572   Writer.AddStmt(E->getSubExpr());
573   Record.push_back(E->shouldCopy());
574   Code = serialization::EXPR_OBJC_INDIRECT_COPY_RESTORE;
575 }
576 
577 void ASTStmtWriter::VisitObjCBridgedCastExpr(ObjCBridgedCastExpr *E) {
578   VisitExplicitCastExpr(E);
579   Writer.AddSourceLocation(E->getLParenLoc(), Record);
580   Writer.AddSourceLocation(E->getBridgeKeywordLoc(), Record);
581   Record.push_back(E->getBridgeKind()); // FIXME: Stable encoding
582   Code = serialization::EXPR_OBJC_BRIDGED_CAST;
583 }
584 
585 void ASTStmtWriter::VisitCastExpr(CastExpr *E) {
586   VisitExpr(E);
587   Record.push_back(E->path_size());
588   Writer.AddStmt(E->getSubExpr());
589   Record.push_back(E->getCastKind()); // FIXME: stable encoding
590 
591   for (CastExpr::path_iterator
592          PI = E->path_begin(), PE = E->path_end(); PI != PE; ++PI)
593     Writer.AddCXXBaseSpecifier(**PI, Record);
594 }
595 
596 void ASTStmtWriter::VisitBinaryOperator(BinaryOperator *E) {
597   VisitExpr(E);
598   Writer.AddStmt(E->getLHS());
599   Writer.AddStmt(E->getRHS());
600   Record.push_back(E->getOpcode()); // FIXME: stable encoding
601   Writer.AddSourceLocation(E->getOperatorLoc(), Record);
602   Record.push_back(E->isFPContractable());
603   Code = serialization::EXPR_BINARY_OPERATOR;
604 }
605 
606 void ASTStmtWriter::VisitCompoundAssignOperator(CompoundAssignOperator *E) {
607   VisitBinaryOperator(E);
608   Writer.AddTypeRef(E->getComputationLHSType(), Record);
609   Writer.AddTypeRef(E->getComputationResultType(), Record);
610   Code = serialization::EXPR_COMPOUND_ASSIGN_OPERATOR;
611 }
612 
613 void ASTStmtWriter::VisitConditionalOperator(ConditionalOperator *E) {
614   VisitExpr(E);
615   Writer.AddStmt(E->getCond());
616   Writer.AddStmt(E->getLHS());
617   Writer.AddStmt(E->getRHS());
618   Writer.AddSourceLocation(E->getQuestionLoc(), Record);
619   Writer.AddSourceLocation(E->getColonLoc(), Record);
620   Code = serialization::EXPR_CONDITIONAL_OPERATOR;
621 }
622 
623 void
624 ASTStmtWriter::VisitBinaryConditionalOperator(BinaryConditionalOperator *E) {
625   VisitExpr(E);
626   Writer.AddStmt(E->getOpaqueValue());
627   Writer.AddStmt(E->getCommon());
628   Writer.AddStmt(E->getCond());
629   Writer.AddStmt(E->getTrueExpr());
630   Writer.AddStmt(E->getFalseExpr());
631   Writer.AddSourceLocation(E->getQuestionLoc(), Record);
632   Writer.AddSourceLocation(E->getColonLoc(), Record);
633   Code = serialization::EXPR_BINARY_CONDITIONAL_OPERATOR;
634 }
635 
636 void ASTStmtWriter::VisitImplicitCastExpr(ImplicitCastExpr *E) {
637   VisitCastExpr(E);
638 
639   if (E->path_size() == 0)
640     AbbrevToUse = Writer.getExprImplicitCastAbbrev();
641 
642   Code = serialization::EXPR_IMPLICIT_CAST;
643 }
644 
645 void ASTStmtWriter::VisitExplicitCastExpr(ExplicitCastExpr *E) {
646   VisitCastExpr(E);
647   Writer.AddTypeSourceInfo(E->getTypeInfoAsWritten(), Record);
648 }
649 
650 void ASTStmtWriter::VisitCStyleCastExpr(CStyleCastExpr *E) {
651   VisitExplicitCastExpr(E);
652   Writer.AddSourceLocation(E->getLParenLoc(), Record);
653   Writer.AddSourceLocation(E->getRParenLoc(), Record);
654   Code = serialization::EXPR_CSTYLE_CAST;
655 }
656 
657 void ASTStmtWriter::VisitCompoundLiteralExpr(CompoundLiteralExpr *E) {
658   VisitExpr(E);
659   Writer.AddSourceLocation(E->getLParenLoc(), Record);
660   Writer.AddTypeSourceInfo(E->getTypeSourceInfo(), Record);
661   Writer.AddStmt(E->getInitializer());
662   Record.push_back(E->isFileScope());
663   Code = serialization::EXPR_COMPOUND_LITERAL;
664 }
665 
666 void ASTStmtWriter::VisitExtVectorElementExpr(ExtVectorElementExpr *E) {
667   VisitExpr(E);
668   Writer.AddStmt(E->getBase());
669   Writer.AddIdentifierRef(&E->getAccessor(), Record);
670   Writer.AddSourceLocation(E->getAccessorLoc(), Record);
671   Code = serialization::EXPR_EXT_VECTOR_ELEMENT;
672 }
673 
674 void ASTStmtWriter::VisitInitListExpr(InitListExpr *E) {
675   VisitExpr(E);
676   // NOTE: only add the (possibly null) syntactic form.
677   // No need to serialize the isSemanticForm flag and the semantic form.
678   Writer.AddStmt(E->getSyntacticForm());
679   Writer.AddSourceLocation(E->getLBraceLoc(), Record);
680   Writer.AddSourceLocation(E->getRBraceLoc(), Record);
681   bool isArrayFiller = E->ArrayFillerOrUnionFieldInit.is<Expr*>();
682   Record.push_back(isArrayFiller);
683   if (isArrayFiller)
684     Writer.AddStmt(E->getArrayFiller());
685   else
686     Writer.AddDeclRef(E->getInitializedFieldInUnion(), Record);
687   Record.push_back(E->hadArrayRangeDesignator());
688   Record.push_back(E->getNumInits());
689   if (isArrayFiller) {
690     // ArrayFiller may have filled "holes" due to designated initializer.
691     // Replace them by 0 to indicate that the filler goes in that place.
692     Expr *filler = E->getArrayFiller();
693     for (unsigned I = 0, N = E->getNumInits(); I != N; ++I)
694       Writer.AddStmt(E->getInit(I) != filler ? E->getInit(I) : nullptr);
695   } else {
696     for (unsigned I = 0, N = E->getNumInits(); I != N; ++I)
697       Writer.AddStmt(E->getInit(I));
698   }
699   Code = serialization::EXPR_INIT_LIST;
700 }
701 
702 void ASTStmtWriter::VisitDesignatedInitExpr(DesignatedInitExpr *E) {
703   VisitExpr(E);
704   Record.push_back(E->getNumSubExprs());
705   for (unsigned I = 0, N = E->getNumSubExprs(); I != N; ++I)
706     Writer.AddStmt(E->getSubExpr(I));
707   Writer.AddSourceLocation(E->getEqualOrColonLoc(), Record);
708   Record.push_back(E->usesGNUSyntax());
709   for (DesignatedInitExpr::designators_iterator D = E->designators_begin(),
710                                              DEnd = E->designators_end();
711        D != DEnd; ++D) {
712     if (D->isFieldDesignator()) {
713       if (FieldDecl *Field = D->getField()) {
714         Record.push_back(serialization::DESIG_FIELD_DECL);
715         Writer.AddDeclRef(Field, Record);
716       } else {
717         Record.push_back(serialization::DESIG_FIELD_NAME);
718         Writer.AddIdentifierRef(D->getFieldName(), Record);
719       }
720       Writer.AddSourceLocation(D->getDotLoc(), Record);
721       Writer.AddSourceLocation(D->getFieldLoc(), Record);
722     } else if (D->isArrayDesignator()) {
723       Record.push_back(serialization::DESIG_ARRAY);
724       Record.push_back(D->getFirstExprIndex());
725       Writer.AddSourceLocation(D->getLBracketLoc(), Record);
726       Writer.AddSourceLocation(D->getRBracketLoc(), Record);
727     } else {
728       assert(D->isArrayRangeDesignator() && "Unknown designator");
729       Record.push_back(serialization::DESIG_ARRAY_RANGE);
730       Record.push_back(D->getFirstExprIndex());
731       Writer.AddSourceLocation(D->getLBracketLoc(), Record);
732       Writer.AddSourceLocation(D->getEllipsisLoc(), Record);
733       Writer.AddSourceLocation(D->getRBracketLoc(), Record);
734     }
735   }
736   Code = serialization::EXPR_DESIGNATED_INIT;
737 }
738 
739 void ASTStmtWriter::VisitImplicitValueInitExpr(ImplicitValueInitExpr *E) {
740   VisitExpr(E);
741   Code = serialization::EXPR_IMPLICIT_VALUE_INIT;
742 }
743 
744 void ASTStmtWriter::VisitVAArgExpr(VAArgExpr *E) {
745   VisitExpr(E);
746   Writer.AddStmt(E->getSubExpr());
747   Writer.AddTypeSourceInfo(E->getWrittenTypeInfo(), Record);
748   Writer.AddSourceLocation(E->getBuiltinLoc(), Record);
749   Writer.AddSourceLocation(E->getRParenLoc(), Record);
750   Code = serialization::EXPR_VA_ARG;
751 }
752 
753 void ASTStmtWriter::VisitAddrLabelExpr(AddrLabelExpr *E) {
754   VisitExpr(E);
755   Writer.AddSourceLocation(E->getAmpAmpLoc(), Record);
756   Writer.AddSourceLocation(E->getLabelLoc(), Record);
757   Writer.AddDeclRef(E->getLabel(), Record);
758   Code = serialization::EXPR_ADDR_LABEL;
759 }
760 
761 void ASTStmtWriter::VisitStmtExpr(StmtExpr *E) {
762   VisitExpr(E);
763   Writer.AddStmt(E->getSubStmt());
764   Writer.AddSourceLocation(E->getLParenLoc(), Record);
765   Writer.AddSourceLocation(E->getRParenLoc(), Record);
766   Code = serialization::EXPR_STMT;
767 }
768 
769 void ASTStmtWriter::VisitChooseExpr(ChooseExpr *E) {
770   VisitExpr(E);
771   Writer.AddStmt(E->getCond());
772   Writer.AddStmt(E->getLHS());
773   Writer.AddStmt(E->getRHS());
774   Writer.AddSourceLocation(E->getBuiltinLoc(), Record);
775   Writer.AddSourceLocation(E->getRParenLoc(), Record);
776   Record.push_back(E->isConditionDependent() ? false : E->isConditionTrue());
777   Code = serialization::EXPR_CHOOSE;
778 }
779 
780 void ASTStmtWriter::VisitGNUNullExpr(GNUNullExpr *E) {
781   VisitExpr(E);
782   Writer.AddSourceLocation(E->getTokenLocation(), Record);
783   Code = serialization::EXPR_GNU_NULL;
784 }
785 
786 void ASTStmtWriter::VisitShuffleVectorExpr(ShuffleVectorExpr *E) {
787   VisitExpr(E);
788   Record.push_back(E->getNumSubExprs());
789   for (unsigned I = 0, N = E->getNumSubExprs(); I != N; ++I)
790     Writer.AddStmt(E->getExpr(I));
791   Writer.AddSourceLocation(E->getBuiltinLoc(), Record);
792   Writer.AddSourceLocation(E->getRParenLoc(), Record);
793   Code = serialization::EXPR_SHUFFLE_VECTOR;
794 }
795 
796 void ASTStmtWriter::VisitConvertVectorExpr(ConvertVectorExpr *E) {
797   VisitExpr(E);
798   Writer.AddSourceLocation(E->getBuiltinLoc(), Record);
799   Writer.AddSourceLocation(E->getRParenLoc(), Record);
800   Writer.AddTypeSourceInfo(E->getTypeSourceInfo(), Record);
801   Writer.AddStmt(E->getSrcExpr());
802   Code = serialization::EXPR_CONVERT_VECTOR;
803 }
804 
805 void ASTStmtWriter::VisitBlockExpr(BlockExpr *E) {
806   VisitExpr(E);
807   Writer.AddDeclRef(E->getBlockDecl(), Record);
808   Code = serialization::EXPR_BLOCK;
809 }
810 
811 void ASTStmtWriter::VisitGenericSelectionExpr(GenericSelectionExpr *E) {
812   VisitExpr(E);
813   Record.push_back(E->getNumAssocs());
814 
815   Writer.AddStmt(E->getControllingExpr());
816   for (unsigned I = 0, N = E->getNumAssocs(); I != N; ++I) {
817     Writer.AddTypeSourceInfo(E->getAssocTypeSourceInfo(I), Record);
818     Writer.AddStmt(E->getAssocExpr(I));
819   }
820   Record.push_back(E->isResultDependent() ? -1U : E->getResultIndex());
821 
822   Writer.AddSourceLocation(E->getGenericLoc(), Record);
823   Writer.AddSourceLocation(E->getDefaultLoc(), Record);
824   Writer.AddSourceLocation(E->getRParenLoc(), Record);
825   Code = serialization::EXPR_GENERIC_SELECTION;
826 }
827 
828 void ASTStmtWriter::VisitPseudoObjectExpr(PseudoObjectExpr *E) {
829   VisitExpr(E);
830   Record.push_back(E->getNumSemanticExprs());
831 
832   // Push the result index.  Currently, this needs to exactly match
833   // the encoding used internally for ResultIndex.
834   unsigned result = E->getResultExprIndex();
835   result = (result == PseudoObjectExpr::NoResult ? 0 : result + 1);
836   Record.push_back(result);
837 
838   Writer.AddStmt(E->getSyntacticForm());
839   for (PseudoObjectExpr::semantics_iterator
840          i = E->semantics_begin(), e = E->semantics_end(); i != e; ++i) {
841     Writer.AddStmt(*i);
842   }
843   Code = serialization::EXPR_PSEUDO_OBJECT;
844 }
845 
846 void ASTStmtWriter::VisitAtomicExpr(AtomicExpr *E) {
847   VisitExpr(E);
848   Record.push_back(E->getOp());
849   for (unsigned I = 0, N = E->getNumSubExprs(); I != N; ++I)
850     Writer.AddStmt(E->getSubExprs()[I]);
851   Writer.AddSourceLocation(E->getBuiltinLoc(), Record);
852   Writer.AddSourceLocation(E->getRParenLoc(), Record);
853   Code = serialization::EXPR_ATOMIC;
854 }
855 
856 //===----------------------------------------------------------------------===//
857 // Objective-C Expressions and Statements.
858 //===----------------------------------------------------------------------===//
859 
860 void ASTStmtWriter::VisitObjCStringLiteral(ObjCStringLiteral *E) {
861   VisitExpr(E);
862   Writer.AddStmt(E->getString());
863   Writer.AddSourceLocation(E->getAtLoc(), Record);
864   Code = serialization::EXPR_OBJC_STRING_LITERAL;
865 }
866 
867 void ASTStmtWriter::VisitObjCBoxedExpr(ObjCBoxedExpr *E) {
868   VisitExpr(E);
869   Writer.AddStmt(E->getSubExpr());
870   Writer.AddDeclRef(E->getBoxingMethod(), Record);
871   Writer.AddSourceRange(E->getSourceRange(), Record);
872   Code = serialization::EXPR_OBJC_BOXED_EXPRESSION;
873 }
874 
875 void ASTStmtWriter::VisitObjCArrayLiteral(ObjCArrayLiteral *E) {
876   VisitExpr(E);
877   Record.push_back(E->getNumElements());
878   for (unsigned i = 0; i < E->getNumElements(); i++)
879     Writer.AddStmt(E->getElement(i));
880   Writer.AddDeclRef(E->getArrayWithObjectsMethod(), Record);
881   Writer.AddDeclRef(E->getArrayAllocMethod(), Record);
882   Writer.AddSourceRange(E->getSourceRange(), Record);
883   Code = serialization::EXPR_OBJC_ARRAY_LITERAL;
884 }
885 
886 void ASTStmtWriter::VisitObjCDictionaryLiteral(ObjCDictionaryLiteral *E) {
887   VisitExpr(E);
888   Record.push_back(E->getNumElements());
889   Record.push_back(E->HasPackExpansions);
890   for (unsigned i = 0; i < E->getNumElements(); i++) {
891     ObjCDictionaryElement Element = E->getKeyValueElement(i);
892     Writer.AddStmt(Element.Key);
893     Writer.AddStmt(Element.Value);
894     if (E->HasPackExpansions) {
895       Writer.AddSourceLocation(Element.EllipsisLoc, Record);
896       unsigned NumExpansions = 0;
897       if (Element.NumExpansions)
898         NumExpansions = *Element.NumExpansions + 1;
899       Record.push_back(NumExpansions);
900     }
901   }
902 
903   Writer.AddDeclRef(E->getDictWithObjectsMethod(), Record);
904   Writer.AddDeclRef(E->getDictAllocMethod(), Record);
905   Writer.AddSourceRange(E->getSourceRange(), Record);
906   Code = serialization::EXPR_OBJC_DICTIONARY_LITERAL;
907 }
908 
909 void ASTStmtWriter::VisitObjCEncodeExpr(ObjCEncodeExpr *E) {
910   VisitExpr(E);
911   Writer.AddTypeSourceInfo(E->getEncodedTypeSourceInfo(), Record);
912   Writer.AddSourceLocation(E->getAtLoc(), Record);
913   Writer.AddSourceLocation(E->getRParenLoc(), Record);
914   Code = serialization::EXPR_OBJC_ENCODE;
915 }
916 
917 void ASTStmtWriter::VisitObjCSelectorExpr(ObjCSelectorExpr *E) {
918   VisitExpr(E);
919   Writer.AddSelectorRef(E->getSelector(), Record);
920   Writer.AddSourceLocation(E->getAtLoc(), Record);
921   Writer.AddSourceLocation(E->getRParenLoc(), Record);
922   Code = serialization::EXPR_OBJC_SELECTOR_EXPR;
923 }
924 
925 void ASTStmtWriter::VisitObjCProtocolExpr(ObjCProtocolExpr *E) {
926   VisitExpr(E);
927   Writer.AddDeclRef(E->getProtocol(), Record);
928   Writer.AddSourceLocation(E->getAtLoc(), Record);
929   Writer.AddSourceLocation(E->ProtoLoc, Record);
930   Writer.AddSourceLocation(E->getRParenLoc(), Record);
931   Code = serialization::EXPR_OBJC_PROTOCOL_EXPR;
932 }
933 
934 void ASTStmtWriter::VisitObjCIvarRefExpr(ObjCIvarRefExpr *E) {
935   VisitExpr(E);
936   Writer.AddDeclRef(E->getDecl(), Record);
937   Writer.AddSourceLocation(E->getLocation(), Record);
938   Writer.AddSourceLocation(E->getOpLoc(), Record);
939   Writer.AddStmt(E->getBase());
940   Record.push_back(E->isArrow());
941   Record.push_back(E->isFreeIvar());
942   Code = serialization::EXPR_OBJC_IVAR_REF_EXPR;
943 }
944 
945 void ASTStmtWriter::VisitObjCPropertyRefExpr(ObjCPropertyRefExpr *E) {
946   VisitExpr(E);
947   Record.push_back(E->SetterAndMethodRefFlags.getInt());
948   Record.push_back(E->isImplicitProperty());
949   if (E->isImplicitProperty()) {
950     Writer.AddDeclRef(E->getImplicitPropertyGetter(), Record);
951     Writer.AddDeclRef(E->getImplicitPropertySetter(), Record);
952   } else {
953     Writer.AddDeclRef(E->getExplicitProperty(), Record);
954   }
955   Writer.AddSourceLocation(E->getLocation(), Record);
956   Writer.AddSourceLocation(E->getReceiverLocation(), Record);
957   if (E->isObjectReceiver()) {
958     Record.push_back(0);
959     Writer.AddStmt(E->getBase());
960   } else if (E->isSuperReceiver()) {
961     Record.push_back(1);
962     Writer.AddTypeRef(E->getSuperReceiverType(), Record);
963   } else {
964     Record.push_back(2);
965     Writer.AddDeclRef(E->getClassReceiver(), Record);
966   }
967 
968   Code = serialization::EXPR_OBJC_PROPERTY_REF_EXPR;
969 }
970 
971 void ASTStmtWriter::VisitObjCSubscriptRefExpr(ObjCSubscriptRefExpr *E) {
972   VisitExpr(E);
973   Writer.AddSourceLocation(E->getRBracket(), Record);
974   Writer.AddStmt(E->getBaseExpr());
975   Writer.AddStmt(E->getKeyExpr());
976   Writer.AddDeclRef(E->getAtIndexMethodDecl(), Record);
977   Writer.AddDeclRef(E->setAtIndexMethodDecl(), Record);
978 
979   Code = serialization::EXPR_OBJC_SUBSCRIPT_REF_EXPR;
980 }
981 
982 void ASTStmtWriter::VisitObjCMessageExpr(ObjCMessageExpr *E) {
983   VisitExpr(E);
984   Record.push_back(E->getNumArgs());
985   Record.push_back(E->getNumStoredSelLocs());
986   Record.push_back(E->SelLocsKind);
987   Record.push_back(E->isDelegateInitCall());
988   Record.push_back(E->IsImplicit);
989   Record.push_back((unsigned)E->getReceiverKind()); // FIXME: stable encoding
990   switch (E->getReceiverKind()) {
991   case ObjCMessageExpr::Instance:
992     Writer.AddStmt(E->getInstanceReceiver());
993     break;
994 
995   case ObjCMessageExpr::Class:
996     Writer.AddTypeSourceInfo(E->getClassReceiverTypeInfo(), Record);
997     break;
998 
999   case ObjCMessageExpr::SuperClass:
1000   case ObjCMessageExpr::SuperInstance:
1001     Writer.AddTypeRef(E->getSuperType(), Record);
1002     Writer.AddSourceLocation(E->getSuperLoc(), Record);
1003     break;
1004   }
1005 
1006   if (E->getMethodDecl()) {
1007     Record.push_back(1);
1008     Writer.AddDeclRef(E->getMethodDecl(), Record);
1009   } else {
1010     Record.push_back(0);
1011     Writer.AddSelectorRef(E->getSelector(), Record);
1012   }
1013 
1014   Writer.AddSourceLocation(E->getLeftLoc(), Record);
1015   Writer.AddSourceLocation(E->getRightLoc(), Record);
1016 
1017   for (CallExpr::arg_iterator Arg = E->arg_begin(), ArgEnd = E->arg_end();
1018        Arg != ArgEnd; ++Arg)
1019     Writer.AddStmt(*Arg);
1020 
1021   SourceLocation *Locs = E->getStoredSelLocs();
1022   for (unsigned i = 0, e = E->getNumStoredSelLocs(); i != e; ++i)
1023     Writer.AddSourceLocation(Locs[i], Record);
1024 
1025   Code = serialization::EXPR_OBJC_MESSAGE_EXPR;
1026 }
1027 
1028 void ASTStmtWriter::VisitObjCForCollectionStmt(ObjCForCollectionStmt *S) {
1029   VisitStmt(S);
1030   Writer.AddStmt(S->getElement());
1031   Writer.AddStmt(S->getCollection());
1032   Writer.AddStmt(S->getBody());
1033   Writer.AddSourceLocation(S->getForLoc(), Record);
1034   Writer.AddSourceLocation(S->getRParenLoc(), Record);
1035   Code = serialization::STMT_OBJC_FOR_COLLECTION;
1036 }
1037 
1038 void ASTStmtWriter::VisitObjCAtCatchStmt(ObjCAtCatchStmt *S) {
1039   Writer.AddStmt(S->getCatchBody());
1040   Writer.AddDeclRef(S->getCatchParamDecl(), Record);
1041   Writer.AddSourceLocation(S->getAtCatchLoc(), Record);
1042   Writer.AddSourceLocation(S->getRParenLoc(), Record);
1043   Code = serialization::STMT_OBJC_CATCH;
1044 }
1045 
1046 void ASTStmtWriter::VisitObjCAtFinallyStmt(ObjCAtFinallyStmt *S) {
1047   Writer.AddStmt(S->getFinallyBody());
1048   Writer.AddSourceLocation(S->getAtFinallyLoc(), Record);
1049   Code = serialization::STMT_OBJC_FINALLY;
1050 }
1051 
1052 void ASTStmtWriter::VisitObjCAutoreleasePoolStmt(ObjCAutoreleasePoolStmt *S) {
1053   Writer.AddStmt(S->getSubStmt());
1054   Writer.AddSourceLocation(S->getAtLoc(), Record);
1055   Code = serialization::STMT_OBJC_AUTORELEASE_POOL;
1056 }
1057 
1058 void ASTStmtWriter::VisitObjCAtTryStmt(ObjCAtTryStmt *S) {
1059   Record.push_back(S->getNumCatchStmts());
1060   Record.push_back(S->getFinallyStmt() != nullptr);
1061   Writer.AddStmt(S->getTryBody());
1062   for (unsigned I = 0, N = S->getNumCatchStmts(); I != N; ++I)
1063     Writer.AddStmt(S->getCatchStmt(I));
1064   if (S->getFinallyStmt())
1065     Writer.AddStmt(S->getFinallyStmt());
1066   Writer.AddSourceLocation(S->getAtTryLoc(), Record);
1067   Code = serialization::STMT_OBJC_AT_TRY;
1068 }
1069 
1070 void ASTStmtWriter::VisitObjCAtSynchronizedStmt(ObjCAtSynchronizedStmt *S) {
1071   Writer.AddStmt(S->getSynchExpr());
1072   Writer.AddStmt(S->getSynchBody());
1073   Writer.AddSourceLocation(S->getAtSynchronizedLoc(), Record);
1074   Code = serialization::STMT_OBJC_AT_SYNCHRONIZED;
1075 }
1076 
1077 void ASTStmtWriter::VisitObjCAtThrowStmt(ObjCAtThrowStmt *S) {
1078   Writer.AddStmt(S->getThrowExpr());
1079   Writer.AddSourceLocation(S->getThrowLoc(), Record);
1080   Code = serialization::STMT_OBJC_AT_THROW;
1081 }
1082 
1083 void ASTStmtWriter::VisitObjCBoolLiteralExpr(ObjCBoolLiteralExpr *E) {
1084   VisitExpr(E);
1085   Record.push_back(E->getValue());
1086   Writer.AddSourceLocation(E->getLocation(), Record);
1087   Code = serialization::EXPR_OBJC_BOOL_LITERAL;
1088 }
1089 
1090 //===----------------------------------------------------------------------===//
1091 // C++ Expressions and Statements.
1092 //===----------------------------------------------------------------------===//
1093 
1094 void ASTStmtWriter::VisitCXXCatchStmt(CXXCatchStmt *S) {
1095   VisitStmt(S);
1096   Writer.AddSourceLocation(S->getCatchLoc(), Record);
1097   Writer.AddDeclRef(S->getExceptionDecl(), Record);
1098   Writer.AddStmt(S->getHandlerBlock());
1099   Code = serialization::STMT_CXX_CATCH;
1100 }
1101 
1102 void ASTStmtWriter::VisitCXXTryStmt(CXXTryStmt *S) {
1103   VisitStmt(S);
1104   Record.push_back(S->getNumHandlers());
1105   Writer.AddSourceLocation(S->getTryLoc(), Record);
1106   Writer.AddStmt(S->getTryBlock());
1107   for (unsigned i = 0, e = S->getNumHandlers(); i != e; ++i)
1108     Writer.AddStmt(S->getHandler(i));
1109   Code = serialization::STMT_CXX_TRY;
1110 }
1111 
1112 void ASTStmtWriter::VisitCXXForRangeStmt(CXXForRangeStmt *S) {
1113   VisitStmt(S);
1114   Writer.AddSourceLocation(S->getForLoc(), Record);
1115   Writer.AddSourceLocation(S->getColonLoc(), Record);
1116   Writer.AddSourceLocation(S->getRParenLoc(), Record);
1117   Writer.AddStmt(S->getRangeStmt());
1118   Writer.AddStmt(S->getBeginEndStmt());
1119   Writer.AddStmt(S->getCond());
1120   Writer.AddStmt(S->getInc());
1121   Writer.AddStmt(S->getLoopVarStmt());
1122   Writer.AddStmt(S->getBody());
1123   Code = serialization::STMT_CXX_FOR_RANGE;
1124 }
1125 
1126 void ASTStmtWriter::VisitMSDependentExistsStmt(MSDependentExistsStmt *S) {
1127   VisitStmt(S);
1128   Writer.AddSourceLocation(S->getKeywordLoc(), Record);
1129   Record.push_back(S->isIfExists());
1130   Writer.AddNestedNameSpecifierLoc(S->getQualifierLoc(), Record);
1131   Writer.AddDeclarationNameInfo(S->getNameInfo(), Record);
1132   Writer.AddStmt(S->getSubStmt());
1133   Code = serialization::STMT_MS_DEPENDENT_EXISTS;
1134 }
1135 
1136 void ASTStmtWriter::VisitCXXOperatorCallExpr(CXXOperatorCallExpr *E) {
1137   VisitCallExpr(E);
1138   Record.push_back(E->getOperator());
1139   Writer.AddSourceRange(E->Range, Record);
1140   Record.push_back(E->isFPContractable());
1141   Code = serialization::EXPR_CXX_OPERATOR_CALL;
1142 }
1143 
1144 void ASTStmtWriter::VisitCXXMemberCallExpr(CXXMemberCallExpr *E) {
1145   VisitCallExpr(E);
1146   Code = serialization::EXPR_CXX_MEMBER_CALL;
1147 }
1148 
1149 void ASTStmtWriter::VisitCXXConstructExpr(CXXConstructExpr *E) {
1150   VisitExpr(E);
1151   Record.push_back(E->getNumArgs());
1152   for (unsigned I = 0, N = E->getNumArgs(); I != N; ++I)
1153     Writer.AddStmt(E->getArg(I));
1154   Writer.AddDeclRef(E->getConstructor(), Record);
1155   Writer.AddSourceLocation(E->getLocation(), Record);
1156   Record.push_back(E->isElidable());
1157   Record.push_back(E->hadMultipleCandidates());
1158   Record.push_back(E->isListInitialization());
1159   Record.push_back(E->isStdInitListInitialization());
1160   Record.push_back(E->requiresZeroInitialization());
1161   Record.push_back(E->getConstructionKind()); // FIXME: stable encoding
1162   Writer.AddSourceRange(E->getParenOrBraceRange(), Record);
1163   Code = serialization::EXPR_CXX_CONSTRUCT;
1164 }
1165 
1166 void ASTStmtWriter::VisitCXXTemporaryObjectExpr(CXXTemporaryObjectExpr *E) {
1167   VisitCXXConstructExpr(E);
1168   Writer.AddTypeSourceInfo(E->getTypeSourceInfo(), Record);
1169   Code = serialization::EXPR_CXX_TEMPORARY_OBJECT;
1170 }
1171 
1172 void ASTStmtWriter::VisitLambdaExpr(LambdaExpr *E) {
1173   VisitExpr(E);
1174   Record.push_back(E->NumCaptures);
1175   unsigned NumArrayIndexVars = 0;
1176   if (E->HasArrayIndexVars)
1177     NumArrayIndexVars = E->getArrayIndexStarts()[E->NumCaptures];
1178   Record.push_back(NumArrayIndexVars);
1179   Writer.AddSourceRange(E->IntroducerRange, Record);
1180   Record.push_back(E->CaptureDefault); // FIXME: stable encoding
1181   Writer.AddSourceLocation(E->CaptureDefaultLoc, Record);
1182   Record.push_back(E->ExplicitParams);
1183   Record.push_back(E->ExplicitResultType);
1184   Writer.AddSourceLocation(E->ClosingBrace, Record);
1185 
1186   // Add capture initializers.
1187   for (LambdaExpr::capture_init_iterator C = E->capture_init_begin(),
1188                                       CEnd = E->capture_init_end();
1189        C != CEnd; ++C) {
1190     Writer.AddStmt(*C);
1191   }
1192 
1193   // Add array index variables, if any.
1194   if (NumArrayIndexVars) {
1195     Record.append(E->getArrayIndexStarts(),
1196                   E->getArrayIndexStarts() + E->NumCaptures + 1);
1197     VarDecl **ArrayIndexVars = E->getArrayIndexVars();
1198     for (unsigned I = 0; I != NumArrayIndexVars; ++I)
1199       Writer.AddDeclRef(ArrayIndexVars[I], Record);
1200   }
1201 
1202   Code = serialization::EXPR_LAMBDA;
1203 }
1204 
1205 void ASTStmtWriter::VisitCXXStdInitializerListExpr(CXXStdInitializerListExpr *E) {
1206   VisitExpr(E);
1207   Writer.AddStmt(E->getSubExpr());
1208   Code = serialization::EXPR_CXX_STD_INITIALIZER_LIST;
1209 }
1210 
1211 void ASTStmtWriter::VisitCXXNamedCastExpr(CXXNamedCastExpr *E) {
1212   VisitExplicitCastExpr(E);
1213   Writer.AddSourceRange(SourceRange(E->getOperatorLoc(), E->getRParenLoc()),
1214                         Record);
1215   Writer.AddSourceRange(E->getAngleBrackets(), Record);
1216 }
1217 
1218 void ASTStmtWriter::VisitCXXStaticCastExpr(CXXStaticCastExpr *E) {
1219   VisitCXXNamedCastExpr(E);
1220   Code = serialization::EXPR_CXX_STATIC_CAST;
1221 }
1222 
1223 void ASTStmtWriter::VisitCXXDynamicCastExpr(CXXDynamicCastExpr *E) {
1224   VisitCXXNamedCastExpr(E);
1225   Code = serialization::EXPR_CXX_DYNAMIC_CAST;
1226 }
1227 
1228 void ASTStmtWriter::VisitCXXReinterpretCastExpr(CXXReinterpretCastExpr *E) {
1229   VisitCXXNamedCastExpr(E);
1230   Code = serialization::EXPR_CXX_REINTERPRET_CAST;
1231 }
1232 
1233 void ASTStmtWriter::VisitCXXConstCastExpr(CXXConstCastExpr *E) {
1234   VisitCXXNamedCastExpr(E);
1235   Code = serialization::EXPR_CXX_CONST_CAST;
1236 }
1237 
1238 void ASTStmtWriter::VisitCXXFunctionalCastExpr(CXXFunctionalCastExpr *E) {
1239   VisitExplicitCastExpr(E);
1240   Writer.AddSourceLocation(E->getLParenLoc(), Record);
1241   Writer.AddSourceLocation(E->getRParenLoc(), Record);
1242   Code = serialization::EXPR_CXX_FUNCTIONAL_CAST;
1243 }
1244 
1245 void ASTStmtWriter::VisitUserDefinedLiteral(UserDefinedLiteral *E) {
1246   VisitCallExpr(E);
1247   Writer.AddSourceLocation(E->UDSuffixLoc, Record);
1248   Code = serialization::EXPR_USER_DEFINED_LITERAL;
1249 }
1250 
1251 void ASTStmtWriter::VisitCXXBoolLiteralExpr(CXXBoolLiteralExpr *E) {
1252   VisitExpr(E);
1253   Record.push_back(E->getValue());
1254   Writer.AddSourceLocation(E->getLocation(), Record);
1255   Code = serialization::EXPR_CXX_BOOL_LITERAL;
1256 }
1257 
1258 void ASTStmtWriter::VisitCXXNullPtrLiteralExpr(CXXNullPtrLiteralExpr *E) {
1259   VisitExpr(E);
1260   Writer.AddSourceLocation(E->getLocation(), Record);
1261   Code = serialization::EXPR_CXX_NULL_PTR_LITERAL;
1262 }
1263 
1264 void ASTStmtWriter::VisitCXXTypeidExpr(CXXTypeidExpr *E) {
1265   VisitExpr(E);
1266   Writer.AddSourceRange(E->getSourceRange(), Record);
1267   if (E->isTypeOperand()) {
1268     Writer.AddTypeSourceInfo(E->getTypeOperandSourceInfo(), Record);
1269     Code = serialization::EXPR_CXX_TYPEID_TYPE;
1270   } else {
1271     Writer.AddStmt(E->getExprOperand());
1272     Code = serialization::EXPR_CXX_TYPEID_EXPR;
1273   }
1274 }
1275 
1276 void ASTStmtWriter::VisitCXXThisExpr(CXXThisExpr *E) {
1277   VisitExpr(E);
1278   Writer.AddSourceLocation(E->getLocation(), Record);
1279   Record.push_back(E->isImplicit());
1280   Code = serialization::EXPR_CXX_THIS;
1281 }
1282 
1283 void ASTStmtWriter::VisitCXXThrowExpr(CXXThrowExpr *E) {
1284   VisitExpr(E);
1285   Writer.AddSourceLocation(E->getThrowLoc(), Record);
1286   Writer.AddStmt(E->getSubExpr());
1287   Record.push_back(E->isThrownVariableInScope());
1288   Code = serialization::EXPR_CXX_THROW;
1289 }
1290 
1291 void ASTStmtWriter::VisitCXXDefaultArgExpr(CXXDefaultArgExpr *E) {
1292   VisitExpr(E);
1293 
1294   bool HasOtherExprStored = E->Param.getInt();
1295   // Store these first, the reader reads them before creation.
1296   Record.push_back(HasOtherExprStored);
1297   if (HasOtherExprStored)
1298     Writer.AddStmt(E->getExpr());
1299   Writer.AddDeclRef(E->getParam(), Record);
1300   Writer.AddSourceLocation(E->getUsedLocation(), Record);
1301 
1302   Code = serialization::EXPR_CXX_DEFAULT_ARG;
1303 }
1304 
1305 void ASTStmtWriter::VisitCXXDefaultInitExpr(CXXDefaultInitExpr *E) {
1306   VisitExpr(E);
1307   Writer.AddDeclRef(E->getField(), Record);
1308   Writer.AddSourceLocation(E->getExprLoc(), Record);
1309   Code = serialization::EXPR_CXX_DEFAULT_INIT;
1310 }
1311 
1312 void ASTStmtWriter::VisitCXXBindTemporaryExpr(CXXBindTemporaryExpr *E) {
1313   VisitExpr(E);
1314   Writer.AddCXXTemporary(E->getTemporary(), Record);
1315   Writer.AddStmt(E->getSubExpr());
1316   Code = serialization::EXPR_CXX_BIND_TEMPORARY;
1317 }
1318 
1319 void ASTStmtWriter::VisitCXXScalarValueInitExpr(CXXScalarValueInitExpr *E) {
1320   VisitExpr(E);
1321   Writer.AddTypeSourceInfo(E->getTypeSourceInfo(), Record);
1322   Writer.AddSourceLocation(E->getRParenLoc(), Record);
1323   Code = serialization::EXPR_CXX_SCALAR_VALUE_INIT;
1324 }
1325 
1326 void ASTStmtWriter::VisitCXXNewExpr(CXXNewExpr *E) {
1327   VisitExpr(E);
1328   Record.push_back(E->isGlobalNew());
1329   Record.push_back(E->isArray());
1330   Record.push_back(E->doesUsualArrayDeleteWantSize());
1331   Record.push_back(E->getNumPlacementArgs());
1332   Record.push_back(E->StoredInitializationStyle);
1333   Writer.AddDeclRef(E->getOperatorNew(), Record);
1334   Writer.AddDeclRef(E->getOperatorDelete(), Record);
1335   Writer.AddTypeSourceInfo(E->getAllocatedTypeSourceInfo(), Record);
1336   Writer.AddSourceRange(E->getTypeIdParens(), Record);
1337   Writer.AddSourceRange(E->getSourceRange(), Record);
1338   Writer.AddSourceRange(E->getDirectInitRange(), Record);
1339   for (CXXNewExpr::arg_iterator I = E->raw_arg_begin(), e = E->raw_arg_end();
1340        I != e; ++I)
1341     Writer.AddStmt(*I);
1342 
1343   Code = serialization::EXPR_CXX_NEW;
1344 }
1345 
1346 void ASTStmtWriter::VisitCXXDeleteExpr(CXXDeleteExpr *E) {
1347   VisitExpr(E);
1348   Record.push_back(E->isGlobalDelete());
1349   Record.push_back(E->isArrayForm());
1350   Record.push_back(E->isArrayFormAsWritten());
1351   Record.push_back(E->doesUsualArrayDeleteWantSize());
1352   Writer.AddDeclRef(E->getOperatorDelete(), Record);
1353   Writer.AddStmt(E->getArgument());
1354   Writer.AddSourceLocation(E->getSourceRange().getBegin(), Record);
1355 
1356   Code = serialization::EXPR_CXX_DELETE;
1357 }
1358 
1359 void ASTStmtWriter::VisitCXXPseudoDestructorExpr(CXXPseudoDestructorExpr *E) {
1360   VisitExpr(E);
1361 
1362   Writer.AddStmt(E->getBase());
1363   Record.push_back(E->isArrow());
1364   Writer.AddSourceLocation(E->getOperatorLoc(), Record);
1365   Writer.AddNestedNameSpecifierLoc(E->getQualifierLoc(), Record);
1366   Writer.AddTypeSourceInfo(E->getScopeTypeInfo(), Record);
1367   Writer.AddSourceLocation(E->getColonColonLoc(), Record);
1368   Writer.AddSourceLocation(E->getTildeLoc(), Record);
1369 
1370   // PseudoDestructorTypeStorage.
1371   Writer.AddIdentifierRef(E->getDestroyedTypeIdentifier(), Record);
1372   if (E->getDestroyedTypeIdentifier())
1373     Writer.AddSourceLocation(E->getDestroyedTypeLoc(), Record);
1374   else
1375     Writer.AddTypeSourceInfo(E->getDestroyedTypeInfo(), Record);
1376 
1377   Code = serialization::EXPR_CXX_PSEUDO_DESTRUCTOR;
1378 }
1379 
1380 void ASTStmtWriter::VisitExprWithCleanups(ExprWithCleanups *E) {
1381   VisitExpr(E);
1382   Record.push_back(E->getNumObjects());
1383   for (unsigned i = 0, e = E->getNumObjects(); i != e; ++i)
1384     Writer.AddDeclRef(E->getObject(i), Record);
1385 
1386   Writer.AddStmt(E->getSubExpr());
1387   Code = serialization::EXPR_EXPR_WITH_CLEANUPS;
1388 }
1389 
1390 void
1391 ASTStmtWriter::VisitCXXDependentScopeMemberExpr(CXXDependentScopeMemberExpr *E){
1392   VisitExpr(E);
1393 
1394   // Don't emit anything here, HasTemplateKWAndArgsInfo must be
1395   // emitted first.
1396 
1397   Record.push_back(E->HasTemplateKWAndArgsInfo);
1398   if (E->HasTemplateKWAndArgsInfo) {
1399     const ASTTemplateKWAndArgsInfo &Args = *E->getTemplateKWAndArgsInfo();
1400     Record.push_back(Args.NumTemplateArgs);
1401     AddTemplateKWAndArgsInfo(Args);
1402   }
1403 
1404   if (!E->isImplicitAccess())
1405     Writer.AddStmt(E->getBase());
1406   else
1407     Writer.AddStmt(nullptr);
1408   Writer.AddTypeRef(E->getBaseType(), Record);
1409   Record.push_back(E->isArrow());
1410   Writer.AddSourceLocation(E->getOperatorLoc(), Record);
1411   Writer.AddNestedNameSpecifierLoc(E->getQualifierLoc(), Record);
1412   Writer.AddDeclRef(E->getFirstQualifierFoundInScope(), Record);
1413   Writer.AddDeclarationNameInfo(E->MemberNameInfo, Record);
1414   Code = serialization::EXPR_CXX_DEPENDENT_SCOPE_MEMBER;
1415 }
1416 
1417 void
1418 ASTStmtWriter::VisitDependentScopeDeclRefExpr(DependentScopeDeclRefExpr *E) {
1419   VisitExpr(E);
1420 
1421   // Don't emit anything here, HasTemplateKWAndArgsInfo must be
1422   // emitted first.
1423 
1424   Record.push_back(E->HasTemplateKWAndArgsInfo);
1425   if (E->HasTemplateKWAndArgsInfo) {
1426     const ASTTemplateKWAndArgsInfo &Args = *E->getTemplateKWAndArgsInfo();
1427     Record.push_back(Args.NumTemplateArgs);
1428     AddTemplateKWAndArgsInfo(Args);
1429   }
1430 
1431   Writer.AddNestedNameSpecifierLoc(E->getQualifierLoc(), Record);
1432   Writer.AddDeclarationNameInfo(E->NameInfo, Record);
1433   Code = serialization::EXPR_CXX_DEPENDENT_SCOPE_DECL_REF;
1434 }
1435 
1436 void
1437 ASTStmtWriter::VisitCXXUnresolvedConstructExpr(CXXUnresolvedConstructExpr *E) {
1438   VisitExpr(E);
1439   Record.push_back(E->arg_size());
1440   for (CXXUnresolvedConstructExpr::arg_iterator
1441          ArgI = E->arg_begin(), ArgE = E->arg_end(); ArgI != ArgE; ++ArgI)
1442     Writer.AddStmt(*ArgI);
1443   Writer.AddTypeSourceInfo(E->getTypeSourceInfo(), Record);
1444   Writer.AddSourceLocation(E->getLParenLoc(), Record);
1445   Writer.AddSourceLocation(E->getRParenLoc(), Record);
1446   Code = serialization::EXPR_CXX_UNRESOLVED_CONSTRUCT;
1447 }
1448 
1449 void ASTStmtWriter::VisitOverloadExpr(OverloadExpr *E) {
1450   VisitExpr(E);
1451 
1452   // Don't emit anything here, HasTemplateKWAndArgsInfo must be
1453   // emitted first.
1454 
1455   Record.push_back(E->HasTemplateKWAndArgsInfo);
1456   if (E->HasTemplateKWAndArgsInfo) {
1457     const ASTTemplateKWAndArgsInfo &Args = *E->getTemplateKWAndArgsInfo();
1458     Record.push_back(Args.NumTemplateArgs);
1459     AddTemplateKWAndArgsInfo(Args);
1460   }
1461 
1462   Record.push_back(E->getNumDecls());
1463   for (OverloadExpr::decls_iterator
1464          OvI = E->decls_begin(), OvE = E->decls_end(); OvI != OvE; ++OvI) {
1465     Writer.AddDeclRef(OvI.getDecl(), Record);
1466     Record.push_back(OvI.getAccess());
1467   }
1468 
1469   Writer.AddDeclarationNameInfo(E->NameInfo, Record);
1470   Writer.AddNestedNameSpecifierLoc(E->getQualifierLoc(), Record);
1471 }
1472 
1473 void ASTStmtWriter::VisitUnresolvedMemberExpr(UnresolvedMemberExpr *E) {
1474   VisitOverloadExpr(E);
1475   Record.push_back(E->isArrow());
1476   Record.push_back(E->hasUnresolvedUsing());
1477   Writer.AddStmt(!E->isImplicitAccess() ? E->getBase() : nullptr);
1478   Writer.AddTypeRef(E->getBaseType(), Record);
1479   Writer.AddSourceLocation(E->getOperatorLoc(), Record);
1480   Code = serialization::EXPR_CXX_UNRESOLVED_MEMBER;
1481 }
1482 
1483 void ASTStmtWriter::VisitUnresolvedLookupExpr(UnresolvedLookupExpr *E) {
1484   VisitOverloadExpr(E);
1485   Record.push_back(E->requiresADL());
1486   Record.push_back(E->isOverloaded());
1487   Writer.AddDeclRef(E->getNamingClass(), Record);
1488   Code = serialization::EXPR_CXX_UNRESOLVED_LOOKUP;
1489 }
1490 
1491 void ASTStmtWriter::VisitTypeTraitExpr(TypeTraitExpr *E) {
1492   VisitExpr(E);
1493   Record.push_back(E->TypeTraitExprBits.NumArgs);
1494   Record.push_back(E->TypeTraitExprBits.Kind); // FIXME: Stable encoding
1495   Record.push_back(E->TypeTraitExprBits.Value);
1496   Writer.AddSourceRange(E->getSourceRange(), Record);
1497   for (unsigned I = 0, N = E->getNumArgs(); I != N; ++I)
1498     Writer.AddTypeSourceInfo(E->getArg(I), Record);
1499   Code = serialization::EXPR_TYPE_TRAIT;
1500 }
1501 
1502 void ASTStmtWriter::VisitArrayTypeTraitExpr(ArrayTypeTraitExpr *E) {
1503   VisitExpr(E);
1504   Record.push_back(E->getTrait());
1505   Record.push_back(E->getValue());
1506   Writer.AddSourceRange(E->getSourceRange(), Record);
1507   Writer.AddTypeSourceInfo(E->getQueriedTypeSourceInfo(), Record);
1508   Code = serialization::EXPR_ARRAY_TYPE_TRAIT;
1509 }
1510 
1511 void ASTStmtWriter::VisitExpressionTraitExpr(ExpressionTraitExpr *E) {
1512   VisitExpr(E);
1513   Record.push_back(E->getTrait());
1514   Record.push_back(E->getValue());
1515   Writer.AddSourceRange(E->getSourceRange(), Record);
1516   Writer.AddStmt(E->getQueriedExpression());
1517   Code = serialization::EXPR_CXX_EXPRESSION_TRAIT;
1518 }
1519 
1520 void ASTStmtWriter::VisitCXXNoexceptExpr(CXXNoexceptExpr *E) {
1521   VisitExpr(E);
1522   Record.push_back(E->getValue());
1523   Writer.AddSourceRange(E->getSourceRange(), Record);
1524   Writer.AddStmt(E->getOperand());
1525   Code = serialization::EXPR_CXX_NOEXCEPT;
1526 }
1527 
1528 void ASTStmtWriter::VisitPackExpansionExpr(PackExpansionExpr *E) {
1529   VisitExpr(E);
1530   Writer.AddSourceLocation(E->getEllipsisLoc(), Record);
1531   Record.push_back(E->NumExpansions);
1532   Writer.AddStmt(E->getPattern());
1533   Code = serialization::EXPR_PACK_EXPANSION;
1534 }
1535 
1536 void ASTStmtWriter::VisitSizeOfPackExpr(SizeOfPackExpr *E) {
1537   VisitExpr(E);
1538   Writer.AddSourceLocation(E->OperatorLoc, Record);
1539   Writer.AddSourceLocation(E->PackLoc, Record);
1540   Writer.AddSourceLocation(E->RParenLoc, Record);
1541   Record.push_back(E->Length);
1542   Writer.AddDeclRef(E->Pack, Record);
1543   Code = serialization::EXPR_SIZEOF_PACK;
1544 }
1545 
1546 void ASTStmtWriter::VisitSubstNonTypeTemplateParmExpr(
1547                                               SubstNonTypeTemplateParmExpr *E) {
1548   VisitExpr(E);
1549   Writer.AddDeclRef(E->getParameter(), Record);
1550   Writer.AddSourceLocation(E->getNameLoc(), Record);
1551   Writer.AddStmt(E->getReplacement());
1552   Code = serialization::EXPR_SUBST_NON_TYPE_TEMPLATE_PARM;
1553 }
1554 
1555 void ASTStmtWriter::VisitSubstNonTypeTemplateParmPackExpr(
1556                                           SubstNonTypeTemplateParmPackExpr *E) {
1557   VisitExpr(E);
1558   Writer.AddDeclRef(E->getParameterPack(), Record);
1559   Writer.AddTemplateArgument(E->getArgumentPack(), Record);
1560   Writer.AddSourceLocation(E->getParameterPackLocation(), Record);
1561   Code = serialization::EXPR_SUBST_NON_TYPE_TEMPLATE_PARM_PACK;
1562 }
1563 
1564 void ASTStmtWriter::VisitFunctionParmPackExpr(FunctionParmPackExpr *E) {
1565   VisitExpr(E);
1566   Record.push_back(E->getNumExpansions());
1567   Writer.AddDeclRef(E->getParameterPack(), Record);
1568   Writer.AddSourceLocation(E->getParameterPackLocation(), Record);
1569   for (FunctionParmPackExpr::iterator I = E->begin(), End = E->end();
1570        I != End; ++I)
1571     Writer.AddDeclRef(*I, Record);
1572   Code = serialization::EXPR_FUNCTION_PARM_PACK;
1573 }
1574 
1575 void ASTStmtWriter::VisitMaterializeTemporaryExpr(MaterializeTemporaryExpr *E) {
1576   VisitExpr(E);
1577   Writer.AddStmt(E->getTemporary());
1578   Writer.AddDeclRef(E->getExtendingDecl(), Record);
1579   Record.push_back(E->getManglingNumber());
1580   Code = serialization::EXPR_MATERIALIZE_TEMPORARY;
1581 }
1582 
1583 void ASTStmtWriter::VisitOpaqueValueExpr(OpaqueValueExpr *E) {
1584   VisitExpr(E);
1585   Writer.AddStmt(E->getSourceExpr());
1586   Writer.AddSourceLocation(E->getLocation(), Record);
1587   Code = serialization::EXPR_OPAQUE_VALUE;
1588 }
1589 
1590 //===----------------------------------------------------------------------===//
1591 // CUDA Expressions and Statements.
1592 //===----------------------------------------------------------------------===//
1593 
1594 void ASTStmtWriter::VisitCUDAKernelCallExpr(CUDAKernelCallExpr *E) {
1595   VisitCallExpr(E);
1596   Writer.AddStmt(E->getConfig());
1597   Code = serialization::EXPR_CUDA_KERNEL_CALL;
1598 }
1599 
1600 //===----------------------------------------------------------------------===//
1601 // OpenCL Expressions and Statements.
1602 //===----------------------------------------------------------------------===//
1603 void ASTStmtWriter::VisitAsTypeExpr(AsTypeExpr *E) {
1604   VisitExpr(E);
1605   Writer.AddSourceLocation(E->getBuiltinLoc(), Record);
1606   Writer.AddSourceLocation(E->getRParenLoc(), Record);
1607   Writer.AddStmt(E->getSrcExpr());
1608   Code = serialization::EXPR_ASTYPE;
1609 }
1610 
1611 //===----------------------------------------------------------------------===//
1612 // Microsoft Expressions and Statements.
1613 //===----------------------------------------------------------------------===//
1614 void ASTStmtWriter::VisitMSPropertyRefExpr(MSPropertyRefExpr *E) {
1615   VisitExpr(E);
1616   Record.push_back(E->isArrow());
1617   Writer.AddStmt(E->getBaseExpr());
1618   Writer.AddNestedNameSpecifierLoc(E->getQualifierLoc(), Record);
1619   Writer.AddSourceLocation(E->getMemberLoc(), Record);
1620   Writer.AddDeclRef(E->getPropertyDecl(), Record);
1621   Code = serialization::EXPR_CXX_PROPERTY_REF_EXPR;
1622 }
1623 
1624 void ASTStmtWriter::VisitCXXUuidofExpr(CXXUuidofExpr *E) {
1625   VisitExpr(E);
1626   Writer.AddSourceRange(E->getSourceRange(), Record);
1627   if (E->isTypeOperand()) {
1628     Writer.AddTypeSourceInfo(E->getTypeOperandSourceInfo(), Record);
1629     Code = serialization::EXPR_CXX_UUIDOF_TYPE;
1630   } else {
1631     Writer.AddStmt(E->getExprOperand());
1632     Code = serialization::EXPR_CXX_UUIDOF_EXPR;
1633   }
1634 }
1635 
1636 void ASTStmtWriter::VisitSEHExceptStmt(SEHExceptStmt *S) {
1637   VisitStmt(S);
1638   Writer.AddSourceLocation(S->getExceptLoc(), Record);
1639   Writer.AddStmt(S->getFilterExpr());
1640   Writer.AddStmt(S->getBlock());
1641   Code = serialization::STMT_SEH_EXCEPT;
1642 }
1643 
1644 void ASTStmtWriter::VisitSEHFinallyStmt(SEHFinallyStmt *S) {
1645   VisitStmt(S);
1646   Writer.AddSourceLocation(S->getFinallyLoc(), Record);
1647   Writer.AddStmt(S->getBlock());
1648   Code = serialization::STMT_SEH_FINALLY;
1649 }
1650 
1651 void ASTStmtWriter::VisitSEHTryStmt(SEHTryStmt *S) {
1652   VisitStmt(S);
1653   Record.push_back(S->getIsCXXTry());
1654   Writer.AddSourceLocation(S->getTryLoc(), Record);
1655   Writer.AddStmt(S->getTryBlock());
1656   Writer.AddStmt(S->getHandler());
1657   Code = serialization::STMT_SEH_TRY;
1658 }
1659 
1660 void ASTStmtWriter::VisitSEHLeaveStmt(SEHLeaveStmt *S) {
1661   VisitStmt(S);
1662   Writer.AddSourceLocation(S->getLeaveLoc(), Record);
1663   Code = serialization::STMT_SEH_LEAVE;
1664 }
1665 
1666 //===----------------------------------------------------------------------===//
1667 // OpenMP Clauses.
1668 //===----------------------------------------------------------------------===//
1669 
1670 namespace clang {
1671 class OMPClauseWriter : public OMPClauseVisitor<OMPClauseWriter> {
1672   ASTStmtWriter *Writer;
1673   ASTWriter::RecordData &Record;
1674 public:
1675   OMPClauseWriter(ASTStmtWriter *W, ASTWriter::RecordData &Record)
1676     : Writer(W), Record(Record) { }
1677 #define OPENMP_CLAUSE(Name, Class)    \
1678   void Visit##Class(Class *S);
1679 #include "clang/Basic/OpenMPKinds.def"
1680   void writeClause(OMPClause *C);
1681 };
1682 }
1683 
1684 void OMPClauseWriter::writeClause(OMPClause *C) {
1685   Record.push_back(C->getClauseKind());
1686   Visit(C);
1687   Writer->Writer.AddSourceLocation(C->getLocStart(), Record);
1688   Writer->Writer.AddSourceLocation(C->getLocEnd(), Record);
1689 }
1690 
1691 void OMPClauseWriter::VisitOMPIfClause(OMPIfClause *C) {
1692   Writer->Writer.AddStmt(C->getCondition());
1693   Writer->Writer.AddSourceLocation(C->getLParenLoc(), Record);
1694 }
1695 
1696 void OMPClauseWriter::VisitOMPFinalClause(OMPFinalClause *C) {
1697   Writer->Writer.AddStmt(C->getCondition());
1698   Writer->Writer.AddSourceLocation(C->getLParenLoc(), Record);
1699 }
1700 
1701 void OMPClauseWriter::VisitOMPNumThreadsClause(OMPNumThreadsClause *C) {
1702   Writer->Writer.AddStmt(C->getNumThreads());
1703   Writer->Writer.AddSourceLocation(C->getLParenLoc(), Record);
1704 }
1705 
1706 void OMPClauseWriter::VisitOMPSafelenClause(OMPSafelenClause *C) {
1707   Writer->Writer.AddStmt(C->getSafelen());
1708   Writer->Writer.AddSourceLocation(C->getLParenLoc(), Record);
1709 }
1710 
1711 void OMPClauseWriter::VisitOMPCollapseClause(OMPCollapseClause *C) {
1712   Writer->Writer.AddStmt(C->getNumForLoops());
1713   Writer->Writer.AddSourceLocation(C->getLParenLoc(), Record);
1714 }
1715 
1716 void OMPClauseWriter::VisitOMPDefaultClause(OMPDefaultClause *C) {
1717   Record.push_back(C->getDefaultKind());
1718   Writer->Writer.AddSourceLocation(C->getLParenLoc(), Record);
1719   Writer->Writer.AddSourceLocation(C->getDefaultKindKwLoc(), Record);
1720 }
1721 
1722 void OMPClauseWriter::VisitOMPProcBindClause(OMPProcBindClause *C) {
1723   Record.push_back(C->getProcBindKind());
1724   Writer->Writer.AddSourceLocation(C->getLParenLoc(), Record);
1725   Writer->Writer.AddSourceLocation(C->getProcBindKindKwLoc(), Record);
1726 }
1727 
1728 void OMPClauseWriter::VisitOMPScheduleClause(OMPScheduleClause *C) {
1729   Record.push_back(C->getScheduleKind());
1730   Writer->Writer.AddStmt(C->getChunkSize());
1731   Writer->Writer.AddSourceLocation(C->getLParenLoc(), Record);
1732   Writer->Writer.AddSourceLocation(C->getScheduleKindLoc(), Record);
1733   Writer->Writer.AddSourceLocation(C->getCommaLoc(), Record);
1734 }
1735 
1736 void OMPClauseWriter::VisitOMPOrderedClause(OMPOrderedClause *) {}
1737 
1738 void OMPClauseWriter::VisitOMPNowaitClause(OMPNowaitClause *) {}
1739 
1740 void OMPClauseWriter::VisitOMPUntiedClause(OMPUntiedClause *) {}
1741 
1742 void OMPClauseWriter::VisitOMPMergeableClause(OMPMergeableClause *) {}
1743 
1744 void OMPClauseWriter::VisitOMPReadClause(OMPReadClause *) {}
1745 
1746 void OMPClauseWriter::VisitOMPWriteClause(OMPWriteClause *) {}
1747 
1748 void OMPClauseWriter::VisitOMPUpdateClause(OMPUpdateClause *) {}
1749 
1750 void OMPClauseWriter::VisitOMPCaptureClause(OMPCaptureClause *) {}
1751 
1752 void OMPClauseWriter::VisitOMPSeqCstClause(OMPSeqCstClause *) {}
1753 
1754 void OMPClauseWriter::VisitOMPPrivateClause(OMPPrivateClause *C) {
1755   Record.push_back(C->varlist_size());
1756   Writer->Writer.AddSourceLocation(C->getLParenLoc(), Record);
1757   for (auto *VE : C->varlists())
1758     Writer->Writer.AddStmt(VE);
1759 }
1760 
1761 void OMPClauseWriter::VisitOMPFirstprivateClause(OMPFirstprivateClause *C) {
1762   Record.push_back(C->varlist_size());
1763   Writer->Writer.AddSourceLocation(C->getLParenLoc(), Record);
1764   for (auto *VE : C->varlists())
1765     Writer->Writer.AddStmt(VE);
1766 }
1767 
1768 void OMPClauseWriter::VisitOMPLastprivateClause(OMPLastprivateClause *C) {
1769   Record.push_back(C->varlist_size());
1770   Writer->Writer.AddSourceLocation(C->getLParenLoc(), Record);
1771   for (auto *VE : C->varlists())
1772     Writer->Writer.AddStmt(VE);
1773 }
1774 
1775 void OMPClauseWriter::VisitOMPSharedClause(OMPSharedClause *C) {
1776   Record.push_back(C->varlist_size());
1777   Writer->Writer.AddSourceLocation(C->getLParenLoc(), Record);
1778   for (auto *VE : C->varlists())
1779     Writer->Writer.AddStmt(VE);
1780 }
1781 
1782 void OMPClauseWriter::VisitOMPReductionClause(OMPReductionClause *C) {
1783   Record.push_back(C->varlist_size());
1784   Writer->Writer.AddSourceLocation(C->getLParenLoc(), Record);
1785   Writer->Writer.AddSourceLocation(C->getColonLoc(), Record);
1786   Writer->Writer.AddNestedNameSpecifierLoc(C->getQualifierLoc(), Record);
1787   Writer->Writer.AddDeclarationNameInfo(C->getNameInfo(), Record);
1788   for (auto *VE : C->varlists())
1789     Writer->Writer.AddStmt(VE);
1790 }
1791 
1792 void OMPClauseWriter::VisitOMPLinearClause(OMPLinearClause *C) {
1793   Record.push_back(C->varlist_size());
1794   Writer->Writer.AddSourceLocation(C->getLParenLoc(), Record);
1795   Writer->Writer.AddSourceLocation(C->getColonLoc(), Record);
1796   for (auto *VE : C->varlists())
1797     Writer->Writer.AddStmt(VE);
1798   Writer->Writer.AddStmt(C->getStep());
1799 }
1800 
1801 void OMPClauseWriter::VisitOMPAlignedClause(OMPAlignedClause *C) {
1802   Record.push_back(C->varlist_size());
1803   Writer->Writer.AddSourceLocation(C->getLParenLoc(), Record);
1804   Writer->Writer.AddSourceLocation(C->getColonLoc(), Record);
1805   for (auto *VE : C->varlists())
1806     Writer->Writer.AddStmt(VE);
1807   Writer->Writer.AddStmt(C->getAlignment());
1808 }
1809 
1810 void OMPClauseWriter::VisitOMPCopyinClause(OMPCopyinClause *C) {
1811   Record.push_back(C->varlist_size());
1812   Writer->Writer.AddSourceLocation(C->getLParenLoc(), Record);
1813   for (auto *VE : C->varlists())
1814     Writer->Writer.AddStmt(VE);
1815 }
1816 
1817 void OMPClauseWriter::VisitOMPCopyprivateClause(OMPCopyprivateClause *C) {
1818   Record.push_back(C->varlist_size());
1819   Writer->Writer.AddSourceLocation(C->getLParenLoc(), Record);
1820   for (auto *VE : C->varlists())
1821     Writer->Writer.AddStmt(VE);
1822 }
1823 
1824 void OMPClauseWriter::VisitOMPFlushClause(OMPFlushClause *C) {
1825   Record.push_back(C->varlist_size());
1826   Writer->Writer.AddSourceLocation(C->getLParenLoc(), Record);
1827   for (auto *VE : C->varlists())
1828     Writer->Writer.AddStmt(VE);
1829 }
1830 
1831 //===----------------------------------------------------------------------===//
1832 // OpenMP Directives.
1833 //===----------------------------------------------------------------------===//
1834 void ASTStmtWriter::VisitOMPExecutableDirective(OMPExecutableDirective *E) {
1835   Writer.AddSourceLocation(E->getLocStart(), Record);
1836   Writer.AddSourceLocation(E->getLocEnd(), Record);
1837   OMPClauseWriter ClauseWriter(this, Record);
1838   for (unsigned i = 0; i < E->getNumClauses(); ++i) {
1839     ClauseWriter.writeClause(E->getClause(i));
1840   }
1841   if (E->hasAssociatedStmt())
1842     Writer.AddStmt(E->getAssociatedStmt());
1843 }
1844 
1845 void ASTStmtWriter::VisitOMPLoopDirective(OMPLoopDirective *D) {
1846   VisitStmt(D);
1847   Record.push_back(D->getNumClauses());
1848   Record.push_back(D->getCollapsedNumber());
1849   VisitOMPExecutableDirective(D);
1850 }
1851 
1852 void ASTStmtWriter::VisitOMPParallelDirective(OMPParallelDirective *D) {
1853   VisitStmt(D);
1854   Record.push_back(D->getNumClauses());
1855   VisitOMPExecutableDirective(D);
1856   Code = serialization::STMT_OMP_PARALLEL_DIRECTIVE;
1857 }
1858 
1859 void ASTStmtWriter::VisitOMPSimdDirective(OMPSimdDirective *D) {
1860   VisitOMPLoopDirective(D);
1861   Code = serialization::STMT_OMP_SIMD_DIRECTIVE;
1862 }
1863 
1864 void ASTStmtWriter::VisitOMPForDirective(OMPForDirective *D) {
1865   VisitOMPLoopDirective(D);
1866   Code = serialization::STMT_OMP_FOR_DIRECTIVE;
1867 }
1868 
1869 void ASTStmtWriter::VisitOMPSectionsDirective(OMPSectionsDirective *D) {
1870   VisitStmt(D);
1871   Record.push_back(D->getNumClauses());
1872   VisitOMPExecutableDirective(D);
1873   Code = serialization::STMT_OMP_SECTIONS_DIRECTIVE;
1874 }
1875 
1876 void ASTStmtWriter::VisitOMPSectionDirective(OMPSectionDirective *D) {
1877   VisitStmt(D);
1878   VisitOMPExecutableDirective(D);
1879   Code = serialization::STMT_OMP_SECTION_DIRECTIVE;
1880 }
1881 
1882 void ASTStmtWriter::VisitOMPSingleDirective(OMPSingleDirective *D) {
1883   VisitStmt(D);
1884   Record.push_back(D->getNumClauses());
1885   VisitOMPExecutableDirective(D);
1886   Code = serialization::STMT_OMP_SINGLE_DIRECTIVE;
1887 }
1888 
1889 void ASTStmtWriter::VisitOMPMasterDirective(OMPMasterDirective *D) {
1890   VisitStmt(D);
1891   VisitOMPExecutableDirective(D);
1892   Code = serialization::STMT_OMP_MASTER_DIRECTIVE;
1893 }
1894 
1895 void ASTStmtWriter::VisitOMPCriticalDirective(OMPCriticalDirective *D) {
1896   VisitStmt(D);
1897   VisitOMPExecutableDirective(D);
1898   Writer.AddDeclarationNameInfo(D->getDirectiveName(), Record);
1899   Code = serialization::STMT_OMP_CRITICAL_DIRECTIVE;
1900 }
1901 
1902 void ASTStmtWriter::VisitOMPParallelForDirective(OMPParallelForDirective *D) {
1903   VisitOMPLoopDirective(D);
1904   Code = serialization::STMT_OMP_PARALLEL_FOR_DIRECTIVE;
1905 }
1906 
1907 void ASTStmtWriter::VisitOMPParallelSectionsDirective(
1908     OMPParallelSectionsDirective *D) {
1909   VisitStmt(D);
1910   Record.push_back(D->getNumClauses());
1911   VisitOMPExecutableDirective(D);
1912   Code = serialization::STMT_OMP_PARALLEL_SECTIONS_DIRECTIVE;
1913 }
1914 
1915 void ASTStmtWriter::VisitOMPTaskDirective(OMPTaskDirective *D) {
1916   VisitStmt(D);
1917   Record.push_back(D->getNumClauses());
1918   VisitOMPExecutableDirective(D);
1919   Code = serialization::STMT_OMP_TASK_DIRECTIVE;
1920 }
1921 
1922 void ASTStmtWriter::VisitOMPAtomicDirective(OMPAtomicDirective *D) {
1923   VisitStmt(D);
1924   Record.push_back(D->getNumClauses());
1925   VisitOMPExecutableDirective(D);
1926   Code = serialization::STMT_OMP_ATOMIC_DIRECTIVE;
1927 }
1928 
1929 void ASTStmtWriter::VisitOMPTaskyieldDirective(OMPTaskyieldDirective *D) {
1930   VisitStmt(D);
1931   VisitOMPExecutableDirective(D);
1932   Code = serialization::STMT_OMP_TASKYIELD_DIRECTIVE;
1933 }
1934 
1935 void ASTStmtWriter::VisitOMPBarrierDirective(OMPBarrierDirective *D) {
1936   VisitStmt(D);
1937   VisitOMPExecutableDirective(D);
1938   Code = serialization::STMT_OMP_BARRIER_DIRECTIVE;
1939 }
1940 
1941 void ASTStmtWriter::VisitOMPTaskwaitDirective(OMPTaskwaitDirective *D) {
1942   VisitStmt(D);
1943   VisitOMPExecutableDirective(D);
1944   Code = serialization::STMT_OMP_TASKWAIT_DIRECTIVE;
1945 }
1946 
1947 void ASTStmtWriter::VisitOMPFlushDirective(OMPFlushDirective *D) {
1948   VisitStmt(D);
1949   Record.push_back(D->getNumClauses());
1950   VisitOMPExecutableDirective(D);
1951   Code = serialization::STMT_OMP_FLUSH_DIRECTIVE;
1952 }
1953 
1954 void ASTStmtWriter::VisitOMPOrderedDirective(OMPOrderedDirective *D) {
1955   VisitStmt(D);
1956   VisitOMPExecutableDirective(D);
1957   Code = serialization::STMT_OMP_ORDERED_DIRECTIVE;
1958 }
1959 
1960 //===----------------------------------------------------------------------===//
1961 // ASTWriter Implementation
1962 //===----------------------------------------------------------------------===//
1963 
1964 unsigned ASTWriter::RecordSwitchCaseID(SwitchCase *S) {
1965   assert(SwitchCaseIDs.find(S) == SwitchCaseIDs.end() &&
1966          "SwitchCase recorded twice");
1967   unsigned NextID = SwitchCaseIDs.size();
1968   SwitchCaseIDs[S] = NextID;
1969   return NextID;
1970 }
1971 
1972 unsigned ASTWriter::getSwitchCaseID(SwitchCase *S) {
1973   assert(SwitchCaseIDs.find(S) != SwitchCaseIDs.end() &&
1974          "SwitchCase hasn't been seen yet");
1975   return SwitchCaseIDs[S];
1976 }
1977 
1978 void ASTWriter::ClearSwitchCaseIDs() {
1979   SwitchCaseIDs.clear();
1980 }
1981 
1982 /// \brief Write the given substatement or subexpression to the
1983 /// bitstream.
1984 void ASTWriter::WriteSubStmt(Stmt *S,
1985                              llvm::DenseMap<Stmt *, uint64_t> &SubStmtEntries,
1986                              llvm::DenseSet<Stmt *> &ParentStmts) {
1987   RecordData Record;
1988   ASTStmtWriter Writer(*this, Record);
1989   ++NumStatements;
1990 
1991   if (!S) {
1992     Stream.EmitRecord(serialization::STMT_NULL_PTR, Record);
1993     return;
1994   }
1995 
1996   llvm::DenseMap<Stmt *, uint64_t>::iterator I = SubStmtEntries.find(S);
1997   if (I != SubStmtEntries.end()) {
1998     Record.push_back(I->second);
1999     Stream.EmitRecord(serialization::STMT_REF_PTR, Record);
2000     return;
2001   }
2002 
2003 #ifndef NDEBUG
2004   assert(!ParentStmts.count(S) && "There is a Stmt cycle!");
2005 
2006   struct ParentStmtInserterRAII {
2007     Stmt *S;
2008     llvm::DenseSet<Stmt *> &ParentStmts;
2009 
2010     ParentStmtInserterRAII(Stmt *S, llvm::DenseSet<Stmt *> &ParentStmts)
2011       : S(S), ParentStmts(ParentStmts) {
2012       ParentStmts.insert(S);
2013     }
2014     ~ParentStmtInserterRAII() {
2015       ParentStmts.erase(S);
2016     }
2017   };
2018 
2019   ParentStmtInserterRAII ParentStmtInserter(S, ParentStmts);
2020 #endif
2021 
2022   // Redirect ASTWriter::AddStmt to collect sub-stmts.
2023   SmallVector<Stmt *, 16> SubStmts;
2024   CollectedStmts = &SubStmts;
2025 
2026   Writer.Code = serialization::STMT_NULL_PTR;
2027   Writer.AbbrevToUse = 0;
2028   Writer.Visit(S);
2029 
2030 #ifndef NDEBUG
2031   if (Writer.Code == serialization::STMT_NULL_PTR) {
2032     SourceManager &SrcMgr
2033       = DeclIDs.begin()->first->getASTContext().getSourceManager();
2034     S->dump(SrcMgr);
2035     llvm_unreachable("Unhandled sub-statement writing AST file");
2036   }
2037 #endif
2038 
2039   // Revert ASTWriter::AddStmt.
2040   CollectedStmts = &StmtsToEmit;
2041 
2042   // Write the sub-stmts in reverse order, last to first. When reading them back
2043   // we will read them in correct order by "pop"ing them from the Stmts stack.
2044   // This simplifies reading and allows to store a variable number of sub-stmts
2045   // without knowing it in advance.
2046   while (!SubStmts.empty())
2047     WriteSubStmt(SubStmts.pop_back_val(), SubStmtEntries, ParentStmts);
2048 
2049   Stream.EmitRecord(Writer.Code, Record, Writer.AbbrevToUse);
2050 
2051   SubStmtEntries[S] = Stream.GetCurrentBitNo();
2052 }
2053 
2054 /// \brief Flush all of the statements that have been added to the
2055 /// queue via AddStmt().
2056 void ASTWriter::FlushStmts() {
2057   RecordData Record;
2058 
2059   // We expect to be the only consumer of the two temporary statement maps,
2060   // assert that they are empty.
2061   assert(SubStmtEntries.empty() && "unexpected entries in sub-stmt map");
2062   assert(ParentStmts.empty() && "unexpected entries in parent stmt map");
2063 
2064   for (unsigned I = 0, N = StmtsToEmit.size(); I != N; ++I) {
2065     WriteSubStmt(StmtsToEmit[I], SubStmtEntries, ParentStmts);
2066 
2067     assert(N == StmtsToEmit.size() &&
2068            "Substatement written via AddStmt rather than WriteSubStmt!");
2069 
2070     // Note that we are at the end of a full expression. Any
2071     // expression records that follow this one are part of a different
2072     // expression.
2073     Stream.EmitRecord(serialization::STMT_STOP, Record);
2074 
2075     SubStmtEntries.clear();
2076     ParentStmts.clear();
2077   }
2078 
2079   StmtsToEmit.clear();
2080 }
2081