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