blob: 846bd4ce14417b2c804a68d97df60a15e18b307a [file] [log] [blame]
Chris Lattner6000dac2007-08-08 22:51:59 +00001//===--- StmtDumper.cpp - Dumping implementation for Stmt ASTs ------------===//
2//
3// The LLVM Compiler Infrastructure
4//
Chris Lattner0bc735f2007-12-29 19:59:25 +00005// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
Chris Lattner6000dac2007-08-08 22:51:59 +00007//
8//===----------------------------------------------------------------------===//
9//
10// This file implements the Stmt::dump/Stmt::print methods, which dump out the
11// AST in a form that exposes type details and other fields.
12//
13//===----------------------------------------------------------------------===//
14
15#include "clang/AST/StmtVisitor.h"
Ted Kremenek91d1d7a2007-10-17 18:36:42 +000016#include "clang/AST/DeclObjC.h"
Douglas Gregor2a3009a2009-02-03 19:21:40 +000017#include "clang/AST/DeclCXX.h"
Douglas Gregord249e1d1f2009-05-29 20:38:28 +000018#include "clang/AST/PrettyPrinter.h"
Chris Lattnere300c872007-08-30 06:17:34 +000019#include "clang/Basic/SourceManager.h"
Daniel Dunbar806c12e2009-12-03 09:13:13 +000020#include "llvm/Support/raw_ostream.h"
Chris Lattner6000dac2007-08-08 22:51:59 +000021using namespace clang;
22
23//===----------------------------------------------------------------------===//
24// StmtDumper Visitor
25//===----------------------------------------------------------------------===//
26
27namespace {
Benjamin Kramer770b4a82009-11-28 19:03:38 +000028 class StmtDumper : public StmtVisitor<StmtDumper> {
Chris Lattnere300c872007-08-30 06:17:34 +000029 SourceManager *SM;
Daniel Dunbar806c12e2009-12-03 09:13:13 +000030 llvm::raw_ostream &OS;
Chris Lattner6000dac2007-08-08 22:51:59 +000031 unsigned IndentLevel;
Mike Stump1eb44332009-09-09 15:08:12 +000032
Chris Lattner6000dac2007-08-08 22:51:59 +000033 /// MaxDepth - When doing a normal dump (not dumpAll) we only want to dump
34 /// the first few levels of an AST. This keeps track of how many ast levels
35 /// are left.
36 unsigned MaxDepth;
Mike Stump1eb44332009-09-09 15:08:12 +000037
Chris Lattnere300c872007-08-30 06:17:34 +000038 /// LastLocFilename/LastLocLine - Keep track of the last location we print
39 /// out so that we can print out deltas from then on out.
40 const char *LastLocFilename;
41 unsigned LastLocLine;
Douglas Gregord249e1d1f2009-05-29 20:38:28 +000042
Chris Lattner6000dac2007-08-08 22:51:59 +000043 public:
Daniel Dunbar806c12e2009-12-03 09:13:13 +000044 StmtDumper(SourceManager *sm, llvm::raw_ostream &os, unsigned maxDepth)
45 : SM(sm), OS(os), IndentLevel(0-1), MaxDepth(maxDepth) {
Chris Lattnere300c872007-08-30 06:17:34 +000046 LastLocFilename = "";
47 LastLocLine = ~0U;
48 }
Mike Stump1eb44332009-09-09 15:08:12 +000049
Chris Lattnerf9e05812007-08-09 18:03:18 +000050 void DumpSubTree(Stmt *S) {
Chris Lattner6000dac2007-08-08 22:51:59 +000051 // Prune the recursion if not using dump all.
52 if (MaxDepth == 0) return;
Mike Stump1eb44332009-09-09 15:08:12 +000053
Chris Lattnerf9e05812007-08-09 18:03:18 +000054 ++IndentLevel;
Chris Lattner6000dac2007-08-08 22:51:59 +000055 if (S) {
Ted Kremenek5399ce22007-12-12 06:59:42 +000056 if (DeclStmt* DS = dyn_cast<DeclStmt>(S))
57 VisitDeclStmt(DS);
Mike Stump1eb44332009-09-09 15:08:12 +000058 else {
Ted Kremenek5399ce22007-12-12 06:59:42 +000059 Visit(S);
Mike Stump1eb44332009-09-09 15:08:12 +000060
Ted Kremenek5399ce22007-12-12 06:59:42 +000061 // Print out children.
John McCall7502c1d2011-02-13 04:07:26 +000062 Stmt::child_range CI = S->children();
63 if (CI) {
64 while (CI) {
Daniel Dunbar806c12e2009-12-03 09:13:13 +000065 OS << '\n';
Ted Kremenek5399ce22007-12-12 06:59:42 +000066 DumpSubTree(*CI++);
67 }
Chris Lattnerb3938792007-08-30 00:53:54 +000068 }
69 }
Chris Lattnera46325e2010-05-25 17:56:43 +000070 OS << ')';
Chris Lattner6000dac2007-08-08 22:51:59 +000071 } else {
72 Indent();
Daniel Dunbar806c12e2009-12-03 09:13:13 +000073 OS << "<<<NULL>>>";
Chris Lattner6000dac2007-08-08 22:51:59 +000074 }
Chris Lattnerf9e05812007-08-09 18:03:18 +000075 --IndentLevel;
Chris Lattner6000dac2007-08-08 22:51:59 +000076 }
Mike Stump1eb44332009-09-09 15:08:12 +000077
Chris Lattnerf9e05812007-08-09 18:03:18 +000078 void DumpDeclarator(Decl *D);
Mike Stump1eb44332009-09-09 15:08:12 +000079
Chris Lattner6000dac2007-08-08 22:51:59 +000080 void Indent() const {
81 for (int i = 0, e = IndentLevel; i < e; ++i)
Daniel Dunbar806c12e2009-12-03 09:13:13 +000082 OS << " ";
Chris Lattner6000dac2007-08-08 22:51:59 +000083 }
Mike Stump1eb44332009-09-09 15:08:12 +000084
Steve Naroff9dcbfa42007-09-01 21:08:38 +000085 void DumpType(QualType T) {
John McCall49f4e1c2010-12-10 11:01:00 +000086 SplitQualType T_split = T.split();
87 OS << "'" << QualType::getAsString(T_split) << "'";
Chris Lattnerfd8f7da2007-08-09 00:36:22 +000088
Douglas Gregor61366e92008-12-24 00:01:03 +000089 if (!T.isNull()) {
John McCall0953e762009-09-24 19:53:00 +000090 // If the type is sugared, also dump a (shallow) desugared type.
John McCall49f4e1c2010-12-10 11:01:00 +000091 SplitQualType D_split = T.getSplitDesugaredType();
92 if (T_split != D_split)
93 OS << ":'" << QualType::getAsString(D_split) << "'";
Chris Lattnerbad37852008-04-02 05:06:23 +000094 }
Chris Lattnerfd8f7da2007-08-09 00:36:22 +000095 }
John McCall6b5a61b2011-02-07 10:33:21 +000096 void DumpDeclRef(Decl *node);
Steve Naroff9dcbfa42007-09-01 21:08:38 +000097 void DumpStmt(const Stmt *Node) {
Chris Lattner6000dac2007-08-08 22:51:59 +000098 Indent();
Daniel Dunbar806c12e2009-12-03 09:13:13 +000099 OS << "(" << Node->getStmtClassName()
100 << " " << (void*)Node;
Steve Naroff9dcbfa42007-09-01 21:08:38 +0000101 DumpSourceRange(Node);
Chris Lattner6000dac2007-08-08 22:51:59 +0000102 }
John McCallf89e55a2010-11-18 06:31:45 +0000103 void DumpValueKind(ExprValueKind K) {
104 switch (K) {
105 case VK_RValue: break;
106 case VK_LValue: OS << " lvalue"; break;
107 case VK_XValue: OS << " xvalue"; break;
108 }
109 }
110 void DumpObjectKind(ExprObjectKind K) {
111 switch (K) {
112 case OK_Ordinary: break;
113 case OK_BitField: OS << " bitfield"; break;
114 case OK_ObjCProperty: OS << " objcproperty"; break;
115 case OK_VectorComponent: OS << " vectorcomponent"; break;
116 }
117 }
Steve Naroff9dcbfa42007-09-01 21:08:38 +0000118 void DumpExpr(const Expr *Node) {
Chris Lattner6000dac2007-08-08 22:51:59 +0000119 DumpStmt(Node);
Daniel Dunbar806c12e2009-12-03 09:13:13 +0000120 OS << ' ';
Chris Lattnerfd8f7da2007-08-09 00:36:22 +0000121 DumpType(Node->getType());
John McCallf89e55a2010-11-18 06:31:45 +0000122 DumpValueKind(Node->getValueKind());
123 DumpObjectKind(Node->getObjectKind());
Chris Lattner6000dac2007-08-08 22:51:59 +0000124 }
Steve Naroff9dcbfa42007-09-01 21:08:38 +0000125 void DumpSourceRange(const Stmt *Node);
Chris Lattnere300c872007-08-30 06:17:34 +0000126 void DumpLocation(SourceLocation Loc);
Mike Stump1eb44332009-09-09 15:08:12 +0000127
Chris Lattner17a1a722007-08-30 01:00:35 +0000128 // Stmts.
Chris Lattnerc5598cb2007-08-21 04:04:25 +0000129 void VisitStmt(Stmt *Node);
Ted Kremenek5399ce22007-12-12 06:59:42 +0000130 void VisitDeclStmt(DeclStmt *Node);
Chris Lattner17a1a722007-08-30 01:00:35 +0000131 void VisitLabelStmt(LabelStmt *Node);
132 void VisitGotoStmt(GotoStmt *Node);
Mike Stump1eb44332009-09-09 15:08:12 +0000133
Chris Lattner17a1a722007-08-30 01:00:35 +0000134 // Exprs
135 void VisitExpr(Expr *Node);
Anders Carlsson27a5b9b2009-08-22 23:33:40 +0000136 void VisitCastExpr(CastExpr *Node);
Chris Lattner17a1a722007-08-30 01:00:35 +0000137 void VisitDeclRefExpr(DeclRefExpr *Node);
Chris Lattnerd9f69102008-08-10 01:53:14 +0000138 void VisitPredefinedExpr(PredefinedExpr *Node);
Chris Lattner17a1a722007-08-30 01:00:35 +0000139 void VisitCharacterLiteral(CharacterLiteral *Node);
140 void VisitIntegerLiteral(IntegerLiteral *Node);
141 void VisitFloatingLiteral(FloatingLiteral *Node);
142 void VisitStringLiteral(StringLiteral *Str);
143 void VisitUnaryOperator(UnaryOperator *Node);
Sebastian Redl05189992008-11-11 17:56:53 +0000144 void VisitSizeOfAlignOfExpr(SizeOfAlignOfExpr *Node);
Chris Lattner17a1a722007-08-30 01:00:35 +0000145 void VisitMemberExpr(MemberExpr *Node);
Nate Begeman213541a2008-04-18 23:10:10 +0000146 void VisitExtVectorElementExpr(ExtVectorElementExpr *Node);
Chris Lattner17a1a722007-08-30 01:00:35 +0000147 void VisitBinaryOperator(BinaryOperator *Node);
148 void VisitCompoundAssignOperator(CompoundAssignOperator *Node);
149 void VisitAddrLabelExpr(AddrLabelExpr *Node);
John McCall6b5a61b2011-02-07 10:33:21 +0000150 void VisitBlockExpr(BlockExpr *Node);
Chris Lattner17a1a722007-08-30 01:00:35 +0000151
152 // C++
Douglas Gregor49badde2008-10-27 19:41:14 +0000153 void VisitCXXNamedCastExpr(CXXNamedCastExpr *Node);
Chris Lattner17a1a722007-08-30 01:00:35 +0000154 void VisitCXXBoolLiteralExpr(CXXBoolLiteralExpr *Node);
Douglas Gregorcd9b46e2008-11-04 14:56:14 +0000155 void VisitCXXThisExpr(CXXThisExpr *Node);
Douglas Gregor49badde2008-10-27 19:41:14 +0000156 void VisitCXXFunctionalCastExpr(CXXFunctionalCastExpr *Node);
Anders Carlsson0eca1b62009-08-12 00:21:52 +0000157 void VisitCXXConstructExpr(CXXConstructExpr *Node);
158 void VisitCXXBindTemporaryExpr(CXXBindTemporaryExpr *Node);
John McCall4765fa02010-12-06 08:20:24 +0000159 void VisitExprWithCleanups(ExprWithCleanups *Node);
John McCall9d5f35e2009-12-11 21:50:11 +0000160 void VisitUnresolvedLookupExpr(UnresolvedLookupExpr *Node);
Anders Carlsson0eca1b62009-08-12 00:21:52 +0000161 void DumpCXXTemporary(CXXTemporary *Temporary);
Mike Stump1eb44332009-09-09 15:08:12 +0000162
Chris Lattner17a1a722007-08-30 01:00:35 +0000163 // ObjC
Douglas Gregor8f5e3dd2010-04-23 22:50:49 +0000164 void VisitObjCAtCatchStmt(ObjCAtCatchStmt *Node);
Chris Lattner17a1a722007-08-30 01:00:35 +0000165 void VisitObjCEncodeExpr(ObjCEncodeExpr *Node);
Ted Kremenekb3d914b2008-02-29 22:04:05 +0000166 void VisitObjCMessageExpr(ObjCMessageExpr* Node);
Fariborz Jahanianb62f6812007-10-16 20:40:23 +0000167 void VisitObjCSelectorExpr(ObjCSelectorExpr *Node);
Fariborz Jahanian390d50a2007-10-17 16:58:11 +0000168 void VisitObjCProtocolExpr(ObjCProtocolExpr *Node);
Daniel Dunbar7f8ea5c2008-08-30 05:35:15 +0000169 void VisitObjCPropertyRefExpr(ObjCPropertyRefExpr *Node);
Steve Naroff3c64d9e2008-03-12 13:19:12 +0000170 void VisitObjCIvarRefExpr(ObjCIvarRefExpr *Node);
Chris Lattner6000dac2007-08-08 22:51:59 +0000171 };
172}
173
174//===----------------------------------------------------------------------===//
Chris Lattnere300c872007-08-30 06:17:34 +0000175// Utilities
176//===----------------------------------------------------------------------===//
177
178void StmtDumper::DumpLocation(SourceLocation Loc) {
Chris Lattnerdf7c17a2009-01-16 07:00:02 +0000179 SourceLocation SpellingLoc = SM->getSpellingLoc(Loc);
Mike Stump1eb44332009-09-09 15:08:12 +0000180
Chris Lattnere300c872007-08-30 06:17:34 +0000181 // The general format we print out is filename:line:col, but we drop pieces
182 // that haven't changed since the last loc printed.
Chris Lattnerb9c3f962009-01-27 07:57:44 +0000183 PresumedLoc PLoc = SM->getPresumedLoc(SpellingLoc);
184
Douglas Gregorcb7b1e12010-11-12 07:15:47 +0000185 if (PLoc.isInvalid()) {
186 OS << "<invalid sloc>";
187 return;
188 }
189
Chris Lattnerb9c3f962009-01-27 07:57:44 +0000190 if (strcmp(PLoc.getFilename(), LastLocFilename) != 0) {
Daniel Dunbar806c12e2009-12-03 09:13:13 +0000191 OS << PLoc.getFilename() << ':' << PLoc.getLine()
192 << ':' << PLoc.getColumn();
Chris Lattnerb9c3f962009-01-27 07:57:44 +0000193 LastLocFilename = PLoc.getFilename();
194 LastLocLine = PLoc.getLine();
195 } else if (PLoc.getLine() != LastLocLine) {
Daniel Dunbar806c12e2009-12-03 09:13:13 +0000196 OS << "line" << ':' << PLoc.getLine()
197 << ':' << PLoc.getColumn();
Chris Lattnerb9c3f962009-01-27 07:57:44 +0000198 LastLocLine = PLoc.getLine();
Chris Lattnere300c872007-08-30 06:17:34 +0000199 } else {
Daniel Dunbar806c12e2009-12-03 09:13:13 +0000200 OS << "col" << ':' << PLoc.getColumn();
Chris Lattnere300c872007-08-30 06:17:34 +0000201 }
202}
203
Steve Naroff9dcbfa42007-09-01 21:08:38 +0000204void StmtDumper::DumpSourceRange(const Stmt *Node) {
Chris Lattnere300c872007-08-30 06:17:34 +0000205 // Can't translate locations if a SourceManager isn't available.
206 if (SM == 0) return;
Mike Stump1eb44332009-09-09 15:08:12 +0000207
Chris Lattnere300c872007-08-30 06:17:34 +0000208 // TODO: If the parent expression is available, we can print a delta vs its
209 // location.
210 SourceRange R = Node->getSourceRange();
Mike Stump1eb44332009-09-09 15:08:12 +0000211
Daniel Dunbar806c12e2009-12-03 09:13:13 +0000212 OS << " <";
Chris Lattner311ff022007-10-16 22:36:42 +0000213 DumpLocation(R.getBegin());
214 if (R.getBegin() != R.getEnd()) {
Daniel Dunbar806c12e2009-12-03 09:13:13 +0000215 OS << ", ";
Chris Lattner311ff022007-10-16 22:36:42 +0000216 DumpLocation(R.getEnd());
Chris Lattnere300c872007-08-30 06:17:34 +0000217 }
Daniel Dunbar806c12e2009-12-03 09:13:13 +0000218 OS << ">";
Mike Stump1eb44332009-09-09 15:08:12 +0000219
Chris Lattnere300c872007-08-30 06:17:34 +0000220 // <t2.c:123:421[blah], t2.c:412:321>
221
222}
223
224
225//===----------------------------------------------------------------------===//
Chris Lattner6000dac2007-08-08 22:51:59 +0000226// Stmt printing methods.
227//===----------------------------------------------------------------------===//
228
229void StmtDumper::VisitStmt(Stmt *Node) {
Chris Lattner17a1a722007-08-30 01:00:35 +0000230 DumpStmt(Node);
Chris Lattner6000dac2007-08-08 22:51:59 +0000231}
232
Chris Lattnerf9e05812007-08-09 18:03:18 +0000233void StmtDumper::DumpDeclarator(Decl *D) {
Chris Lattner6000dac2007-08-08 22:51:59 +0000234 // FIXME: Need to complete/beautify this... this code simply shows the
235 // nodes are where they need to be.
236 if (TypedefDecl *localType = dyn_cast<TypedefDecl>(D)) {
Daniel Dunbar806c12e2009-12-03 09:13:13 +0000237 OS << "\"typedef " << localType->getUnderlyingType().getAsString()
Benjamin Kramer900fc632010-04-17 09:33:03 +0000238 << ' ' << localType << '"';
Chris Lattner6000dac2007-08-08 22:51:59 +0000239 } else if (ValueDecl *VD = dyn_cast<ValueDecl>(D)) {
Daniel Dunbar806c12e2009-12-03 09:13:13 +0000240 OS << "\"";
Chris Lattner6000dac2007-08-08 22:51:59 +0000241 // Emit storage class for vardecls.
242 if (VarDecl *V = dyn_cast<VarDecl>(VD)) {
John McCalld931b082010-08-26 03:08:43 +0000243 if (V->getStorageClass() != SC_None)
Daniel Dunbar806c12e2009-12-03 09:13:13 +0000244 OS << VarDecl::getStorageClassSpecifierString(V->getStorageClass())
245 << " ";
Chris Lattner6000dac2007-08-08 22:51:59 +0000246 }
Mike Stump1eb44332009-09-09 15:08:12 +0000247
Chris Lattner39f34e92008-11-24 04:00:27 +0000248 std::string Name = VD->getNameAsString();
Mike Stump1eb44332009-09-09 15:08:12 +0000249 VD->getType().getAsStringInternal(Name,
Chris Lattnere4f21422009-06-30 01:26:17 +0000250 PrintingPolicy(VD->getASTContext().getLangOptions()));
Daniel Dunbar806c12e2009-12-03 09:13:13 +0000251 OS << Name;
Mike Stump1eb44332009-09-09 15:08:12 +0000252
Chris Lattner6000dac2007-08-08 22:51:59 +0000253 // If this is a vardecl with an initializer, emit it.
254 if (VarDecl *V = dyn_cast<VarDecl>(VD)) {
255 if (V->getInit()) {
Daniel Dunbar806c12e2009-12-03 09:13:13 +0000256 OS << " =\n";
Chris Lattnerf9e05812007-08-09 18:03:18 +0000257 DumpSubTree(V->getInit());
Chris Lattner6000dac2007-08-08 22:51:59 +0000258 }
259 }
Daniel Dunbar806c12e2009-12-03 09:13:13 +0000260 OS << '"';
Steve Naroff92199282007-11-17 21:37:36 +0000261 } else if (TagDecl *TD = dyn_cast<TagDecl>(D)) {
262 // print a free standing tag decl (e.g. "struct x;").
263 const char *tagname;
264 if (const IdentifierInfo *II = TD->getIdentifier())
Daniel Dunbare013d682009-10-18 20:26:12 +0000265 tagname = II->getNameStart();
Steve Naroff92199282007-11-17 21:37:36 +0000266 else
267 tagname = "<anonymous>";
Daniel Dunbar806c12e2009-12-03 09:13:13 +0000268 OS << '"' << TD->getKindName() << ' ' << tagname << ";\"";
Steve Naroff92199282007-11-17 21:37:36 +0000269 // FIXME: print tag bodies.
Douglas Gregor2a3009a2009-02-03 19:21:40 +0000270 } else if (UsingDirectiveDecl *UD = dyn_cast<UsingDirectiveDecl>(D)) {
271 // print using-directive decl (e.g. "using namespace x;")
272 const char *ns;
273 if (const IdentifierInfo *II = UD->getNominatedNamespace()->getIdentifier())
Daniel Dunbare013d682009-10-18 20:26:12 +0000274 ns = II->getNameStart();
Douglas Gregor2a3009a2009-02-03 19:21:40 +0000275 else
276 ns = "<anonymous>";
Daniel Dunbar806c12e2009-12-03 09:13:13 +0000277 OS << '"' << UD->getDeclKindName() << ns << ";\"";
Sebastian Redl0ca43592010-05-04 10:20:17 +0000278 } else if (UsingDecl *UD = dyn_cast<UsingDecl>(D)) {
279 // print using decl (e.g. "using std::string;")
280 const char *tn = UD->isTypeName() ? "typename " : "";
281 OS << '"' << UD->getDeclKindName() << tn;
282 UD->getTargetNestedNameDecl()->print(OS,
283 PrintingPolicy(UD->getASTContext().getLangOptions()));
284 OS << ";\"";
Chris Lattner4ae493c2011-02-18 02:08:43 +0000285 } else if (LabelDecl *LD = dyn_cast<LabelDecl>(D)) {
286 OS << "label " << LD->getNameAsString();
Chris Lattner6000dac2007-08-08 22:51:59 +0000287 } else {
Chris Lattner6000dac2007-08-08 22:51:59 +0000288 assert(0 && "Unexpected decl");
289 }
Chris Lattner6000dac2007-08-08 22:51:59 +0000290}
291
Ted Kremenek5399ce22007-12-12 06:59:42 +0000292void StmtDumper::VisitDeclStmt(DeclStmt *Node) {
293 DumpStmt(Node);
Daniel Dunbar806c12e2009-12-03 09:13:13 +0000294 OS << "\n";
Ted Kremenek04a72b72008-10-06 18:38:35 +0000295 for (DeclStmt::decl_iterator DI = Node->decl_begin(), DE = Node->decl_end();
296 DI != DE; ++DI) {
Douglas Gregor4afa39d2009-01-20 01:17:11 +0000297 Decl* D = *DI;
Ted Kremenek5399ce22007-12-12 06:59:42 +0000298 ++IndentLevel;
299 Indent();
Daniel Dunbar806c12e2009-12-03 09:13:13 +0000300 OS << (void*) D << " ";
Ted Kremenek5399ce22007-12-12 06:59:42 +0000301 DumpDeclarator(D);
Chris Lattnerf2797252009-03-29 16:04:50 +0000302 if (DI+1 != DE)
Daniel Dunbar806c12e2009-12-03 09:13:13 +0000303 OS << "\n";
Ted Kremenek5399ce22007-12-12 06:59:42 +0000304 --IndentLevel;
305 }
306}
307
Chris Lattner6000dac2007-08-08 22:51:59 +0000308void StmtDumper::VisitLabelStmt(LabelStmt *Node) {
309 DumpStmt(Node);
Daniel Dunbar806c12e2009-12-03 09:13:13 +0000310 OS << " '" << Node->getName() << "'";
Chris Lattner6000dac2007-08-08 22:51:59 +0000311}
312
Chris Lattner6000dac2007-08-08 22:51:59 +0000313void StmtDumper::VisitGotoStmt(GotoStmt *Node) {
314 DumpStmt(Node);
Daniel Dunbar806c12e2009-12-03 09:13:13 +0000315 OS << " '" << Node->getLabel()->getName()
316 << "':" << (void*)Node->getLabel();
Chris Lattner6000dac2007-08-08 22:51:59 +0000317}
318
Chris Lattner6000dac2007-08-08 22:51:59 +0000319//===----------------------------------------------------------------------===//
320// Expr printing methods.
321//===----------------------------------------------------------------------===//
322
323void StmtDumper::VisitExpr(Expr *Node) {
324 DumpExpr(Node);
Chris Lattner6000dac2007-08-08 22:51:59 +0000325}
326
Anders Carlsson5cf86ba2010-04-24 19:06:50 +0000327static void DumpBasePath(llvm::raw_ostream &OS, CastExpr *Node) {
John McCallf871d0c2010-08-07 06:22:56 +0000328 if (Node->path_empty())
Anders Carlsson5cf86ba2010-04-24 19:06:50 +0000329 return;
330
331 OS << " (";
332 bool First = true;
John McCallf871d0c2010-08-07 06:22:56 +0000333 for (CastExpr::path_iterator
334 I = Node->path_begin(), E = Node->path_end(); I != E; ++I) {
Anders Carlsson5cf86ba2010-04-24 19:06:50 +0000335 const CXXBaseSpecifier *Base = *I;
336 if (!First)
337 OS << " -> ";
338
339 const CXXRecordDecl *RD =
340 cast<CXXRecordDecl>(Base->getType()->getAs<RecordType>()->getDecl());
341
342 if (Base->isVirtual())
343 OS << "virtual ";
344 OS << RD->getName();
345 First = false;
346 }
347
348 OS << ')';
349}
350
Anders Carlsson27a5b9b2009-08-22 23:33:40 +0000351void StmtDumper::VisitCastExpr(CastExpr *Node) {
352 DumpExpr(Node);
Anders Carlsson5cf86ba2010-04-24 19:06:50 +0000353 OS << " <" << Node->getCastKindName();
354 DumpBasePath(OS, Node);
355 OS << ">";
Anders Carlsson27a5b9b2009-08-22 23:33:40 +0000356}
357
Chris Lattner6000dac2007-08-08 22:51:59 +0000358void StmtDumper::VisitDeclRefExpr(DeclRefExpr *Node) {
359 DumpExpr(Node);
Ted Kremenekeb641f92007-09-10 17:32:55 +0000360
Daniel Dunbar806c12e2009-12-03 09:13:13 +0000361 OS << " ";
John McCall6b5a61b2011-02-07 10:33:21 +0000362 DumpDeclRef(Node->getDecl());
363}
364
365void StmtDumper::DumpDeclRef(Decl *d) {
366 OS << d->getDeclKindName() << ' ' << (void*) d;
367
368 if (NamedDecl *nd = dyn_cast<NamedDecl>(d)) {
369 OS << " '";
370 nd->getDeclName().printName(OS);
371 OS << "'";
Ted Kremenekeb641f92007-09-10 17:32:55 +0000372 }
Mike Stump1eb44332009-09-09 15:08:12 +0000373
John McCall6b5a61b2011-02-07 10:33:21 +0000374 if (ValueDecl *vd = dyn_cast<ValueDecl>(d)) {
375 OS << ' '; DumpType(vd->getType());
376 }
Chris Lattner6000dac2007-08-08 22:51:59 +0000377}
378
John McCall9d5f35e2009-12-11 21:50:11 +0000379void StmtDumper::VisitUnresolvedLookupExpr(UnresolvedLookupExpr *Node) {
380 DumpExpr(Node);
381 OS << " (";
382 if (!Node->requiresADL()) OS << "no ";
Benjamin Kramer900fc632010-04-17 09:33:03 +0000383 OS << "ADL) = '" << Node->getName() << '\'';
John McCall9d5f35e2009-12-11 21:50:11 +0000384
385 UnresolvedLookupExpr::decls_iterator
386 I = Node->decls_begin(), E = Node->decls_end();
387 if (I == E) OS << " empty";
388 for (; I != E; ++I)
389 OS << " " << (void*) *I;
390}
391
Steve Naroff3c64d9e2008-03-12 13:19:12 +0000392void StmtDumper::VisitObjCIvarRefExpr(ObjCIvarRefExpr *Node) {
Steve Naroff466c2e32008-05-23 00:59:14 +0000393 DumpExpr(Node);
Steve Naroff3c64d9e2008-03-12 13:19:12 +0000394
Daniel Dunbar806c12e2009-12-03 09:13:13 +0000395 OS << " " << Node->getDecl()->getDeclKindName()
Benjamin Kramer900fc632010-04-17 09:33:03 +0000396 << "Decl='" << Node->getDecl()
Daniel Dunbar806c12e2009-12-03 09:13:13 +0000397 << "' " << (void*)Node->getDecl();
Steve Naroff218543b2008-05-23 22:01:24 +0000398 if (Node->isFreeIvar())
Daniel Dunbar806c12e2009-12-03 09:13:13 +0000399 OS << " isFreeIvar";
Steve Naroff3c64d9e2008-03-12 13:19:12 +0000400}
401
Chris Lattnerd9f69102008-08-10 01:53:14 +0000402void StmtDumper::VisitPredefinedExpr(PredefinedExpr *Node) {
Chris Lattner6000dac2007-08-08 22:51:59 +0000403 DumpExpr(Node);
404 switch (Node->getIdentType()) {
Chris Lattner0d17f6f2008-06-21 18:04:54 +0000405 default: assert(0 && "unknown case");
Daniel Dunbar806c12e2009-12-03 09:13:13 +0000406 case PredefinedExpr::Func: OS << " __func__"; break;
407 case PredefinedExpr::Function: OS << " __FUNCTION__"; break;
408 case PredefinedExpr::PrettyFunction: OS << " __PRETTY_FUNCTION__";break;
Chris Lattner6000dac2007-08-08 22:51:59 +0000409 }
410}
411
412void StmtDumper::VisitCharacterLiteral(CharacterLiteral *Node) {
Chris Lattnera0df31a2007-08-09 01:04:32 +0000413 DumpExpr(Node);
Daniel Dunbar806c12e2009-12-03 09:13:13 +0000414 OS << Node->getValue();
Chris Lattner6000dac2007-08-08 22:51:59 +0000415}
416
417void StmtDumper::VisitIntegerLiteral(IntegerLiteral *Node) {
418 DumpExpr(Node);
419
420 bool isSigned = Node->getType()->isSignedIntegerType();
Daniel Dunbar806c12e2009-12-03 09:13:13 +0000421 OS << " " << Node->getValue().toString(10, isSigned);
Chris Lattner6000dac2007-08-08 22:51:59 +0000422}
423void StmtDumper::VisitFloatingLiteral(FloatingLiteral *Node) {
424 DumpExpr(Node);
Daniel Dunbar806c12e2009-12-03 09:13:13 +0000425 OS << " " << Node->getValueAsApproximateDouble();
Chris Lattner6000dac2007-08-08 22:51:59 +0000426}
Chris Lattner5d661452007-08-26 03:42:43 +0000427
Chris Lattner6000dac2007-08-08 22:51:59 +0000428void StmtDumper::VisitStringLiteral(StringLiteral *Str) {
Chris Lattnera0df31a2007-08-09 01:04:32 +0000429 DumpExpr(Str);
430 // FIXME: this doesn't print wstrings right.
Daniel Dunbar806c12e2009-12-03 09:13:13 +0000431 OS << " ";
432 if (Str->isWide())
433 OS << "L";
434 OS << '"';
Benjamin Kramer2f4eaef2010-08-17 12:54:38 +0000435 OS.write_escaped(Str->getString());
Daniel Dunbar806c12e2009-12-03 09:13:13 +0000436 OS << '"';
Chris Lattner6000dac2007-08-08 22:51:59 +0000437}
Chris Lattner17a1a722007-08-30 01:00:35 +0000438
Chris Lattner6000dac2007-08-08 22:51:59 +0000439void StmtDumper::VisitUnaryOperator(UnaryOperator *Node) {
Chris Lattner13cb21f2007-08-09 17:35:30 +0000440 DumpExpr(Node);
Daniel Dunbar806c12e2009-12-03 09:13:13 +0000441 OS << " " << (Node->isPostfix() ? "postfix" : "prefix")
442 << " '" << UnaryOperator::getOpcodeStr(Node->getOpcode()) << "'";
Chris Lattner6000dac2007-08-08 22:51:59 +0000443}
Sebastian Redl05189992008-11-11 17:56:53 +0000444void StmtDumper::VisitSizeOfAlignOfExpr(SizeOfAlignOfExpr *Node) {
Chris Lattner13cb21f2007-08-09 17:35:30 +0000445 DumpExpr(Node);
Daniel Dunbar806c12e2009-12-03 09:13:13 +0000446 OS << " " << (Node->isSizeOf() ? "sizeof" : "alignof") << " ";
Sebastian Redl05189992008-11-11 17:56:53 +0000447 if (Node->isArgumentType())
448 DumpType(Node->getArgumentType());
Chris Lattner6000dac2007-08-08 22:51:59 +0000449}
Chris Lattner13cb21f2007-08-09 17:35:30 +0000450
Chris Lattner6000dac2007-08-08 22:51:59 +0000451void StmtDumper::VisitMemberExpr(MemberExpr *Node) {
Chris Lattner13cb21f2007-08-09 17:35:30 +0000452 DumpExpr(Node);
Daniel Dunbar806c12e2009-12-03 09:13:13 +0000453 OS << " " << (Node->isArrow() ? "->" : ".")
Benjamin Kramer900fc632010-04-17 09:33:03 +0000454 << Node->getMemberDecl() << ' '
Daniel Dunbar806c12e2009-12-03 09:13:13 +0000455 << (void*)Node->getMemberDecl();
Chris Lattner6000dac2007-08-08 22:51:59 +0000456}
Nate Begeman213541a2008-04-18 23:10:10 +0000457void StmtDumper::VisitExtVectorElementExpr(ExtVectorElementExpr *Node) {
Chris Lattner13cb21f2007-08-09 17:35:30 +0000458 DumpExpr(Node);
Daniel Dunbar806c12e2009-12-03 09:13:13 +0000459 OS << " " << Node->getAccessor().getNameStart();
Chris Lattner6000dac2007-08-08 22:51:59 +0000460}
Chris Lattner6000dac2007-08-08 22:51:59 +0000461void StmtDumper::VisitBinaryOperator(BinaryOperator *Node) {
462 DumpExpr(Node);
Daniel Dunbar806c12e2009-12-03 09:13:13 +0000463 OS << " '" << BinaryOperator::getOpcodeStr(Node->getOpcode()) << "'";
Chris Lattnereb14fe82007-08-25 02:00:02 +0000464}
465void StmtDumper::VisitCompoundAssignOperator(CompoundAssignOperator *Node) {
466 DumpExpr(Node);
Daniel Dunbar806c12e2009-12-03 09:13:13 +0000467 OS << " '" << BinaryOperator::getOpcodeStr(Node->getOpcode())
468 << "' ComputeLHSTy=";
Eli Friedmanab3a8522009-03-28 01:22:36 +0000469 DumpType(Node->getComputationLHSType());
Daniel Dunbar806c12e2009-12-03 09:13:13 +0000470 OS << " ComputeResultTy=";
Eli Friedmanab3a8522009-03-28 01:22:36 +0000471 DumpType(Node->getComputationResultType());
Chris Lattner6000dac2007-08-08 22:51:59 +0000472}
Chris Lattner6000dac2007-08-08 22:51:59 +0000473
John McCall6b5a61b2011-02-07 10:33:21 +0000474void StmtDumper::VisitBlockExpr(BlockExpr *Node) {
475 DumpExpr(Node);
476
477 IndentLevel++;
478 BlockDecl *block = Node->getBlockDecl();
479 if (block->capturesCXXThis()) {
480 OS << '\n'; Indent(); OS << "(capture this)";
481 }
482 for (BlockDecl::capture_iterator
483 i = block->capture_begin(), e = block->capture_end(); i != e; ++i) {
484 OS << '\n';
485 Indent();
486 OS << "(capture ";
487 if (i->isByRef()) OS << "byref ";
488 if (i->isNested()) OS << "nested ";
489 DumpDeclRef(i->getVariable());
490 if (i->hasCopyExpr()) DumpSubTree(i->getCopyExpr());
491 OS << ")";
492 }
493 IndentLevel--;
494
495 DumpSubTree(block->getBody());
496}
497
Chris Lattner6000dac2007-08-08 22:51:59 +0000498// GNU extensions.
499
500void StmtDumper::VisitAddrLabelExpr(AddrLabelExpr *Node) {
Chris Lattner13cb21f2007-08-09 17:35:30 +0000501 DumpExpr(Node);
Daniel Dunbar806c12e2009-12-03 09:13:13 +0000502 OS << " " << Node->getLabel()->getName()
503 << " " << (void*)Node->getLabel();
Chris Lattner6000dac2007-08-08 22:51:59 +0000504}
505
Chris Lattnerf9e05812007-08-09 18:03:18 +0000506//===----------------------------------------------------------------------===//
507// C++ Expressions
508//===----------------------------------------------------------------------===//
Chris Lattner6000dac2007-08-08 22:51:59 +0000509
Douglas Gregor49badde2008-10-27 19:41:14 +0000510void StmtDumper::VisitCXXNamedCastExpr(CXXNamedCastExpr *Node) {
Chris Lattner13cb21f2007-08-09 17:35:30 +0000511 DumpExpr(Node);
Daniel Dunbar806c12e2009-12-03 09:13:13 +0000512 OS << " " << Node->getCastName()
513 << "<" << Node->getTypeAsWritten().getAsString() << ">"
Anders Carlsson5cf86ba2010-04-24 19:06:50 +0000514 << " <" << Node->getCastKindName();
515 DumpBasePath(OS, Node);
516 OS << ">";
Chris Lattner6000dac2007-08-08 22:51:59 +0000517}
518
519void StmtDumper::VisitCXXBoolLiteralExpr(CXXBoolLiteralExpr *Node) {
Chris Lattner13cb21f2007-08-09 17:35:30 +0000520 DumpExpr(Node);
Daniel Dunbar806c12e2009-12-03 09:13:13 +0000521 OS << " " << (Node->getValue() ? "true" : "false");
Chris Lattner6000dac2007-08-08 22:51:59 +0000522}
523
Douglas Gregorcd9b46e2008-11-04 14:56:14 +0000524void StmtDumper::VisitCXXThisExpr(CXXThisExpr *Node) {
525 DumpExpr(Node);
Daniel Dunbar806c12e2009-12-03 09:13:13 +0000526 OS << " this";
Douglas Gregorcd9b46e2008-11-04 14:56:14 +0000527}
528
Douglas Gregor49badde2008-10-27 19:41:14 +0000529void StmtDumper::VisitCXXFunctionalCastExpr(CXXFunctionalCastExpr *Node) {
530 DumpExpr(Node);
Daniel Dunbar806c12e2009-12-03 09:13:13 +0000531 OS << " functional cast to " << Node->getTypeAsWritten().getAsString();
Douglas Gregor49badde2008-10-27 19:41:14 +0000532}
533
Anders Carlsson0eca1b62009-08-12 00:21:52 +0000534void StmtDumper::VisitCXXConstructExpr(CXXConstructExpr *Node) {
535 DumpExpr(Node);
John McCalld4bbdfe2010-02-02 19:03:45 +0000536 CXXConstructorDecl *Ctor = Node->getConstructor();
537 DumpType(Ctor->getType());
Anders Carlsson0eca1b62009-08-12 00:21:52 +0000538 if (Node->isElidable())
Daniel Dunbar806c12e2009-12-03 09:13:13 +0000539 OS << " elidable";
John McCallf8cf0b02010-08-07 06:38:55 +0000540 if (Node->requiresZeroInitialization())
541 OS << " zeroing";
Anders Carlsson0eca1b62009-08-12 00:21:52 +0000542}
543
544void StmtDumper::VisitCXXBindTemporaryExpr(CXXBindTemporaryExpr *Node) {
545 DumpExpr(Node);
Daniel Dunbar806c12e2009-12-03 09:13:13 +0000546 OS << " ";
Anders Carlsson0eca1b62009-08-12 00:21:52 +0000547 DumpCXXTemporary(Node->getTemporary());
548}
549
John McCall4765fa02010-12-06 08:20:24 +0000550void StmtDumper::VisitExprWithCleanups(ExprWithCleanups *Node) {
Anders Carlsson0eca1b62009-08-12 00:21:52 +0000551 DumpExpr(Node);
552 ++IndentLevel;
553 for (unsigned i = 0, e = Node->getNumTemporaries(); i != e; ++i) {
Daniel Dunbar806c12e2009-12-03 09:13:13 +0000554 OS << "\n";
Anders Carlsson0eca1b62009-08-12 00:21:52 +0000555 Indent();
556 DumpCXXTemporary(Node->getTemporary(i));
557 }
558 --IndentLevel;
559}
560
561void StmtDumper::DumpCXXTemporary(CXXTemporary *Temporary) {
Daniel Dunbar806c12e2009-12-03 09:13:13 +0000562 OS << "(CXXTemporary " << (void *)Temporary << ")";
Anders Carlsson0eca1b62009-08-12 00:21:52 +0000563}
564
Anders Carlsson55085182007-08-21 17:43:55 +0000565//===----------------------------------------------------------------------===//
566// Obj-C Expressions
567//===----------------------------------------------------------------------===//
568
Ted Kremenekb3d914b2008-02-29 22:04:05 +0000569void StmtDumper::VisitObjCMessageExpr(ObjCMessageExpr* Node) {
570 DumpExpr(Node);
Daniel Dunbar806c12e2009-12-03 09:13:13 +0000571 OS << " selector=" << Node->getSelector().getAsString();
Douglas Gregor04badcf2010-04-21 00:45:42 +0000572 switch (Node->getReceiverKind()) {
573 case ObjCMessageExpr::Instance:
574 break;
575
576 case ObjCMessageExpr::Class:
577 OS << " class=";
578 DumpType(Node->getClassReceiver());
579 break;
580
581 case ObjCMessageExpr::SuperInstance:
582 OS << " super (instance)";
583 break;
584
585 case ObjCMessageExpr::SuperClass:
586 OS << " super (class)";
587 break;
588 }
Ted Kremenekb3d914b2008-02-29 22:04:05 +0000589}
590
Douglas Gregor8f5e3dd2010-04-23 22:50:49 +0000591void StmtDumper::VisitObjCAtCatchStmt(ObjCAtCatchStmt *Node) {
592 DumpStmt(Node);
Douglas Gregorc00d8e12010-04-26 16:46:50 +0000593 if (VarDecl *CatchParam = Node->getCatchParamDecl()) {
Douglas Gregor8f5e3dd2010-04-23 22:50:49 +0000594 OS << " catch parm = ";
595 DumpDeclarator(CatchParam);
596 } else {
597 OS << " catch all";
598 }
599}
600
Anders Carlssonf9bcf012007-08-22 15:14:15 +0000601void StmtDumper::VisitObjCEncodeExpr(ObjCEncodeExpr *Node) {
602 DumpExpr(Node);
Daniel Dunbar806c12e2009-12-03 09:13:13 +0000603 OS << " ";
Anders Carlssonf9bcf012007-08-22 15:14:15 +0000604 DumpType(Node->getEncodedType());
Anders Carlssonf9bcf012007-08-22 15:14:15 +0000605}
606
Fariborz Jahanianb62f6812007-10-16 20:40:23 +0000607void StmtDumper::VisitObjCSelectorExpr(ObjCSelectorExpr *Node) {
608 DumpExpr(Node);
Mike Stump1eb44332009-09-09 15:08:12 +0000609
Daniel Dunbar806c12e2009-12-03 09:13:13 +0000610 OS << " " << Node->getSelector().getAsString();
Fariborz Jahanianb62f6812007-10-16 20:40:23 +0000611}
612
Fariborz Jahanian390d50a2007-10-17 16:58:11 +0000613void StmtDumper::VisitObjCProtocolExpr(ObjCProtocolExpr *Node) {
614 DumpExpr(Node);
Mike Stump1eb44332009-09-09 15:08:12 +0000615
Benjamin Kramer900fc632010-04-17 09:33:03 +0000616 OS << ' ' << Node->getProtocol();
Fariborz Jahanian390d50a2007-10-17 16:58:11 +0000617}
Daniel Dunbar7f8ea5c2008-08-30 05:35:15 +0000618
619void StmtDumper::VisitObjCPropertyRefExpr(ObjCPropertyRefExpr *Node) {
620 DumpExpr(Node);
John McCall12f78a62010-12-02 01:19:52 +0000621 if (Node->isImplicitProperty()) {
Fariborz Jahanian99130e52010-12-22 19:46:35 +0000622 OS << " Kind=MethodRef Getter=\"";
623 if (Node->getImplicitPropertyGetter())
624 OS << Node->getImplicitPropertyGetter()->getSelector().getAsString();
625 else
626 OS << "(null)";
627
628 OS << "\" Setter=\"";
John McCall12f78a62010-12-02 01:19:52 +0000629 if (ObjCMethodDecl *Setter = Node->getImplicitPropertySetter())
630 OS << Setter->getSelector().getAsString();
631 else
632 OS << "(null)";
633 OS << "\"";
634 } else {
635 OS << " Kind=PropertyRef Property=\"" << Node->getExplicitProperty() << '"';
636 }
Fariborz Jahanian5daf5702008-11-22 18:39:36 +0000637
Fariborz Jahanian8ac2d442010-10-14 16:04:05 +0000638 if (Node->isSuperReceiver())
639 OS << " super";
Douglas Gregorcd9b46e2008-11-04 14:56:14 +0000640}
641
Chris Lattner6000dac2007-08-08 22:51:59 +0000642//===----------------------------------------------------------------------===//
643// Stmt method implementations
644//===----------------------------------------------------------------------===//
645
646/// dump - This does a local dump of the specified AST fragment. It dumps the
647/// specified node and a few nodes underneath it, but not the whole subtree.
648/// This is useful in a debugger.
Chris Lattnere300c872007-08-30 06:17:34 +0000649void Stmt::dump(SourceManager &SM) const {
Argyrios Kyrtzidis96680332010-08-09 10:54:31 +0000650 dump(llvm::errs(), SM);
651}
652
653void Stmt::dump(llvm::raw_ostream &OS, SourceManager &SM) const {
654 StmtDumper P(&SM, OS, 4);
Chris Lattnerb3938792007-08-30 00:53:54 +0000655 P.DumpSubTree(const_cast<Stmt*>(this));
Argyrios Kyrtzidis96680332010-08-09 10:54:31 +0000656 OS << "\n";
Chris Lattner0c727a32007-08-30 00:40:08 +0000657}
658
659/// dump - This does a local dump of the specified AST fragment. It dumps the
660/// specified node and a few nodes underneath it, but not the whole subtree.
661/// This is useful in a debugger.
Chris Lattner6000dac2007-08-08 22:51:59 +0000662void Stmt::dump() const {
Argyrios Kyrtzidis96680332010-08-09 10:54:31 +0000663 StmtDumper P(0, llvm::errs(), 4);
Chris Lattnerb3938792007-08-30 00:53:54 +0000664 P.DumpSubTree(const_cast<Stmt*>(this));
Argyrios Kyrtzidis96680332010-08-09 10:54:31 +0000665 llvm::errs() << "\n";
Chris Lattner0c727a32007-08-30 00:40:08 +0000666}
667
668/// dumpAll - This does a dump of the specified AST fragment and all subtrees.
Chris Lattnere300c872007-08-30 06:17:34 +0000669void Stmt::dumpAll(SourceManager &SM) const {
Argyrios Kyrtzidis96680332010-08-09 10:54:31 +0000670 StmtDumper P(&SM, llvm::errs(), ~0U);
Chris Lattnerb3938792007-08-30 00:53:54 +0000671 P.DumpSubTree(const_cast<Stmt*>(this));
Argyrios Kyrtzidis96680332010-08-09 10:54:31 +0000672 llvm::errs() << "\n";
Chris Lattner6000dac2007-08-08 22:51:59 +0000673}
674
675/// dumpAll - This does a dump of the specified AST fragment and all subtrees.
676void Stmt::dumpAll() const {
Argyrios Kyrtzidis96680332010-08-09 10:54:31 +0000677 StmtDumper P(0, llvm::errs(), ~0U);
Chris Lattnerb3938792007-08-30 00:53:54 +0000678 P.DumpSubTree(const_cast<Stmt*>(this));
Argyrios Kyrtzidis96680332010-08-09 10:54:31 +0000679 llvm::errs() << "\n";
Chris Lattner6000dac2007-08-08 22:51:59 +0000680}