]> CyberLeo.Net >> Repos - FreeBSD/stable/9.git/blob - contrib/llvm/tools/clang/lib/AST/StmtPrinter.cpp
MFC 254790 (by emaste):
[FreeBSD/stable/9.git] / contrib / llvm / tools / clang / lib / AST / StmtPrinter.cpp
1 //===--- StmtPrinter.cpp - Printing implementation for Stmt ASTs ----------===//
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 the Stmt::dumpPretty/Stmt::printPretty methods, which
11 // pretty print the AST back out to C code.
12 //
13 //===----------------------------------------------------------------------===//
14
15 #include "clang/AST/ASTContext.h"
16 #include "clang/AST/Attr.h"
17 #include "clang/AST/DeclCXX.h"
18 #include "clang/AST/DeclObjC.h"
19 #include "clang/AST/DeclTemplate.h"
20 #include "clang/AST/Expr.h"
21 #include "clang/AST/ExprCXX.h"
22 #include "clang/AST/PrettyPrinter.h"
23 #include "clang/AST/StmtVisitor.h"
24 #include "clang/Basic/CharInfo.h"
25 #include "llvm/ADT/SmallString.h"
26 #include "llvm/Support/Format.h"
27 using namespace clang;
28
29 //===----------------------------------------------------------------------===//
30 // StmtPrinter Visitor
31 //===----------------------------------------------------------------------===//
32
33 namespace  {
34   class StmtPrinter : public StmtVisitor<StmtPrinter> {
35     raw_ostream &OS;
36     unsigned IndentLevel;
37     clang::PrinterHelper* Helper;
38     PrintingPolicy Policy;
39
40   public:
41     StmtPrinter(raw_ostream &os, PrinterHelper* helper,
42                 const PrintingPolicy &Policy,
43                 unsigned Indentation = 0)
44       : OS(os), IndentLevel(Indentation), Helper(helper), Policy(Policy) {}
45
46     void PrintStmt(Stmt *S) {
47       PrintStmt(S, Policy.Indentation);
48     }
49
50     void PrintStmt(Stmt *S, int SubIndent) {
51       IndentLevel += SubIndent;
52       if (S && isa<Expr>(S)) {
53         // If this is an expr used in a stmt context, indent and newline it.
54         Indent();
55         Visit(S);
56         OS << ";\n";
57       } else if (S) {
58         Visit(S);
59       } else {
60         Indent() << "<<<NULL STATEMENT>>>\n";
61       }
62       IndentLevel -= SubIndent;
63     }
64
65     void PrintRawCompoundStmt(CompoundStmt *S);
66     void PrintRawDecl(Decl *D);
67     void PrintRawDeclStmt(const DeclStmt *S);
68     void PrintRawIfStmt(IfStmt *If);
69     void PrintRawCXXCatchStmt(CXXCatchStmt *Catch);
70     void PrintCallArgs(CallExpr *E);
71     void PrintRawSEHExceptHandler(SEHExceptStmt *S);
72     void PrintRawSEHFinallyStmt(SEHFinallyStmt *S);
73
74     void PrintExpr(Expr *E) {
75       if (E)
76         Visit(E);
77       else
78         OS << "<null expr>";
79     }
80
81     raw_ostream &Indent(int Delta = 0) {
82       for (int i = 0, e = IndentLevel+Delta; i < e; ++i)
83         OS << "  ";
84       return OS;
85     }
86
87     void Visit(Stmt* S) {
88       if (Helper && Helper->handledStmt(S,OS))
89           return;
90       else StmtVisitor<StmtPrinter>::Visit(S);
91     }
92     
93     void VisitStmt(Stmt *Node) LLVM_ATTRIBUTE_UNUSED {
94       Indent() << "<<unknown stmt type>>\n";
95     }
96     void VisitExpr(Expr *Node) LLVM_ATTRIBUTE_UNUSED {
97       OS << "<<unknown expr type>>";
98     }
99     void VisitCXXNamedCastExpr(CXXNamedCastExpr *Node);
100
101 #define ABSTRACT_STMT(CLASS)
102 #define STMT(CLASS, PARENT) \
103     void Visit##CLASS(CLASS *Node);
104 #include "clang/AST/StmtNodes.inc"
105   };
106 }
107
108 //===----------------------------------------------------------------------===//
109 //  Stmt printing methods.
110 //===----------------------------------------------------------------------===//
111
112 /// PrintRawCompoundStmt - Print a compound stmt without indenting the {, and
113 /// with no newline after the }.
114 void StmtPrinter::PrintRawCompoundStmt(CompoundStmt *Node) {
115   OS << "{\n";
116   for (CompoundStmt::body_iterator I = Node->body_begin(), E = Node->body_end();
117        I != E; ++I)
118     PrintStmt(*I);
119
120   Indent() << "}";
121 }
122
123 void StmtPrinter::PrintRawDecl(Decl *D) {
124   D->print(OS, Policy, IndentLevel);
125 }
126
127 void StmtPrinter::PrintRawDeclStmt(const DeclStmt *S) {
128   DeclStmt::const_decl_iterator Begin = S->decl_begin(), End = S->decl_end();
129   SmallVector<Decl*, 2> Decls;
130   for ( ; Begin != End; ++Begin)
131     Decls.push_back(*Begin);
132
133   Decl::printGroup(Decls.data(), Decls.size(), OS, Policy, IndentLevel);
134 }
135
136 void StmtPrinter::VisitNullStmt(NullStmt *Node) {
137   Indent() << ";\n";
138 }
139
140 void StmtPrinter::VisitDeclStmt(DeclStmt *Node) {
141   Indent();
142   PrintRawDeclStmt(Node);
143   OS << ";\n";
144 }
145
146 void StmtPrinter::VisitCompoundStmt(CompoundStmt *Node) {
147   Indent();
148   PrintRawCompoundStmt(Node);
149   OS << "\n";
150 }
151
152 void StmtPrinter::VisitCaseStmt(CaseStmt *Node) {
153   Indent(-1) << "case ";
154   PrintExpr(Node->getLHS());
155   if (Node->getRHS()) {
156     OS << " ... ";
157     PrintExpr(Node->getRHS());
158   }
159   OS << ":\n";
160
161   PrintStmt(Node->getSubStmt(), 0);
162 }
163
164 void StmtPrinter::VisitDefaultStmt(DefaultStmt *Node) {
165   Indent(-1) << "default:\n";
166   PrintStmt(Node->getSubStmt(), 0);
167 }
168
169 void StmtPrinter::VisitLabelStmt(LabelStmt *Node) {
170   Indent(-1) << Node->getName() << ":\n";
171   PrintStmt(Node->getSubStmt(), 0);
172 }
173
174 void StmtPrinter::VisitAttributedStmt(AttributedStmt *Node) {
175   OS << "[[";
176   bool first = true;
177   for (ArrayRef<const Attr*>::iterator it = Node->getAttrs().begin(),
178                                        end = Node->getAttrs().end();
179                                        it != end; ++it) {
180     if (!first) {
181       OS << ", ";
182       first = false;
183     }
184     // TODO: check this
185     (*it)->printPretty(OS, Policy);
186   }
187   OS << "]] ";
188   PrintStmt(Node->getSubStmt(), 0);
189 }
190
191 void StmtPrinter::PrintRawIfStmt(IfStmt *If) {
192   OS << "if (";
193   if (const DeclStmt *DS = If->getConditionVariableDeclStmt())
194     PrintRawDeclStmt(DS);
195   else
196     PrintExpr(If->getCond());
197   OS << ')';
198
199   if (CompoundStmt *CS = dyn_cast<CompoundStmt>(If->getThen())) {
200     OS << ' ';
201     PrintRawCompoundStmt(CS);
202     OS << (If->getElse() ? ' ' : '\n');
203   } else {
204     OS << '\n';
205     PrintStmt(If->getThen());
206     if (If->getElse()) Indent();
207   }
208
209   if (Stmt *Else = If->getElse()) {
210     OS << "else";
211
212     if (CompoundStmt *CS = dyn_cast<CompoundStmt>(Else)) {
213       OS << ' ';
214       PrintRawCompoundStmt(CS);
215       OS << '\n';
216     } else if (IfStmt *ElseIf = dyn_cast<IfStmt>(Else)) {
217       OS << ' ';
218       PrintRawIfStmt(ElseIf);
219     } else {
220       OS << '\n';
221       PrintStmt(If->getElse());
222     }
223   }
224 }
225
226 void StmtPrinter::VisitIfStmt(IfStmt *If) {
227   Indent();
228   PrintRawIfStmt(If);
229 }
230
231 void StmtPrinter::VisitSwitchStmt(SwitchStmt *Node) {
232   Indent() << "switch (";
233   if (const DeclStmt *DS = Node->getConditionVariableDeclStmt())
234     PrintRawDeclStmt(DS);
235   else
236     PrintExpr(Node->getCond());
237   OS << ")";
238
239   // Pretty print compoundstmt bodies (very common).
240   if (CompoundStmt *CS = dyn_cast<CompoundStmt>(Node->getBody())) {
241     OS << " ";
242     PrintRawCompoundStmt(CS);
243     OS << "\n";
244   } else {
245     OS << "\n";
246     PrintStmt(Node->getBody());
247   }
248 }
249
250 void StmtPrinter::VisitWhileStmt(WhileStmt *Node) {
251   Indent() << "while (";
252   if (const DeclStmt *DS = Node->getConditionVariableDeclStmt())
253     PrintRawDeclStmt(DS);
254   else
255     PrintExpr(Node->getCond());
256   OS << ")\n";
257   PrintStmt(Node->getBody());
258 }
259
260 void StmtPrinter::VisitDoStmt(DoStmt *Node) {
261   Indent() << "do ";
262   if (CompoundStmt *CS = dyn_cast<CompoundStmt>(Node->getBody())) {
263     PrintRawCompoundStmt(CS);
264     OS << " ";
265   } else {
266     OS << "\n";
267     PrintStmt(Node->getBody());
268     Indent();
269   }
270
271   OS << "while (";
272   PrintExpr(Node->getCond());
273   OS << ");\n";
274 }
275
276 void StmtPrinter::VisitForStmt(ForStmt *Node) {
277   Indent() << "for (";
278   if (Node->getInit()) {
279     if (DeclStmt *DS = dyn_cast<DeclStmt>(Node->getInit()))
280       PrintRawDeclStmt(DS);
281     else
282       PrintExpr(cast<Expr>(Node->getInit()));
283   }
284   OS << ";";
285   if (Node->getCond()) {
286     OS << " ";
287     PrintExpr(Node->getCond());
288   }
289   OS << ";";
290   if (Node->getInc()) {
291     OS << " ";
292     PrintExpr(Node->getInc());
293   }
294   OS << ") ";
295
296   if (CompoundStmt *CS = dyn_cast<CompoundStmt>(Node->getBody())) {
297     PrintRawCompoundStmt(CS);
298     OS << "\n";
299   } else {
300     OS << "\n";
301     PrintStmt(Node->getBody());
302   }
303 }
304
305 void StmtPrinter::VisitObjCForCollectionStmt(ObjCForCollectionStmt *Node) {
306   Indent() << "for (";
307   if (DeclStmt *DS = dyn_cast<DeclStmt>(Node->getElement()))
308     PrintRawDeclStmt(DS);
309   else
310     PrintExpr(cast<Expr>(Node->getElement()));
311   OS << " in ";
312   PrintExpr(Node->getCollection());
313   OS << ") ";
314
315   if (CompoundStmt *CS = dyn_cast<CompoundStmt>(Node->getBody())) {
316     PrintRawCompoundStmt(CS);
317     OS << "\n";
318   } else {
319     OS << "\n";
320     PrintStmt(Node->getBody());
321   }
322 }
323
324 void StmtPrinter::VisitCXXForRangeStmt(CXXForRangeStmt *Node) {
325   Indent() << "for (";
326   PrintingPolicy SubPolicy(Policy);
327   SubPolicy.SuppressInitializers = true;
328   Node->getLoopVariable()->print(OS, SubPolicy, IndentLevel);
329   OS << " : ";
330   PrintExpr(Node->getRangeInit());
331   OS << ") {\n";
332   PrintStmt(Node->getBody());
333   Indent() << "}\n";
334 }
335
336 void StmtPrinter::VisitMSDependentExistsStmt(MSDependentExistsStmt *Node) {
337   Indent();
338   if (Node->isIfExists())
339     OS << "__if_exists (";
340   else
341     OS << "__if_not_exists (";
342   
343   if (NestedNameSpecifier *Qualifier
344         = Node->getQualifierLoc().getNestedNameSpecifier())
345     Qualifier->print(OS, Policy);
346   
347   OS << Node->getNameInfo() << ") ";
348   
349   PrintRawCompoundStmt(Node->getSubStmt());
350 }
351
352 void StmtPrinter::VisitGotoStmt(GotoStmt *Node) {
353   Indent() << "goto " << Node->getLabel()->getName() << ";\n";
354 }
355
356 void StmtPrinter::VisitIndirectGotoStmt(IndirectGotoStmt *Node) {
357   Indent() << "goto *";
358   PrintExpr(Node->getTarget());
359   OS << ";\n";
360 }
361
362 void StmtPrinter::VisitContinueStmt(ContinueStmt *Node) {
363   Indent() << "continue;\n";
364 }
365
366 void StmtPrinter::VisitBreakStmt(BreakStmt *Node) {
367   Indent() << "break;\n";
368 }
369
370
371 void StmtPrinter::VisitReturnStmt(ReturnStmt *Node) {
372   Indent() << "return";
373   if (Node->getRetValue()) {
374     OS << " ";
375     PrintExpr(Node->getRetValue());
376   }
377   OS << ";\n";
378 }
379
380
381 void StmtPrinter::VisitGCCAsmStmt(GCCAsmStmt *Node) {
382   Indent() << "asm ";
383
384   if (Node->isVolatile())
385     OS << "volatile ";
386
387   OS << "(";
388   VisitStringLiteral(Node->getAsmString());
389
390   // Outputs
391   if (Node->getNumOutputs() != 0 || Node->getNumInputs() != 0 ||
392       Node->getNumClobbers() != 0)
393     OS << " : ";
394
395   for (unsigned i = 0, e = Node->getNumOutputs(); i != e; ++i) {
396     if (i != 0)
397       OS << ", ";
398
399     if (!Node->getOutputName(i).empty()) {
400       OS << '[';
401       OS << Node->getOutputName(i);
402       OS << "] ";
403     }
404
405     VisitStringLiteral(Node->getOutputConstraintLiteral(i));
406     OS << " ";
407     Visit(Node->getOutputExpr(i));
408   }
409
410   // Inputs
411   if (Node->getNumInputs() != 0 || Node->getNumClobbers() != 0)
412     OS << " : ";
413
414   for (unsigned i = 0, e = Node->getNumInputs(); i != e; ++i) {
415     if (i != 0)
416       OS << ", ";
417
418     if (!Node->getInputName(i).empty()) {
419       OS << '[';
420       OS << Node->getInputName(i);
421       OS << "] ";
422     }
423
424     VisitStringLiteral(Node->getInputConstraintLiteral(i));
425     OS << " ";
426     Visit(Node->getInputExpr(i));
427   }
428
429   // Clobbers
430   if (Node->getNumClobbers() != 0)
431     OS << " : ";
432
433   for (unsigned i = 0, e = Node->getNumClobbers(); i != e; ++i) {
434     if (i != 0)
435       OS << ", ";
436
437     VisitStringLiteral(Node->getClobberStringLiteral(i));
438   }
439
440   OS << ");\n";
441 }
442
443 void StmtPrinter::VisitMSAsmStmt(MSAsmStmt *Node) {
444   // FIXME: Implement MS style inline asm statement printer.
445   Indent() << "__asm ";
446   if (Node->hasBraces())
447     OS << "{\n";
448   OS << Node->getAsmString() << "\n";
449   if (Node->hasBraces())
450     Indent() << "}\n";
451 }
452
453 void StmtPrinter::VisitCapturedStmt(CapturedStmt *Node) {
454   PrintStmt(Node->getCapturedDecl()->getBody());
455 }
456
457 void StmtPrinter::VisitObjCAtTryStmt(ObjCAtTryStmt *Node) {
458   Indent() << "@try";
459   if (CompoundStmt *TS = dyn_cast<CompoundStmt>(Node->getTryBody())) {
460     PrintRawCompoundStmt(TS);
461     OS << "\n";
462   }
463
464   for (unsigned I = 0, N = Node->getNumCatchStmts(); I != N; ++I) {
465     ObjCAtCatchStmt *catchStmt = Node->getCatchStmt(I);
466     Indent() << "@catch(";
467     if (catchStmt->getCatchParamDecl()) {
468       if (Decl *DS = catchStmt->getCatchParamDecl())
469         PrintRawDecl(DS);
470     }
471     OS << ")";
472     if (CompoundStmt *CS = dyn_cast<CompoundStmt>(catchStmt->getCatchBody())) {
473       PrintRawCompoundStmt(CS);
474       OS << "\n";
475     }
476   }
477
478   if (ObjCAtFinallyStmt *FS = static_cast<ObjCAtFinallyStmt *>(
479         Node->getFinallyStmt())) {
480     Indent() << "@finally";
481     PrintRawCompoundStmt(dyn_cast<CompoundStmt>(FS->getFinallyBody()));
482     OS << "\n";
483   }
484 }
485
486 void StmtPrinter::VisitObjCAtFinallyStmt(ObjCAtFinallyStmt *Node) {
487 }
488
489 void StmtPrinter::VisitObjCAtCatchStmt (ObjCAtCatchStmt *Node) {
490   Indent() << "@catch (...) { /* todo */ } \n";
491 }
492
493 void StmtPrinter::VisitObjCAtThrowStmt(ObjCAtThrowStmt *Node) {
494   Indent() << "@throw";
495   if (Node->getThrowExpr()) {
496     OS << " ";
497     PrintExpr(Node->getThrowExpr());
498   }
499   OS << ";\n";
500 }
501
502 void StmtPrinter::VisitObjCAtSynchronizedStmt(ObjCAtSynchronizedStmt *Node) {
503   Indent() << "@synchronized (";
504   PrintExpr(Node->getSynchExpr());
505   OS << ")";
506   PrintRawCompoundStmt(Node->getSynchBody());
507   OS << "\n";
508 }
509
510 void StmtPrinter::VisitObjCAutoreleasePoolStmt(ObjCAutoreleasePoolStmt *Node) {
511   Indent() << "@autoreleasepool";
512   PrintRawCompoundStmt(dyn_cast<CompoundStmt>(Node->getSubStmt()));
513   OS << "\n";
514 }
515
516 void StmtPrinter::PrintRawCXXCatchStmt(CXXCatchStmt *Node) {
517   OS << "catch (";
518   if (Decl *ExDecl = Node->getExceptionDecl())
519     PrintRawDecl(ExDecl);
520   else
521     OS << "...";
522   OS << ") ";
523   PrintRawCompoundStmt(cast<CompoundStmt>(Node->getHandlerBlock()));
524 }
525
526 void StmtPrinter::VisitCXXCatchStmt(CXXCatchStmt *Node) {
527   Indent();
528   PrintRawCXXCatchStmt(Node);
529   OS << "\n";
530 }
531
532 void StmtPrinter::VisitCXXTryStmt(CXXTryStmt *Node) {
533   Indent() << "try ";
534   PrintRawCompoundStmt(Node->getTryBlock());
535   for (unsigned i = 0, e = Node->getNumHandlers(); i < e; ++i) {
536     OS << " ";
537     PrintRawCXXCatchStmt(Node->getHandler(i));
538   }
539   OS << "\n";
540 }
541
542 void StmtPrinter::VisitSEHTryStmt(SEHTryStmt *Node) {
543   Indent() << (Node->getIsCXXTry() ? "try " : "__try ");
544   PrintRawCompoundStmt(Node->getTryBlock());
545   SEHExceptStmt *E = Node->getExceptHandler();
546   SEHFinallyStmt *F = Node->getFinallyHandler();
547   if(E)
548     PrintRawSEHExceptHandler(E);
549   else {
550     assert(F && "Must have a finally block...");
551     PrintRawSEHFinallyStmt(F);
552   }
553   OS << "\n";
554 }
555
556 void StmtPrinter::PrintRawSEHFinallyStmt(SEHFinallyStmt *Node) {
557   OS << "__finally ";
558   PrintRawCompoundStmt(Node->getBlock());
559   OS << "\n";
560 }
561
562 void StmtPrinter::PrintRawSEHExceptHandler(SEHExceptStmt *Node) {
563   OS << "__except (";
564   VisitExpr(Node->getFilterExpr());
565   OS << ")\n";
566   PrintRawCompoundStmt(Node->getBlock());
567   OS << "\n";
568 }
569
570 void StmtPrinter::VisitSEHExceptStmt(SEHExceptStmt *Node) {
571   Indent();
572   PrintRawSEHExceptHandler(Node);
573   OS << "\n";
574 }
575
576 void StmtPrinter::VisitSEHFinallyStmt(SEHFinallyStmt *Node) {
577   Indent();
578   PrintRawSEHFinallyStmt(Node);
579   OS << "\n";
580 }
581
582 //===----------------------------------------------------------------------===//
583 //  OpenMP clauses printing methods
584 //===----------------------------------------------------------------------===//
585
586 namespace {
587 class OMPClausePrinter : public OMPClauseVisitor<OMPClausePrinter> {
588   raw_ostream &OS;
589   /// \brief Process clauses with list of variables.
590   template <typename T>
591   void VisitOMPClauseList(T *Node, char StartSym);
592 public:
593   OMPClausePrinter(raw_ostream &OS) : OS(OS) { }
594 #define OPENMP_CLAUSE(Name, Class)                              \
595   void Visit##Class(Class *S);
596 #include "clang/Basic/OpenMPKinds.def"
597 };
598
599 void OMPClausePrinter::VisitOMPDefaultClause(OMPDefaultClause *Node) {
600   OS << "default("
601      << getOpenMPSimpleClauseTypeName(OMPC_default, Node->getDefaultKind())
602      << ")";
603 }
604
605 template<typename T>
606 void OMPClausePrinter::VisitOMPClauseList(T *Node, char StartSym) {
607   for (typename T::varlist_iterator I = Node->varlist_begin(),
608                                     E = Node->varlist_end();
609          I != E; ++I)
610     OS << (I == Node->varlist_begin() ? StartSym : ',')
611        << *cast<NamedDecl>(cast<DeclRefExpr>(*I)->getDecl());
612 }
613
614 void OMPClausePrinter::VisitOMPPrivateClause(OMPPrivateClause *Node) {
615   if (!Node->varlist_empty()) {
616     OS << "private";
617     VisitOMPClauseList(Node, '(');
618     OS << ")";
619   }
620 }
621
622 void OMPClausePrinter::VisitOMPFirstprivateClause(OMPFirstprivateClause *Node) {
623   if (!Node->varlist_empty()) {
624     OS << "firstprivate";
625     VisitOMPClauseList(Node, '(');
626     OS << ")";
627   }
628 }
629
630 void OMPClausePrinter::VisitOMPSharedClause(OMPSharedClause *Node) {
631   if (!Node->varlist_empty()) {
632     OS << "shared";
633     VisitOMPClauseList(Node, '(');
634     OS << ")";
635   }
636 }
637
638 }
639
640 //===----------------------------------------------------------------------===//
641 //  OpenMP directives printing methods
642 //===----------------------------------------------------------------------===//
643
644 void StmtPrinter::VisitOMPParallelDirective(OMPParallelDirective *Node) {
645   Indent() << "#pragma omp parallel ";
646
647   OMPClausePrinter Printer(OS);
648   ArrayRef<OMPClause *> Clauses = Node->clauses();
649   for (ArrayRef<OMPClause *>::iterator I = Clauses.begin(), E = Clauses.end();
650        I != E; ++I)
651     if (*I && !(*I)->isImplicit()) {
652       Printer.Visit(*I);
653       OS << ' ';
654     }
655   OS << "\n";
656   if (Node->getAssociatedStmt()) {
657     assert(isa<CapturedStmt>(Node->getAssociatedStmt()) &&
658            "Expected captured statement!");
659     Stmt *CS = cast<CapturedStmt>(Node->getAssociatedStmt())->getCapturedStmt();
660     PrintStmt(CS);
661   }
662 }
663 //===----------------------------------------------------------------------===//
664 //  Expr printing methods.
665 //===----------------------------------------------------------------------===//
666
667 void StmtPrinter::VisitDeclRefExpr(DeclRefExpr *Node) {
668   if (NestedNameSpecifier *Qualifier = Node->getQualifier())
669     Qualifier->print(OS, Policy);
670   if (Node->hasTemplateKeyword())
671     OS << "template ";
672   OS << Node->getNameInfo();
673   if (Node->hasExplicitTemplateArgs())
674     TemplateSpecializationType::PrintTemplateArgumentList(
675         OS, Node->getTemplateArgs(), Node->getNumTemplateArgs(), Policy);
676 }
677
678 void StmtPrinter::VisitDependentScopeDeclRefExpr(
679                                            DependentScopeDeclRefExpr *Node) {
680   if (NestedNameSpecifier *Qualifier = Node->getQualifier())
681     Qualifier->print(OS, Policy);
682   if (Node->hasTemplateKeyword())
683     OS << "template ";
684   OS << Node->getNameInfo();
685   if (Node->hasExplicitTemplateArgs())
686     TemplateSpecializationType::PrintTemplateArgumentList(
687         OS, Node->getTemplateArgs(), Node->getNumTemplateArgs(), Policy);
688 }
689
690 void StmtPrinter::VisitUnresolvedLookupExpr(UnresolvedLookupExpr *Node) {
691   if (Node->getQualifier())
692     Node->getQualifier()->print(OS, Policy);
693   if (Node->hasTemplateKeyword())
694     OS << "template ";
695   OS << Node->getNameInfo();
696   if (Node->hasExplicitTemplateArgs())
697     TemplateSpecializationType::PrintTemplateArgumentList(
698         OS, Node->getTemplateArgs(), Node->getNumTemplateArgs(), Policy);
699 }
700
701 void StmtPrinter::VisitObjCIvarRefExpr(ObjCIvarRefExpr *Node) {
702   if (Node->getBase()) {
703     PrintExpr(Node->getBase());
704     OS << (Node->isArrow() ? "->" : ".");
705   }
706   OS << *Node->getDecl();
707 }
708
709 void StmtPrinter::VisitObjCPropertyRefExpr(ObjCPropertyRefExpr *Node) {
710   if (Node->isSuperReceiver())
711     OS << "super.";
712   else if (Node->getBase()) {
713     PrintExpr(Node->getBase());
714     OS << ".";
715   }
716
717   if (Node->isImplicitProperty())
718     OS << Node->getImplicitPropertyGetter()->getSelector().getAsString();
719   else
720     OS << Node->getExplicitProperty()->getName();
721 }
722
723 void StmtPrinter::VisitObjCSubscriptRefExpr(ObjCSubscriptRefExpr *Node) {
724   
725   PrintExpr(Node->getBaseExpr());
726   OS << "[";
727   PrintExpr(Node->getKeyExpr());
728   OS << "]";
729 }
730
731 void StmtPrinter::VisitPredefinedExpr(PredefinedExpr *Node) {
732   switch (Node->getIdentType()) {
733     default:
734       llvm_unreachable("unknown case");
735     case PredefinedExpr::Func:
736       OS << "__func__";
737       break;
738     case PredefinedExpr::Function:
739       OS << "__FUNCTION__";
740       break;
741     case PredefinedExpr::FuncDName:
742       OS << "__FUNCDNAME__";
743       break;
744     case PredefinedExpr::LFunction:
745       OS << "L__FUNCTION__";
746       break;
747     case PredefinedExpr::PrettyFunction:
748       OS << "__PRETTY_FUNCTION__";
749       break;
750   }
751 }
752
753 void StmtPrinter::VisitCharacterLiteral(CharacterLiteral *Node) {
754   unsigned value = Node->getValue();
755
756   switch (Node->getKind()) {
757   case CharacterLiteral::Ascii: break; // no prefix.
758   case CharacterLiteral::Wide:  OS << 'L'; break;
759   case CharacterLiteral::UTF16: OS << 'u'; break;
760   case CharacterLiteral::UTF32: OS << 'U'; break;
761   }
762
763   switch (value) {
764   case '\\':
765     OS << "'\\\\'";
766     break;
767   case '\'':
768     OS << "'\\''";
769     break;
770   case '\a':
771     // TODO: K&R: the meaning of '\\a' is different in traditional C
772     OS << "'\\a'";
773     break;
774   case '\b':
775     OS << "'\\b'";
776     break;
777   // Nonstandard escape sequence.
778   /*case '\e':
779     OS << "'\\e'";
780     break;*/
781   case '\f':
782     OS << "'\\f'";
783     break;
784   case '\n':
785     OS << "'\\n'";
786     break;
787   case '\r':
788     OS << "'\\r'";
789     break;
790   case '\t':
791     OS << "'\\t'";
792     break;
793   case '\v':
794     OS << "'\\v'";
795     break;
796   default:
797     if (value < 256 && isPrintable((unsigned char)value))
798       OS << "'" << (char)value << "'";
799     else if (value < 256)
800       OS << "'\\x" << llvm::format("%02x", value) << "'";
801     else if (value <= 0xFFFF)
802       OS << "'\\u" << llvm::format("%04x", value) << "'";
803     else
804       OS << "'\\U" << llvm::format("%08x", value) << "'";
805   }
806 }
807
808 void StmtPrinter::VisitIntegerLiteral(IntegerLiteral *Node) {
809   bool isSigned = Node->getType()->isSignedIntegerType();
810   OS << Node->getValue().toString(10, isSigned);
811
812   // Emit suffixes.  Integer literals are always a builtin integer type.
813   switch (Node->getType()->getAs<BuiltinType>()->getKind()) {
814   default: llvm_unreachable("Unexpected type for integer literal!");
815   // FIXME: The Short and UShort cases are to handle cases where a short
816   // integeral literal is formed during template instantiation.  They should
817   // be removed when template instantiation no longer needs integer literals.
818   case BuiltinType::Short:
819   case BuiltinType::UShort:
820   case BuiltinType::Int:       break; // no suffix.
821   case BuiltinType::UInt:      OS << 'U'; break;
822   case BuiltinType::Long:      OS << 'L'; break;
823   case BuiltinType::ULong:     OS << "UL"; break;
824   case BuiltinType::LongLong:  OS << "LL"; break;
825   case BuiltinType::ULongLong: OS << "ULL"; break;
826   case BuiltinType::Int128:    OS << "i128"; break;
827   case BuiltinType::UInt128:   OS << "Ui128"; break;
828   }
829 }
830
831 static void PrintFloatingLiteral(raw_ostream &OS, FloatingLiteral *Node,
832                                  bool PrintSuffix) {
833   SmallString<16> Str;
834   Node->getValue().toString(Str);
835   OS << Str;
836   if (Str.find_first_not_of("-0123456789") == StringRef::npos)
837     OS << '.'; // Trailing dot in order to separate from ints.
838
839   if (!PrintSuffix)
840     return;
841
842   // Emit suffixes.  Float literals are always a builtin float type.
843   switch (Node->getType()->getAs<BuiltinType>()->getKind()) {
844   default: llvm_unreachable("Unexpected type for float literal!");
845   case BuiltinType::Half:       break; // FIXME: suffix?
846   case BuiltinType::Double:     break; // no suffix.
847   case BuiltinType::Float:      OS << 'F'; break;
848   case BuiltinType::LongDouble: OS << 'L'; break;
849   }
850 }
851
852 void StmtPrinter::VisitFloatingLiteral(FloatingLiteral *Node) {
853   PrintFloatingLiteral(OS, Node, /*PrintSuffix=*/true);
854 }
855
856 void StmtPrinter::VisitImaginaryLiteral(ImaginaryLiteral *Node) {
857   PrintExpr(Node->getSubExpr());
858   OS << "i";
859 }
860
861 void StmtPrinter::VisitStringLiteral(StringLiteral *Str) {
862   Str->outputString(OS);
863 }
864 void StmtPrinter::VisitParenExpr(ParenExpr *Node) {
865   OS << "(";
866   PrintExpr(Node->getSubExpr());
867   OS << ")";
868 }
869 void StmtPrinter::VisitUnaryOperator(UnaryOperator *Node) {
870   if (!Node->isPostfix()) {
871     OS << UnaryOperator::getOpcodeStr(Node->getOpcode());
872
873     // Print a space if this is an "identifier operator" like __real, or if
874     // it might be concatenated incorrectly like '+'.
875     switch (Node->getOpcode()) {
876     default: break;
877     case UO_Real:
878     case UO_Imag:
879     case UO_Extension:
880       OS << ' ';
881       break;
882     case UO_Plus:
883     case UO_Minus:
884       if (isa<UnaryOperator>(Node->getSubExpr()))
885         OS << ' ';
886       break;
887     }
888   }
889   PrintExpr(Node->getSubExpr());
890
891   if (Node->isPostfix())
892     OS << UnaryOperator::getOpcodeStr(Node->getOpcode());
893 }
894
895 void StmtPrinter::VisitOffsetOfExpr(OffsetOfExpr *Node) {
896   OS << "__builtin_offsetof(";
897   Node->getTypeSourceInfo()->getType().print(OS, Policy);
898   OS << ", ";
899   bool PrintedSomething = false;
900   for (unsigned i = 0, n = Node->getNumComponents(); i < n; ++i) {
901     OffsetOfExpr::OffsetOfNode ON = Node->getComponent(i);
902     if (ON.getKind() == OffsetOfExpr::OffsetOfNode::Array) {
903       // Array node
904       OS << "[";
905       PrintExpr(Node->getIndexExpr(ON.getArrayExprIndex()));
906       OS << "]";
907       PrintedSomething = true;
908       continue;
909     }
910
911     // Skip implicit base indirections.
912     if (ON.getKind() == OffsetOfExpr::OffsetOfNode::Base)
913       continue;
914
915     // Field or identifier node.
916     IdentifierInfo *Id = ON.getFieldName();
917     if (!Id)
918       continue;
919     
920     if (PrintedSomething)
921       OS << ".";
922     else
923       PrintedSomething = true;
924     OS << Id->getName();    
925   }
926   OS << ")";
927 }
928
929 void StmtPrinter::VisitUnaryExprOrTypeTraitExpr(UnaryExprOrTypeTraitExpr *Node){
930   switch(Node->getKind()) {
931   case UETT_SizeOf:
932     OS << "sizeof";
933     break;
934   case UETT_AlignOf:
935     if (Policy.LangOpts.CPlusPlus)
936       OS << "alignof";
937     else if (Policy.LangOpts.C11)
938       OS << "_Alignof";
939     else
940       OS << "__alignof";
941     break;
942   case UETT_VecStep:
943     OS << "vec_step";
944     break;
945   }
946   if (Node->isArgumentType()) {
947     OS << '(';
948     Node->getArgumentType().print(OS, Policy);
949     OS << ')';
950   } else {
951     OS << " ";
952     PrintExpr(Node->getArgumentExpr());
953   }
954 }
955
956 void StmtPrinter::VisitGenericSelectionExpr(GenericSelectionExpr *Node) {
957   OS << "_Generic(";
958   PrintExpr(Node->getControllingExpr());
959   for (unsigned i = 0; i != Node->getNumAssocs(); ++i) {
960     OS << ", ";
961     QualType T = Node->getAssocType(i);
962     if (T.isNull())
963       OS << "default";
964     else
965       T.print(OS, Policy);
966     OS << ": ";
967     PrintExpr(Node->getAssocExpr(i));
968   }
969   OS << ")";
970 }
971
972 void StmtPrinter::VisitArraySubscriptExpr(ArraySubscriptExpr *Node) {
973   PrintExpr(Node->getLHS());
974   OS << "[";
975   PrintExpr(Node->getRHS());
976   OS << "]";
977 }
978
979 void StmtPrinter::PrintCallArgs(CallExpr *Call) {
980   for (unsigned i = 0, e = Call->getNumArgs(); i != e; ++i) {
981     if (isa<CXXDefaultArgExpr>(Call->getArg(i))) {
982       // Don't print any defaulted arguments
983       break;
984     }
985
986     if (i) OS << ", ";
987     PrintExpr(Call->getArg(i));
988   }
989 }
990
991 void StmtPrinter::VisitCallExpr(CallExpr *Call) {
992   PrintExpr(Call->getCallee());
993   OS << "(";
994   PrintCallArgs(Call);
995   OS << ")";
996 }
997 void StmtPrinter::VisitMemberExpr(MemberExpr *Node) {
998   // FIXME: Suppress printing implicit bases (like "this")
999   PrintExpr(Node->getBase());
1000
1001   MemberExpr *ParentMember = dyn_cast<MemberExpr>(Node->getBase());
1002   FieldDecl  *ParentDecl   = ParentMember
1003     ? dyn_cast<FieldDecl>(ParentMember->getMemberDecl()) : NULL;
1004
1005   if (!ParentDecl || !ParentDecl->isAnonymousStructOrUnion())
1006     OS << (Node->isArrow() ? "->" : ".");
1007
1008   if (FieldDecl *FD = dyn_cast<FieldDecl>(Node->getMemberDecl()))
1009     if (FD->isAnonymousStructOrUnion())
1010       return;
1011
1012   if (NestedNameSpecifier *Qualifier = Node->getQualifier())
1013     Qualifier->print(OS, Policy);
1014   if (Node->hasTemplateKeyword())
1015     OS << "template ";
1016   OS << Node->getMemberNameInfo();
1017   if (Node->hasExplicitTemplateArgs())
1018     TemplateSpecializationType::PrintTemplateArgumentList(
1019         OS, Node->getTemplateArgs(), Node->getNumTemplateArgs(), Policy);
1020 }
1021 void StmtPrinter::VisitObjCIsaExpr(ObjCIsaExpr *Node) {
1022   PrintExpr(Node->getBase());
1023   OS << (Node->isArrow() ? "->isa" : ".isa");
1024 }
1025
1026 void StmtPrinter::VisitExtVectorElementExpr(ExtVectorElementExpr *Node) {
1027   PrintExpr(Node->getBase());
1028   OS << ".";
1029   OS << Node->getAccessor().getName();
1030 }
1031 void StmtPrinter::VisitCStyleCastExpr(CStyleCastExpr *Node) {
1032   OS << '(';
1033   Node->getTypeAsWritten().print(OS, Policy);
1034   OS << ')';
1035   PrintExpr(Node->getSubExpr());
1036 }
1037 void StmtPrinter::VisitCompoundLiteralExpr(CompoundLiteralExpr *Node) {
1038   OS << '(';
1039   Node->getType().print(OS, Policy);
1040   OS << ')';
1041   PrintExpr(Node->getInitializer());
1042 }
1043 void StmtPrinter::VisitImplicitCastExpr(ImplicitCastExpr *Node) {
1044   // No need to print anything, simply forward to the sub expression.
1045   PrintExpr(Node->getSubExpr());
1046 }
1047 void StmtPrinter::VisitBinaryOperator(BinaryOperator *Node) {
1048   PrintExpr(Node->getLHS());
1049   OS << " " << BinaryOperator::getOpcodeStr(Node->getOpcode()) << " ";
1050   PrintExpr(Node->getRHS());
1051 }
1052 void StmtPrinter::VisitCompoundAssignOperator(CompoundAssignOperator *Node) {
1053   PrintExpr(Node->getLHS());
1054   OS << " " << BinaryOperator::getOpcodeStr(Node->getOpcode()) << " ";
1055   PrintExpr(Node->getRHS());
1056 }
1057 void StmtPrinter::VisitConditionalOperator(ConditionalOperator *Node) {
1058   PrintExpr(Node->getCond());
1059   OS << " ? ";
1060   PrintExpr(Node->getLHS());
1061   OS << " : ";
1062   PrintExpr(Node->getRHS());
1063 }
1064
1065 // GNU extensions.
1066
1067 void
1068 StmtPrinter::VisitBinaryConditionalOperator(BinaryConditionalOperator *Node) {
1069   PrintExpr(Node->getCommon());
1070   OS << " ?: ";
1071   PrintExpr(Node->getFalseExpr());
1072 }
1073 void StmtPrinter::VisitAddrLabelExpr(AddrLabelExpr *Node) {
1074   OS << "&&" << Node->getLabel()->getName();
1075 }
1076
1077 void StmtPrinter::VisitStmtExpr(StmtExpr *E) {
1078   OS << "(";
1079   PrintRawCompoundStmt(E->getSubStmt());
1080   OS << ")";
1081 }
1082
1083 void StmtPrinter::VisitChooseExpr(ChooseExpr *Node) {
1084   OS << "__builtin_choose_expr(";
1085   PrintExpr(Node->getCond());
1086   OS << ", ";
1087   PrintExpr(Node->getLHS());
1088   OS << ", ";
1089   PrintExpr(Node->getRHS());
1090   OS << ")";
1091 }
1092
1093 void StmtPrinter::VisitGNUNullExpr(GNUNullExpr *) {
1094   OS << "__null";
1095 }
1096
1097 void StmtPrinter::VisitShuffleVectorExpr(ShuffleVectorExpr *Node) {
1098   OS << "__builtin_shufflevector(";
1099   for (unsigned i = 0, e = Node->getNumSubExprs(); i != e; ++i) {
1100     if (i) OS << ", ";
1101     PrintExpr(Node->getExpr(i));
1102   }
1103   OS << ")";
1104 }
1105
1106 void StmtPrinter::VisitConvertVectorExpr(ConvertVectorExpr *Node) {
1107   OS << "__builtin_convertvector(";
1108   PrintExpr(Node->getSrcExpr());
1109   OS << ", ";
1110   Node->getType().print(OS, Policy);
1111   OS << ")";
1112 }
1113
1114 void StmtPrinter::VisitInitListExpr(InitListExpr* Node) {
1115   if (Node->getSyntacticForm()) {
1116     Visit(Node->getSyntacticForm());
1117     return;
1118   }
1119
1120   OS << "{ ";
1121   for (unsigned i = 0, e = Node->getNumInits(); i != e; ++i) {
1122     if (i) OS << ", ";
1123     if (Node->getInit(i))
1124       PrintExpr(Node->getInit(i));
1125     else
1126       OS << "0";
1127   }
1128   OS << " }";
1129 }
1130
1131 void StmtPrinter::VisitParenListExpr(ParenListExpr* Node) {
1132   OS << "( ";
1133   for (unsigned i = 0, e = Node->getNumExprs(); i != e; ++i) {
1134     if (i) OS << ", ";
1135     PrintExpr(Node->getExpr(i));
1136   }
1137   OS << " )";
1138 }
1139
1140 void StmtPrinter::VisitDesignatedInitExpr(DesignatedInitExpr *Node) {
1141   for (DesignatedInitExpr::designators_iterator D = Node->designators_begin(),
1142                       DEnd = Node->designators_end();
1143        D != DEnd; ++D) {
1144     if (D->isFieldDesignator()) {
1145       if (D->getDotLoc().isInvalid())
1146         OS << D->getFieldName()->getName() << ":";
1147       else
1148         OS << "." << D->getFieldName()->getName();
1149     } else {
1150       OS << "[";
1151       if (D->isArrayDesignator()) {
1152         PrintExpr(Node->getArrayIndex(*D));
1153       } else {
1154         PrintExpr(Node->getArrayRangeStart(*D));
1155         OS << " ... ";
1156         PrintExpr(Node->getArrayRangeEnd(*D));
1157       }
1158       OS << "]";
1159     }
1160   }
1161
1162   OS << " = ";
1163   PrintExpr(Node->getInit());
1164 }
1165
1166 void StmtPrinter::VisitImplicitValueInitExpr(ImplicitValueInitExpr *Node) {
1167   if (Policy.LangOpts.CPlusPlus) {
1168     OS << "/*implicit*/";
1169     Node->getType().print(OS, Policy);
1170     OS << "()";
1171   } else {
1172     OS << "/*implicit*/(";
1173     Node->getType().print(OS, Policy);
1174     OS << ')';
1175     if (Node->getType()->isRecordType())
1176       OS << "{}";
1177     else
1178       OS << 0;
1179   }
1180 }
1181
1182 void StmtPrinter::VisitVAArgExpr(VAArgExpr *Node) {
1183   OS << "__builtin_va_arg(";
1184   PrintExpr(Node->getSubExpr());
1185   OS << ", ";
1186   Node->getType().print(OS, Policy);
1187   OS << ")";
1188 }
1189
1190 void StmtPrinter::VisitPseudoObjectExpr(PseudoObjectExpr *Node) {
1191   PrintExpr(Node->getSyntacticForm());
1192 }
1193
1194 void StmtPrinter::VisitAtomicExpr(AtomicExpr *Node) {
1195   const char *Name = 0;
1196   switch (Node->getOp()) {
1197 #define BUILTIN(ID, TYPE, ATTRS)
1198 #define ATOMIC_BUILTIN(ID, TYPE, ATTRS) \
1199   case AtomicExpr::AO ## ID: \
1200     Name = #ID "("; \
1201     break;
1202 #include "clang/Basic/Builtins.def"
1203   }
1204   OS << Name;
1205
1206   // AtomicExpr stores its subexpressions in a permuted order.
1207   PrintExpr(Node->getPtr());
1208   if (Node->getOp() != AtomicExpr::AO__c11_atomic_load &&
1209       Node->getOp() != AtomicExpr::AO__atomic_load_n) {
1210     OS << ", ";
1211     PrintExpr(Node->getVal1());
1212   }
1213   if (Node->getOp() == AtomicExpr::AO__atomic_exchange ||
1214       Node->isCmpXChg()) {
1215     OS << ", ";
1216     PrintExpr(Node->getVal2());
1217   }
1218   if (Node->getOp() == AtomicExpr::AO__atomic_compare_exchange ||
1219       Node->getOp() == AtomicExpr::AO__atomic_compare_exchange_n) {
1220     OS << ", ";
1221     PrintExpr(Node->getWeak());
1222   }
1223   if (Node->getOp() != AtomicExpr::AO__c11_atomic_init) {
1224     OS << ", ";
1225     PrintExpr(Node->getOrder());
1226   }
1227   if (Node->isCmpXChg()) {
1228     OS << ", ";
1229     PrintExpr(Node->getOrderFail());
1230   }
1231   OS << ")";
1232 }
1233
1234 // C++
1235 void StmtPrinter::VisitCXXOperatorCallExpr(CXXOperatorCallExpr *Node) {
1236   const char *OpStrings[NUM_OVERLOADED_OPERATORS] = {
1237     "",
1238 #define OVERLOADED_OPERATOR(Name,Spelling,Token,Unary,Binary,MemberOnly) \
1239     Spelling,
1240 #include "clang/Basic/OperatorKinds.def"
1241   };
1242
1243   OverloadedOperatorKind Kind = Node->getOperator();
1244   if (Kind == OO_PlusPlus || Kind == OO_MinusMinus) {
1245     if (Node->getNumArgs() == 1) {
1246       OS << OpStrings[Kind] << ' ';
1247       PrintExpr(Node->getArg(0));
1248     } else {
1249       PrintExpr(Node->getArg(0));
1250       OS << ' ' << OpStrings[Kind];
1251     }
1252   } else if (Kind == OO_Arrow) {
1253     PrintExpr(Node->getArg(0));
1254   } else if (Kind == OO_Call) {
1255     PrintExpr(Node->getArg(0));
1256     OS << '(';
1257     for (unsigned ArgIdx = 1; ArgIdx < Node->getNumArgs(); ++ArgIdx) {
1258       if (ArgIdx > 1)
1259         OS << ", ";
1260       if (!isa<CXXDefaultArgExpr>(Node->getArg(ArgIdx)))
1261         PrintExpr(Node->getArg(ArgIdx));
1262     }
1263     OS << ')';
1264   } else if (Kind == OO_Subscript) {
1265     PrintExpr(Node->getArg(0));
1266     OS << '[';
1267     PrintExpr(Node->getArg(1));
1268     OS << ']';
1269   } else if (Node->getNumArgs() == 1) {
1270     OS << OpStrings[Kind] << ' ';
1271     PrintExpr(Node->getArg(0));
1272   } else if (Node->getNumArgs() == 2) {
1273     PrintExpr(Node->getArg(0));
1274     OS << ' ' << OpStrings[Kind] << ' ';
1275     PrintExpr(Node->getArg(1));
1276   } else {
1277     llvm_unreachable("unknown overloaded operator");
1278   }
1279 }
1280
1281 void StmtPrinter::VisitCXXMemberCallExpr(CXXMemberCallExpr *Node) {
1282   VisitCallExpr(cast<CallExpr>(Node));
1283 }
1284
1285 void StmtPrinter::VisitCUDAKernelCallExpr(CUDAKernelCallExpr *Node) {
1286   PrintExpr(Node->getCallee());
1287   OS << "<<<";
1288   PrintCallArgs(Node->getConfig());
1289   OS << ">>>(";
1290   PrintCallArgs(Node);
1291   OS << ")";
1292 }
1293
1294 void StmtPrinter::VisitCXXNamedCastExpr(CXXNamedCastExpr *Node) {
1295   OS << Node->getCastName() << '<';
1296   Node->getTypeAsWritten().print(OS, Policy);
1297   OS << ">(";
1298   PrintExpr(Node->getSubExpr());
1299   OS << ")";
1300 }
1301
1302 void StmtPrinter::VisitCXXStaticCastExpr(CXXStaticCastExpr *Node) {
1303   VisitCXXNamedCastExpr(Node);
1304 }
1305
1306 void StmtPrinter::VisitCXXDynamicCastExpr(CXXDynamicCastExpr *Node) {
1307   VisitCXXNamedCastExpr(Node);
1308 }
1309
1310 void StmtPrinter::VisitCXXReinterpretCastExpr(CXXReinterpretCastExpr *Node) {
1311   VisitCXXNamedCastExpr(Node);
1312 }
1313
1314 void StmtPrinter::VisitCXXConstCastExpr(CXXConstCastExpr *Node) {
1315   VisitCXXNamedCastExpr(Node);
1316 }
1317
1318 void StmtPrinter::VisitCXXTypeidExpr(CXXTypeidExpr *Node) {
1319   OS << "typeid(";
1320   if (Node->isTypeOperand()) {
1321     Node->getTypeOperandSourceInfo()->getType().print(OS, Policy);
1322   } else {
1323     PrintExpr(Node->getExprOperand());
1324   }
1325   OS << ")";
1326 }
1327
1328 void StmtPrinter::VisitCXXUuidofExpr(CXXUuidofExpr *Node) {
1329   OS << "__uuidof(";
1330   if (Node->isTypeOperand()) {
1331     Node->getTypeOperandSourceInfo()->getType().print(OS, Policy);
1332   } else {
1333     PrintExpr(Node->getExprOperand());
1334   }
1335   OS << ")";
1336 }
1337
1338 void StmtPrinter::VisitMSPropertyRefExpr(MSPropertyRefExpr *Node) {
1339   PrintExpr(Node->getBaseExpr());
1340   if (Node->isArrow())
1341     OS << "->";
1342   else
1343     OS << ".";
1344   if (NestedNameSpecifier *Qualifier =
1345       Node->getQualifierLoc().getNestedNameSpecifier())
1346     Qualifier->print(OS, Policy);
1347   OS << Node->getPropertyDecl()->getDeclName();
1348 }
1349
1350 void StmtPrinter::VisitUserDefinedLiteral(UserDefinedLiteral *Node) {
1351   switch (Node->getLiteralOperatorKind()) {
1352   case UserDefinedLiteral::LOK_Raw:
1353     OS << cast<StringLiteral>(Node->getArg(0)->IgnoreImpCasts())->getString();
1354     break;
1355   case UserDefinedLiteral::LOK_Template: {
1356     DeclRefExpr *DRE = cast<DeclRefExpr>(Node->getCallee()->IgnoreImpCasts());
1357     const TemplateArgumentList *Args =
1358       cast<FunctionDecl>(DRE->getDecl())->getTemplateSpecializationArgs();
1359     assert(Args);
1360     const TemplateArgument &Pack = Args->get(0);
1361     for (TemplateArgument::pack_iterator I = Pack.pack_begin(),
1362                                          E = Pack.pack_end(); I != E; ++I) {
1363       char C = (char)I->getAsIntegral().getZExtValue();
1364       OS << C;
1365     }
1366     break;
1367   }
1368   case UserDefinedLiteral::LOK_Integer: {
1369     // Print integer literal without suffix.
1370     IntegerLiteral *Int = cast<IntegerLiteral>(Node->getCookedLiteral());
1371     OS << Int->getValue().toString(10, /*isSigned*/false);
1372     break;
1373   }
1374   case UserDefinedLiteral::LOK_Floating: {
1375     // Print floating literal without suffix.
1376     FloatingLiteral *Float = cast<FloatingLiteral>(Node->getCookedLiteral());
1377     PrintFloatingLiteral(OS, Float, /*PrintSuffix=*/false);
1378     break;
1379   }
1380   case UserDefinedLiteral::LOK_String:
1381   case UserDefinedLiteral::LOK_Character:
1382     PrintExpr(Node->getCookedLiteral());
1383     break;
1384   }
1385   OS << Node->getUDSuffix()->getName();
1386 }
1387
1388 void StmtPrinter::VisitCXXBoolLiteralExpr(CXXBoolLiteralExpr *Node) {
1389   OS << (Node->getValue() ? "true" : "false");
1390 }
1391
1392 void StmtPrinter::VisitCXXNullPtrLiteralExpr(CXXNullPtrLiteralExpr *Node) {
1393   OS << "nullptr";
1394 }
1395
1396 void StmtPrinter::VisitCXXThisExpr(CXXThisExpr *Node) {
1397   OS << "this";
1398 }
1399
1400 void StmtPrinter::VisitCXXThrowExpr(CXXThrowExpr *Node) {
1401   if (Node->getSubExpr() == 0)
1402     OS << "throw";
1403   else {
1404     OS << "throw ";
1405     PrintExpr(Node->getSubExpr());
1406   }
1407 }
1408
1409 void StmtPrinter::VisitCXXDefaultArgExpr(CXXDefaultArgExpr *Node) {
1410   // Nothing to print: we picked up the default argument.
1411 }
1412
1413 void StmtPrinter::VisitCXXDefaultInitExpr(CXXDefaultInitExpr *Node) {
1414   // Nothing to print: we picked up the default initializer.
1415 }
1416
1417 void StmtPrinter::VisitCXXFunctionalCastExpr(CXXFunctionalCastExpr *Node) {
1418   Node->getType().print(OS, Policy);
1419   OS << "(";
1420   PrintExpr(Node->getSubExpr());
1421   OS << ")";
1422 }
1423
1424 void StmtPrinter::VisitCXXBindTemporaryExpr(CXXBindTemporaryExpr *Node) {
1425   PrintExpr(Node->getSubExpr());
1426 }
1427
1428 void StmtPrinter::VisitCXXTemporaryObjectExpr(CXXTemporaryObjectExpr *Node) {
1429   Node->getType().print(OS, Policy);
1430   OS << "(";
1431   for (CXXTemporaryObjectExpr::arg_iterator Arg = Node->arg_begin(),
1432                                          ArgEnd = Node->arg_end();
1433        Arg != ArgEnd; ++Arg) {
1434     if (Arg->isDefaultArgument())
1435       break;
1436     if (Arg != Node->arg_begin())
1437       OS << ", ";
1438     PrintExpr(*Arg);
1439   }
1440   OS << ")";
1441 }
1442
1443 void StmtPrinter::VisitLambdaExpr(LambdaExpr *Node) {
1444   OS << '[';
1445   bool NeedComma = false;
1446   switch (Node->getCaptureDefault()) {
1447   case LCD_None:
1448     break;
1449
1450   case LCD_ByCopy:
1451     OS << '=';
1452     NeedComma = true;
1453     break;
1454
1455   case LCD_ByRef:
1456     OS << '&';
1457     NeedComma = true;
1458     break;
1459   }
1460   for (LambdaExpr::capture_iterator C = Node->explicit_capture_begin(),
1461                                  CEnd = Node->explicit_capture_end();
1462        C != CEnd;
1463        ++C) {
1464     if (NeedComma)
1465       OS << ", ";
1466     NeedComma = true;
1467
1468     switch (C->getCaptureKind()) {
1469     case LCK_This:
1470       OS << "this";
1471       break;
1472
1473     case LCK_ByRef:
1474       if (Node->getCaptureDefault() != LCD_ByRef || C->isInitCapture())
1475         OS << '&';
1476       OS << C->getCapturedVar()->getName();
1477       break;
1478
1479     case LCK_ByCopy:
1480       OS << C->getCapturedVar()->getName();
1481       break;
1482     }
1483
1484     if (C->isInitCapture())
1485       PrintExpr(C->getCapturedVar()->getInit());
1486   }
1487   OS << ']';
1488
1489   if (Node->hasExplicitParameters()) {
1490     OS << " (";
1491     CXXMethodDecl *Method = Node->getCallOperator();
1492     NeedComma = false;
1493     for (CXXMethodDecl::param_iterator P = Method->param_begin(),
1494                                     PEnd = Method->param_end();
1495          P != PEnd; ++P) {
1496       if (NeedComma) {
1497         OS << ", ";
1498       } else {
1499         NeedComma = true;
1500       }
1501       std::string ParamStr = (*P)->getNameAsString();
1502       (*P)->getOriginalType().print(OS, Policy, ParamStr);
1503     }
1504     if (Method->isVariadic()) {
1505       if (NeedComma)
1506         OS << ", ";
1507       OS << "...";
1508     }
1509     OS << ')';
1510
1511     if (Node->isMutable())
1512       OS << " mutable";
1513
1514     const FunctionProtoType *Proto
1515       = Method->getType()->getAs<FunctionProtoType>();
1516     Proto->printExceptionSpecification(OS, Policy);
1517
1518     // FIXME: Attributes
1519
1520     // Print the trailing return type if it was specified in the source.
1521     if (Node->hasExplicitResultType()) {
1522       OS << " -> ";
1523       Proto->getResultType().print(OS, Policy);
1524     }
1525   }
1526
1527   // Print the body.
1528   CompoundStmt *Body = Node->getBody();
1529   OS << ' ';
1530   PrintStmt(Body);
1531 }
1532
1533 void StmtPrinter::VisitCXXScalarValueInitExpr(CXXScalarValueInitExpr *Node) {
1534   if (TypeSourceInfo *TSInfo = Node->getTypeSourceInfo())
1535     TSInfo->getType().print(OS, Policy);
1536   else
1537     Node->getType().print(OS, Policy);
1538   OS << "()";
1539 }
1540
1541 void StmtPrinter::VisitCXXNewExpr(CXXNewExpr *E) {
1542   if (E->isGlobalNew())
1543     OS << "::";
1544   OS << "new ";
1545   unsigned NumPlace = E->getNumPlacementArgs();
1546   if (NumPlace > 0 && !isa<CXXDefaultArgExpr>(E->getPlacementArg(0))) {
1547     OS << "(";
1548     PrintExpr(E->getPlacementArg(0));
1549     for (unsigned i = 1; i < NumPlace; ++i) {
1550       if (isa<CXXDefaultArgExpr>(E->getPlacementArg(i)))
1551         break;
1552       OS << ", ";
1553       PrintExpr(E->getPlacementArg(i));
1554     }
1555     OS << ") ";
1556   }
1557   if (E->isParenTypeId())
1558     OS << "(";
1559   std::string TypeS;
1560   if (Expr *Size = E->getArraySize()) {
1561     llvm::raw_string_ostream s(TypeS);
1562     s << '[';
1563     Size->printPretty(s, Helper, Policy);
1564     s << ']';
1565   }
1566   E->getAllocatedType().print(OS, Policy, TypeS);
1567   if (E->isParenTypeId())
1568     OS << ")";
1569
1570   CXXNewExpr::InitializationStyle InitStyle = E->getInitializationStyle();
1571   if (InitStyle) {
1572     if (InitStyle == CXXNewExpr::CallInit)
1573       OS << "(";
1574     PrintExpr(E->getInitializer());
1575     if (InitStyle == CXXNewExpr::CallInit)
1576       OS << ")";
1577   }
1578 }
1579
1580 void StmtPrinter::VisitCXXDeleteExpr(CXXDeleteExpr *E) {
1581   if (E->isGlobalDelete())
1582     OS << "::";
1583   OS << "delete ";
1584   if (E->isArrayForm())
1585     OS << "[] ";
1586   PrintExpr(E->getArgument());
1587 }
1588
1589 void StmtPrinter::VisitCXXPseudoDestructorExpr(CXXPseudoDestructorExpr *E) {
1590   PrintExpr(E->getBase());
1591   if (E->isArrow())
1592     OS << "->";
1593   else
1594     OS << '.';
1595   if (E->getQualifier())
1596     E->getQualifier()->print(OS, Policy);
1597   OS << "~";
1598
1599   if (IdentifierInfo *II = E->getDestroyedTypeIdentifier())
1600     OS << II->getName();
1601   else
1602     E->getDestroyedType().print(OS, Policy);
1603 }
1604
1605 void StmtPrinter::VisitCXXConstructExpr(CXXConstructExpr *E) {
1606   if (E->isListInitialization())
1607     OS << "{ ";
1608
1609   for (unsigned i = 0, e = E->getNumArgs(); i != e; ++i) {
1610     if (isa<CXXDefaultArgExpr>(E->getArg(i))) {
1611       // Don't print any defaulted arguments
1612       break;
1613     }
1614
1615     if (i) OS << ", ";
1616     PrintExpr(E->getArg(i));
1617   }
1618
1619   if (E->isListInitialization())
1620     OS << " }";
1621 }
1622
1623 void StmtPrinter::VisitCXXStdInitializerListExpr(CXXStdInitializerListExpr *E) {
1624   PrintExpr(E->getSubExpr());
1625 }
1626
1627 void StmtPrinter::VisitExprWithCleanups(ExprWithCleanups *E) {
1628   // Just forward to the sub expression.
1629   PrintExpr(E->getSubExpr());
1630 }
1631
1632 void
1633 StmtPrinter::VisitCXXUnresolvedConstructExpr(
1634                                            CXXUnresolvedConstructExpr *Node) {
1635   Node->getTypeAsWritten().print(OS, Policy);
1636   OS << "(";
1637   for (CXXUnresolvedConstructExpr::arg_iterator Arg = Node->arg_begin(),
1638                                              ArgEnd = Node->arg_end();
1639        Arg != ArgEnd; ++Arg) {
1640     if (Arg != Node->arg_begin())
1641       OS << ", ";
1642     PrintExpr(*Arg);
1643   }
1644   OS << ")";
1645 }
1646
1647 void StmtPrinter::VisitCXXDependentScopeMemberExpr(
1648                                          CXXDependentScopeMemberExpr *Node) {
1649   if (!Node->isImplicitAccess()) {
1650     PrintExpr(Node->getBase());
1651     OS << (Node->isArrow() ? "->" : ".");
1652   }
1653   if (NestedNameSpecifier *Qualifier = Node->getQualifier())
1654     Qualifier->print(OS, Policy);
1655   if (Node->hasTemplateKeyword())
1656     OS << "template ";
1657   OS << Node->getMemberNameInfo();
1658   if (Node->hasExplicitTemplateArgs())
1659     TemplateSpecializationType::PrintTemplateArgumentList(
1660         OS, Node->getTemplateArgs(), Node->getNumTemplateArgs(), Policy);
1661 }
1662
1663 void StmtPrinter::VisitUnresolvedMemberExpr(UnresolvedMemberExpr *Node) {
1664   if (!Node->isImplicitAccess()) {
1665     PrintExpr(Node->getBase());
1666     OS << (Node->isArrow() ? "->" : ".");
1667   }
1668   if (NestedNameSpecifier *Qualifier = Node->getQualifier())
1669     Qualifier->print(OS, Policy);
1670   if (Node->hasTemplateKeyword())
1671     OS << "template ";
1672   OS << Node->getMemberNameInfo();
1673   if (Node->hasExplicitTemplateArgs())
1674     TemplateSpecializationType::PrintTemplateArgumentList(
1675         OS, Node->getTemplateArgs(), Node->getNumTemplateArgs(), Policy);
1676 }
1677
1678 static const char *getTypeTraitName(UnaryTypeTrait UTT) {
1679   switch (UTT) {
1680   case UTT_HasNothrowAssign:      return "__has_nothrow_assign";
1681   case UTT_HasNothrowMoveAssign:  return "__has_nothrow_move_assign";
1682   case UTT_HasNothrowConstructor: return "__has_nothrow_constructor";
1683   case UTT_HasNothrowCopy:          return "__has_nothrow_copy";
1684   case UTT_HasTrivialAssign:      return "__has_trivial_assign";
1685   case UTT_HasTrivialMoveAssign:      return "__has_trivial_move_assign";
1686   case UTT_HasTrivialMoveConstructor: return "__has_trivial_move_constructor";
1687   case UTT_HasTrivialDefaultConstructor: return "__has_trivial_constructor";
1688   case UTT_HasTrivialCopy:          return "__has_trivial_copy";
1689   case UTT_HasTrivialDestructor:  return "__has_trivial_destructor";
1690   case UTT_HasVirtualDestructor:  return "__has_virtual_destructor";
1691   case UTT_IsAbstract:            return "__is_abstract";
1692   case UTT_IsArithmetic:            return "__is_arithmetic";
1693   case UTT_IsArray:                 return "__is_array";
1694   case UTT_IsClass:               return "__is_class";
1695   case UTT_IsCompleteType:          return "__is_complete_type";
1696   case UTT_IsCompound:              return "__is_compound";
1697   case UTT_IsConst:                 return "__is_const";
1698   case UTT_IsEmpty:               return "__is_empty";
1699   case UTT_IsEnum:                return "__is_enum";
1700   case UTT_IsFinal:                 return "__is_final";
1701   case UTT_IsFloatingPoint:         return "__is_floating_point";
1702   case UTT_IsFunction:              return "__is_function";
1703   case UTT_IsFundamental:           return "__is_fundamental";
1704   case UTT_IsIntegral:              return "__is_integral";
1705   case UTT_IsInterfaceClass:        return "__is_interface_class";
1706   case UTT_IsLiteral:               return "__is_literal";
1707   case UTT_IsLvalueReference:       return "__is_lvalue_reference";
1708   case UTT_IsMemberFunctionPointer: return "__is_member_function_pointer";
1709   case UTT_IsMemberObjectPointer:   return "__is_member_object_pointer";
1710   case UTT_IsMemberPointer:         return "__is_member_pointer";
1711   case UTT_IsObject:                return "__is_object";
1712   case UTT_IsPOD:                 return "__is_pod";
1713   case UTT_IsPointer:               return "__is_pointer";
1714   case UTT_IsPolymorphic:         return "__is_polymorphic";
1715   case UTT_IsReference:             return "__is_reference";
1716   case UTT_IsRvalueReference:       return "__is_rvalue_reference";
1717   case UTT_IsScalar:                return "__is_scalar";
1718   case UTT_IsSealed:                return "__is_sealed";
1719   case UTT_IsSigned:                return "__is_signed";
1720   case UTT_IsStandardLayout:        return "__is_standard_layout";
1721   case UTT_IsTrivial:               return "__is_trivial";
1722   case UTT_IsTriviallyCopyable:     return "__is_trivially_copyable";
1723   case UTT_IsUnion:               return "__is_union";
1724   case UTT_IsUnsigned:              return "__is_unsigned";
1725   case UTT_IsVoid:                  return "__is_void";
1726   case UTT_IsVolatile:              return "__is_volatile";
1727   }
1728   llvm_unreachable("Type trait not covered by switch statement");
1729 }
1730
1731 static const char *getTypeTraitName(BinaryTypeTrait BTT) {
1732   switch (BTT) {
1733   case BTT_IsBaseOf:              return "__is_base_of";
1734   case BTT_IsConvertible:         return "__is_convertible";
1735   case BTT_IsSame:                return "__is_same";
1736   case BTT_TypeCompatible:        return "__builtin_types_compatible_p";
1737   case BTT_IsConvertibleTo:       return "__is_convertible_to";
1738   case BTT_IsTriviallyAssignable: return "__is_trivially_assignable";
1739   }
1740   llvm_unreachable("Binary type trait not covered by switch");
1741 }
1742
1743 static const char *getTypeTraitName(TypeTrait TT) {
1744   switch (TT) {
1745   case clang::TT_IsTriviallyConstructible:return "__is_trivially_constructible";
1746   }
1747   llvm_unreachable("Type trait not covered by switch");
1748 }
1749
1750 static const char *getTypeTraitName(ArrayTypeTrait ATT) {
1751   switch (ATT) {
1752   case ATT_ArrayRank:        return "__array_rank";
1753   case ATT_ArrayExtent:      return "__array_extent";
1754   }
1755   llvm_unreachable("Array type trait not covered by switch");
1756 }
1757
1758 static const char *getExpressionTraitName(ExpressionTrait ET) {
1759   switch (ET) {
1760   case ET_IsLValueExpr:      return "__is_lvalue_expr";
1761   case ET_IsRValueExpr:      return "__is_rvalue_expr";
1762   }
1763   llvm_unreachable("Expression type trait not covered by switch");
1764 }
1765
1766 void StmtPrinter::VisitUnaryTypeTraitExpr(UnaryTypeTraitExpr *E) {
1767   OS << getTypeTraitName(E->getTrait()) << '(';
1768   E->getQueriedType().print(OS, Policy);
1769   OS << ')';
1770 }
1771
1772 void StmtPrinter::VisitBinaryTypeTraitExpr(BinaryTypeTraitExpr *E) {
1773   OS << getTypeTraitName(E->getTrait()) << '(';
1774   E->getLhsType().print(OS, Policy);
1775   OS << ',';
1776   E->getRhsType().print(OS, Policy);
1777   OS << ')';
1778 }
1779
1780 void StmtPrinter::VisitTypeTraitExpr(TypeTraitExpr *E) {
1781   OS << getTypeTraitName(E->getTrait()) << "(";
1782   for (unsigned I = 0, N = E->getNumArgs(); I != N; ++I) {
1783     if (I > 0)
1784       OS << ", ";
1785     E->getArg(I)->getType().print(OS, Policy);
1786   }
1787   OS << ")";
1788 }
1789
1790 void StmtPrinter::VisitArrayTypeTraitExpr(ArrayTypeTraitExpr *E) {
1791   OS << getTypeTraitName(E->getTrait()) << '(';
1792   E->getQueriedType().print(OS, Policy);
1793   OS << ')';
1794 }
1795
1796 void StmtPrinter::VisitExpressionTraitExpr(ExpressionTraitExpr *E) {
1797   OS << getExpressionTraitName(E->getTrait()) << '(';
1798   PrintExpr(E->getQueriedExpression());
1799   OS << ')';
1800 }
1801
1802 void StmtPrinter::VisitCXXNoexceptExpr(CXXNoexceptExpr *E) {
1803   OS << "noexcept(";
1804   PrintExpr(E->getOperand());
1805   OS << ")";
1806 }
1807
1808 void StmtPrinter::VisitPackExpansionExpr(PackExpansionExpr *E) {
1809   PrintExpr(E->getPattern());
1810   OS << "...";
1811 }
1812
1813 void StmtPrinter::VisitSizeOfPackExpr(SizeOfPackExpr *E) {
1814   OS << "sizeof...(" << *E->getPack() << ")";
1815 }
1816
1817 void StmtPrinter::VisitSubstNonTypeTemplateParmPackExpr(
1818                                        SubstNonTypeTemplateParmPackExpr *Node) {
1819   OS << *Node->getParameterPack();
1820 }
1821
1822 void StmtPrinter::VisitSubstNonTypeTemplateParmExpr(
1823                                        SubstNonTypeTemplateParmExpr *Node) {
1824   Visit(Node->getReplacement());
1825 }
1826
1827 void StmtPrinter::VisitFunctionParmPackExpr(FunctionParmPackExpr *E) {
1828   OS << *E->getParameterPack();
1829 }
1830
1831 void StmtPrinter::VisitMaterializeTemporaryExpr(MaterializeTemporaryExpr *Node){
1832   PrintExpr(Node->GetTemporaryExpr());
1833 }
1834
1835 // Obj-C
1836
1837 void StmtPrinter::VisitObjCStringLiteral(ObjCStringLiteral *Node) {
1838   OS << "@";
1839   VisitStringLiteral(Node->getString());
1840 }
1841
1842 void StmtPrinter::VisitObjCBoxedExpr(ObjCBoxedExpr *E) {
1843   OS << "@";
1844   Visit(E->getSubExpr());
1845 }
1846
1847 void StmtPrinter::VisitObjCArrayLiteral(ObjCArrayLiteral *E) {
1848   OS << "@[ ";
1849   StmtRange ch = E->children();
1850   if (ch.first != ch.second) {
1851     while (1) {
1852       Visit(*ch.first);
1853       ++ch.first;
1854       if (ch.first == ch.second) break;
1855       OS << ", ";
1856     }
1857   }
1858   OS << " ]";
1859 }
1860
1861 void StmtPrinter::VisitObjCDictionaryLiteral(ObjCDictionaryLiteral *E) {
1862   OS << "@{ ";
1863   for (unsigned I = 0, N = E->getNumElements(); I != N; ++I) {
1864     if (I > 0)
1865       OS << ", ";
1866     
1867     ObjCDictionaryElement Element = E->getKeyValueElement(I);
1868     Visit(Element.Key);
1869     OS << " : ";
1870     Visit(Element.Value);
1871     if (Element.isPackExpansion())
1872       OS << "...";
1873   }
1874   OS << " }";
1875 }
1876
1877 void StmtPrinter::VisitObjCEncodeExpr(ObjCEncodeExpr *Node) {
1878   OS << "@encode(";
1879   Node->getEncodedType().print(OS, Policy);
1880   OS << ')';
1881 }
1882
1883 void StmtPrinter::VisitObjCSelectorExpr(ObjCSelectorExpr *Node) {
1884   OS << "@selector(" << Node->getSelector().getAsString() << ')';
1885 }
1886
1887 void StmtPrinter::VisitObjCProtocolExpr(ObjCProtocolExpr *Node) {
1888   OS << "@protocol(" << *Node->getProtocol() << ')';
1889 }
1890
1891 void StmtPrinter::VisitObjCMessageExpr(ObjCMessageExpr *Mess) {
1892   OS << "[";
1893   switch (Mess->getReceiverKind()) {
1894   case ObjCMessageExpr::Instance:
1895     PrintExpr(Mess->getInstanceReceiver());
1896     break;
1897
1898   case ObjCMessageExpr::Class:
1899     Mess->getClassReceiver().print(OS, Policy);
1900     break;
1901
1902   case ObjCMessageExpr::SuperInstance:
1903   case ObjCMessageExpr::SuperClass:
1904     OS << "Super";
1905     break;
1906   }
1907
1908   OS << ' ';
1909   Selector selector = Mess->getSelector();
1910   if (selector.isUnarySelector()) {
1911     OS << selector.getNameForSlot(0);
1912   } else {
1913     for (unsigned i = 0, e = Mess->getNumArgs(); i != e; ++i) {
1914       if (i < selector.getNumArgs()) {
1915         if (i > 0) OS << ' ';
1916         if (selector.getIdentifierInfoForSlot(i))
1917           OS << selector.getIdentifierInfoForSlot(i)->getName() << ':';
1918         else
1919            OS << ":";
1920       }
1921       else OS << ", "; // Handle variadic methods.
1922
1923       PrintExpr(Mess->getArg(i));
1924     }
1925   }
1926   OS << "]";
1927 }
1928
1929 void StmtPrinter::VisitObjCBoolLiteralExpr(ObjCBoolLiteralExpr *Node) {
1930   OS << (Node->getValue() ? "__objc_yes" : "__objc_no");
1931 }
1932
1933 void
1934 StmtPrinter::VisitObjCIndirectCopyRestoreExpr(ObjCIndirectCopyRestoreExpr *E) {
1935   PrintExpr(E->getSubExpr());
1936 }
1937
1938 void
1939 StmtPrinter::VisitObjCBridgedCastExpr(ObjCBridgedCastExpr *E) {
1940   OS << '(' << E->getBridgeKindName();
1941   E->getType().print(OS, Policy);
1942   OS << ')';
1943   PrintExpr(E->getSubExpr());
1944 }
1945
1946 void StmtPrinter::VisitBlockExpr(BlockExpr *Node) {
1947   BlockDecl *BD = Node->getBlockDecl();
1948   OS << "^";
1949
1950   const FunctionType *AFT = Node->getFunctionType();
1951
1952   if (isa<FunctionNoProtoType>(AFT)) {
1953     OS << "()";
1954   } else if (!BD->param_empty() || cast<FunctionProtoType>(AFT)->isVariadic()) {
1955     OS << '(';
1956     for (BlockDecl::param_iterator AI = BD->param_begin(),
1957          E = BD->param_end(); AI != E; ++AI) {
1958       if (AI != BD->param_begin()) OS << ", ";
1959       std::string ParamStr = (*AI)->getNameAsString();
1960       (*AI)->getType().print(OS, Policy, ParamStr);
1961     }
1962
1963     const FunctionProtoType *FT = cast<FunctionProtoType>(AFT);
1964     if (FT->isVariadic()) {
1965       if (!BD->param_empty()) OS << ", ";
1966       OS << "...";
1967     }
1968     OS << ')';
1969   }
1970   OS << "{ }";
1971 }
1972
1973 void StmtPrinter::VisitOpaqueValueExpr(OpaqueValueExpr *Node) { 
1974   PrintExpr(Node->getSourceExpr());
1975 }
1976
1977 void StmtPrinter::VisitAsTypeExpr(AsTypeExpr *Node) {
1978   OS << "__builtin_astype(";
1979   PrintExpr(Node->getSrcExpr());
1980   OS << ", ";
1981   Node->getType().print(OS, Policy);
1982   OS << ")";
1983 }
1984
1985 //===----------------------------------------------------------------------===//
1986 // Stmt method implementations
1987 //===----------------------------------------------------------------------===//
1988
1989 void Stmt::dumpPretty(const ASTContext &Context) const {
1990   printPretty(llvm::errs(), 0, PrintingPolicy(Context.getLangOpts()));
1991 }
1992
1993 void Stmt::printPretty(raw_ostream &OS,
1994                        PrinterHelper *Helper,
1995                        const PrintingPolicy &Policy,
1996                        unsigned Indentation) const {
1997   if (this == 0) {
1998     OS << "<NULL>";
1999     return;
2000   }
2001
2002   StmtPrinter P(OS, Helper, Policy, Indentation);
2003   P.Visit(const_cast<Stmt*>(this));
2004 }
2005
2006 //===----------------------------------------------------------------------===//
2007 // PrinterHelper
2008 //===----------------------------------------------------------------------===//
2009
2010 // Implement virtual destructor.
2011 PrinterHelper::~PrinterHelper() {}