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