blob: f02ea334cd71a1480bc6a8b61b40a6debadd5e0d [file] [log] [blame]
Dmitri Gribenko8d3ba232012-07-06 00:28:32 +00001//===--- CommentDumper.cpp - Dumping implementation for Comment 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#include "clang/AST/CommentVisitor.h"
11#include "llvm/Support/raw_ostream.h"
12
13namespace clang {
14namespace comments {
15
16namespace {
17class CommentDumper: public comments::ConstCommentVisitor<CommentDumper> {
18 raw_ostream &OS;
19 SourceManager *SM;
20 unsigned IndentLevel;
21
22public:
23 CommentDumper(raw_ostream &OS, SourceManager *SM) :
24 OS(OS), SM(SM), IndentLevel(0)
25 { }
26
27 void dumpIndent() const {
28 for (unsigned i = 1, e = IndentLevel; i < e; ++i)
29 OS << " ";
30 }
31
32 void dumpLocation(SourceLocation Loc) {
33 if (SM)
34 Loc.print(OS, *SM);
35 }
36
37 void dumpSourceRange(const Comment *C);
38
39 void dumpComment(const Comment *C);
40
41 void dumpSubtree(const Comment *C);
42
43 // Inline content.
44 void visitTextComment(const TextComment *C);
45 void visitInlineCommandComment(const InlineCommandComment *C);
Dmitri Gribenko3f38bf22012-07-13 00:44:24 +000046 void visitHTMLStartTagComment(const HTMLStartTagComment *C);
47 void visitHTMLEndTagComment(const HTMLEndTagComment *C);
Dmitri Gribenko8d3ba232012-07-06 00:28:32 +000048
49 // Block content.
50 void visitParagraphComment(const ParagraphComment *C);
51 void visitBlockCommandComment(const BlockCommandComment *C);
52 void visitParamCommandComment(const ParamCommandComment *C);
53 void visitVerbatimBlockComment(const VerbatimBlockComment *C);
54 void visitVerbatimBlockLineComment(const VerbatimBlockLineComment *C);
55 void visitVerbatimLineComment(const VerbatimLineComment *C);
56
57 void visitFullComment(const FullComment *C);
58};
59
60void CommentDumper::dumpSourceRange(const Comment *C) {
61 if (!SM)
62 return;
63
64 SourceRange SR = C->getSourceRange();
65
66 OS << " <";
67 dumpLocation(SR.getBegin());
68 if (SR.getBegin() != SR.getEnd()) {
69 OS << ", ";
70 dumpLocation(SR.getEnd());
71 }
72 OS << ">";
73}
74
75void CommentDumper::dumpComment(const Comment *C) {
76 dumpIndent();
77 OS << "(" << C->getCommentKindName()
Dmitri Gribenkoc1093612012-07-30 17:52:50 +000078 << " " << (const void *) C;
Dmitri Gribenko8d3ba232012-07-06 00:28:32 +000079 dumpSourceRange(C);
80}
81
82void CommentDumper::dumpSubtree(const Comment *C) {
83 ++IndentLevel;
84 if (C) {
85 visit(C);
86 for (Comment::child_iterator I = C->child_begin(),
87 E = C->child_end();
88 I != E; ++I) {
89 OS << '\n';
90 dumpSubtree(*I);
91 }
92 OS << ')';
93 } else {
94 dumpIndent();
95 OS << "<<<NULL>>>";
96 }
97 --IndentLevel;
98}
99
100void CommentDumper::visitTextComment(const TextComment *C) {
101 dumpComment(C);
102
103 OS << " Text=\"" << C->getText() << "\"";
104}
105
106void CommentDumper::visitInlineCommandComment(const InlineCommandComment *C) {
107 dumpComment(C);
108
Dmitri Gribenkocdd1b372012-07-18 23:20:23 +0000109 OS << " Name=\"" << C->getCommandName() << "\"";
Dmitri Gribenko2d66a502012-07-23 16:43:01 +0000110 switch (C->getRenderKind()) {
111 case InlineCommandComment::RenderNormal:
112 OS << " RenderNormal";
113 break;
114 case InlineCommandComment::RenderBold:
115 OS << " RenderBold";
116 break;
117 case InlineCommandComment::RenderMonospaced:
118 OS << " RenderMonospaced";
119 break;
120 case InlineCommandComment::RenderEmphasized:
121 OS << " RenderEmphasized";
122 break;
123 }
124
Dmitri Gribenko0eaf69d2012-07-13 19:02:42 +0000125 for (unsigned i = 0, e = C->getNumArgs(); i != e; ++i)
Dmitri Gribenko8d3ba232012-07-06 00:28:32 +0000126 OS << " Arg[" << i << "]=\"" << C->getArgText(i) << "\"";
127}
128
Dmitri Gribenko3f38bf22012-07-13 00:44:24 +0000129void CommentDumper::visitHTMLStartTagComment(const HTMLStartTagComment *C) {
Dmitri Gribenko8d3ba232012-07-06 00:28:32 +0000130 dumpComment(C);
131
132 OS << " Name=\"" << C->getTagName() << "\"";
Dmitri Gribenko0eaf69d2012-07-13 19:02:42 +0000133 if (C->getNumAttrs() != 0) {
Dmitri Gribenko8d3ba232012-07-06 00:28:32 +0000134 OS << " Attrs: ";
Dmitri Gribenko0eaf69d2012-07-13 19:02:42 +0000135 for (unsigned i = 0, e = C->getNumAttrs(); i != e; ++i) {
Dmitri Gribenko3f38bf22012-07-13 00:44:24 +0000136 const HTMLStartTagComment::Attribute &Attr = C->getAttr(i);
Dmitri Gribenko8d3ba232012-07-06 00:28:32 +0000137 OS << " \"" << Attr.Name << "=\"" << Attr.Value << "\"";
138 }
139 }
Dmitri Gribenkoa5ef44f2012-07-11 21:38:39 +0000140 if (C->isSelfClosing())
141 OS << " SelfClosing";
Dmitri Gribenko8d3ba232012-07-06 00:28:32 +0000142}
143
Dmitri Gribenko3f38bf22012-07-13 00:44:24 +0000144void CommentDumper::visitHTMLEndTagComment(const HTMLEndTagComment *C) {
Dmitri Gribenko8d3ba232012-07-06 00:28:32 +0000145 dumpComment(C);
146
147 OS << " Name=\"" << C->getTagName() << "\"";
148}
149
150void CommentDumper::visitParagraphComment(const ParagraphComment *C) {
151 dumpComment(C);
152}
153
154void CommentDumper::visitBlockCommandComment(const BlockCommandComment *C) {
155 dumpComment(C);
156
157 OS << " Name=\"" << C->getCommandName() << "\"";
Dmitri Gribenkoad29b2b2012-07-19 18:43:24 +0000158 for (unsigned i = 0, e = C->getNumArgs(); i != e; ++i)
159 OS << " Arg[" << i << "]=\"" << C->getArgText(i) << "\"";
Dmitri Gribenko8d3ba232012-07-06 00:28:32 +0000160}
161
162void CommentDumper::visitParamCommandComment(const ParamCommandComment *C) {
163 dumpComment(C);
164
Dmitri Gribenkoa5ef44f2012-07-11 21:38:39 +0000165 OS << " " << ParamCommandComment::getDirectionAsString(C->getDirection());
Dmitri Gribenko8d3ba232012-07-06 00:28:32 +0000166
167 if (C->isDirectionExplicit())
168 OS << " explicitly";
169 else
170 OS << " implicitly";
171
Dmitri Gribenko72b57cc2012-07-28 00:35:48 +0000172 if (C->hasParamName())
Dmitri Gribenko8d3ba232012-07-06 00:28:32 +0000173 OS << " Param=\"" << C->getParamName() << "\"";
Dmitri Gribenko72b57cc2012-07-28 00:35:48 +0000174
175 if (C->isParamIndexValid())
176 OS << " ParamIndex=" << C->getParamIndex();
Dmitri Gribenko8d3ba232012-07-06 00:28:32 +0000177}
178
179void CommentDumper::visitVerbatimBlockComment(const VerbatimBlockComment *C) {
180 dumpComment(C);
181
182 OS << " Name=\"" << C->getCommandName() << "\""
183 " CloseName=\"" << C->getCloseName() << "\"";
184}
185
186void CommentDumper::visitVerbatimBlockLineComment(const VerbatimBlockLineComment *C) {
187 dumpComment(C);
188
189 OS << " Text=\"" << C->getText() << "\"";
190}
191
192void CommentDumper::visitVerbatimLineComment(const VerbatimLineComment *C) {
193 dumpComment(C);
194
195 OS << " Text=\"" << C->getText() << "\"";
196}
197
198void CommentDumper::visitFullComment(const FullComment *C) {
199 dumpComment(C);
200}
201
202} // unnamed namespace
203
Dmitri Gribenkofb3643a2012-07-18 16:30:42 +0000204void Comment::dump(llvm::raw_ostream &OS, SourceManager *SM) const {
205 CommentDumper D(llvm::errs(), SM);
Dmitri Gribenko8d3ba232012-07-06 00:28:32 +0000206 D.dumpSubtree(this);
207 llvm::errs() << '\n';
208}
209
210} // end namespace comments
211} // end namespace clang
212