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