blob: c930b2450435f9a53e9993cb393bb69a14b6d904 [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()
78 << " " << (void *) C;
79 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
172 if (C->hasParamName()) {
173 OS << " Param=\"" << C->getParamName() << "\"";
174 }
175}
176
177void CommentDumper::visitVerbatimBlockComment(const VerbatimBlockComment *C) {
178 dumpComment(C);
179
180 OS << " Name=\"" << C->getCommandName() << "\""
181 " CloseName=\"" << C->getCloseName() << "\"";
182}
183
184void CommentDumper::visitVerbatimBlockLineComment(const VerbatimBlockLineComment *C) {
185 dumpComment(C);
186
187 OS << " Text=\"" << C->getText() << "\"";
188}
189
190void CommentDumper::visitVerbatimLineComment(const VerbatimLineComment *C) {
191 dumpComment(C);
192
193 OS << " Text=\"" << C->getText() << "\"";
194}
195
196void CommentDumper::visitFullComment(const FullComment *C) {
197 dumpComment(C);
198}
199
200} // unnamed namespace
201
Dmitri Gribenkofb3643a2012-07-18 16:30:42 +0000202void Comment::dump(llvm::raw_ostream &OS, SourceManager *SM) const {
203 CommentDumper D(llvm::errs(), SM);
Dmitri Gribenko8d3ba232012-07-06 00:28:32 +0000204 D.dumpSubtree(this);
205 llvm::errs() << '\n';
206}
207
208} // end namespace comments
209} // end namespace clang
210