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