150
|
1 // Run lines are sensitive to line numbers and come below the code.
|
|
2
|
|
3 #ifndef HEADER
|
|
4 #define HEADER
|
|
5
|
|
6 // Not a Doxygen comment. NOT_DOXYGEN
|
|
7 void notdoxy1(void);
|
|
8
|
|
9 /* Not a Doxygen comment. NOT_DOXYGEN */
|
|
10 void notdoxy2(void);
|
|
11
|
|
12 /*/ Not a Doxygen comment. NOT_DOXYGEN */
|
|
13 void notdoxy3(void);
|
|
14
|
|
15 /** Doxygen comment. isdoxy4 IS_DOXYGEN_SINGLE */
|
|
16 void isdoxy4(void);
|
|
17
|
|
18 /**
|
|
19 * Doxygen comment. isdoxy5 IS_DOXYGEN_SINGLE */
|
|
20 void isdoxy5(void);
|
|
21
|
|
22 /**
|
|
23 * Doxygen comment.
|
|
24 * isdoxy6 IS_DOXYGEN_SINGLE */
|
|
25 void isdoxy6(void);
|
|
26
|
|
27 /**
|
|
28 * Doxygen comment.
|
|
29 * isdoxy7 IS_DOXYGEN_SINGLE
|
|
30 */
|
|
31 void isdoxy7(void);
|
|
32
|
|
33 /*! Doxygen comment. isdoxy8 IS_DOXYGEN_SINGLE */
|
|
34 void isdoxy8(void);
|
|
35
|
|
36 /// Doxygen comment. isdoxy9 IS_DOXYGEN_SINGLE
|
|
37 void isdoxy9(void);
|
|
38
|
|
39 // Not a Doxygen comment. NOT_DOXYGEN
|
|
40 /// Doxygen comment. isdoxy10 IS_DOXYGEN_SINGLE
|
|
41 void isdoxy10(void);
|
|
42
|
|
43 /// Doxygen comment. isdoxy11 IS_DOXYGEN_SINGLE
|
|
44 // Not a Doxygen comment. NOT_DOXYGEN
|
|
45 void isdoxy11(void);
|
|
46
|
|
47 /** Doxygen comment. isdoxy12 IS_DOXYGEN_SINGLE */
|
|
48 /* Not a Doxygen comment. NOT_DOXYGEN */
|
|
49 void isdoxy12(void);
|
|
50
|
|
51 /// Doxygen comment. isdoxy13 IS_DOXYGEN_START
|
|
52 /// Doxygen comment. IS_DOXYGEN_END
|
|
53 void isdoxy13(void);
|
|
54
|
|
55 /// Doxygen comment. isdoxy14 IS_DOXYGEN_START
|
|
56 /// Blah-blah-blah.
|
|
57 /// Doxygen comment. IS_DOXYGEN_END
|
|
58 void isdoxy14(void);
|
|
59
|
|
60 /// Doxygen comment. isdoxy15 IS_DOXYGEN_START
|
|
61 /** Blah-blah-blah */
|
|
62 /// Doxygen comment. IS_DOXYGEN_END
|
|
63 void isdoxy15(void);
|
|
64
|
|
65 /** Blah-blah-blah. isdoxy16 IS_DOXYGEN_START *//** Blah */
|
|
66 /// Doxygen comment. IS_DOXYGEN_END
|
|
67 void isdoxy16(void);
|
|
68
|
|
69 /// NOT_DOXYGEN
|
|
70 // NOT_DOXYGEN
|
|
71 /// isdoxy17 IS_DOXYGEN_START IS_DOXYGEN_END
|
|
72 void isdoxy17(void);
|
|
73
|
|
74 unsigned
|
|
75 // NOT_DOXYGEN
|
|
76 /// NOT_DOXYGEN
|
|
77 // NOT_DOXYGEN
|
|
78 /// isdoxy18 IS_DOXYGEN_START IS_DOXYGEN_END
|
|
79 // NOT_DOXYGEN
|
|
80 int isdoxy18(void);
|
|
81
|
|
82 //! It all starts here. isdoxy19 IS_DOXYGEN_START
|
|
83 /*! It's a little odd to continue line this,
|
|
84 *
|
|
85 * but we need more multi-line comments. */
|
|
86 /// This comment comes before my other comments
|
|
87 /** This is a block comment that is associated with the function f. It
|
|
88 * runs for three lines. IS_DOXYGEN_END
|
|
89 */
|
|
90 void isdoxy19(int, int);
|
|
91
|
|
92 // NOT IN THE COMMENT NOT_DOXYGEN
|
|
93 /// This is a BCPL comment. isdoxy20 IS_DOXYGEN_START
|
|
94 /// It has only two lines.
|
|
95 /** But there are other blocks that are part of the comment, too. IS_DOXYGEN_END */
|
|
96 void isdoxy20(int);
|
|
97
|
|
98 void notdoxy21(int); ///< This is a member comment. isdoxy21 IS_DOXYGEN_NOT_ATTACHED
|
|
99
|
|
100 void notdoxy22(int); /*!< This is a member comment. isdoxy22 IS_DOXYGEN_NOT_ATTACHED */
|
|
101
|
|
102 void notdoxy23(int); /**< This is a member comment. isdoxy23 IS_DOXYGEN_NOT_ATTACHED */
|
|
103
|
|
104 void notdoxy24(int); // NOT_DOXYGEN
|
|
105
|
|
106 /// IS_DOXYGEN_SINGLE
|
|
107 struct isdoxy25 {
|
|
108 };
|
|
109
|
|
110 struct test26 {
|
|
111 /// IS_DOXYGEN_SINGLE
|
|
112 int isdoxy26;
|
|
113 };
|
|
114
|
|
115 struct test27 {
|
|
116 int isdoxy27; ///< IS_DOXYGEN_SINGLE
|
|
117 };
|
|
118
|
|
119 struct notdoxy28 {
|
|
120 }; ///< IS_DOXYGEN_NOT_ATTACHED
|
|
121
|
|
122 /// IS_DOXYGEN_SINGLE
|
|
123 enum isdoxy29 {
|
|
124 };
|
|
125
|
|
126 enum notdoxy30 {
|
|
127 }; ///< IS_DOXYGEN_NOT_ATTACHED
|
|
128
|
|
129 /// IS_DOXYGEN_SINGLE
|
|
130 namespace isdoxy31 {
|
|
131 };
|
|
132
|
|
133 namespace notdoxy32 {
|
|
134 }; ///< IS_DOXYGEN_NOT_ATTACHED
|
|
135
|
|
136 class test33 {
|
|
137 ///< IS_DOXYGEN_NOT_ATTACHED
|
|
138 int isdoxy33; ///< isdoxy33 IS_DOXYGEN_SINGLE
|
|
139 int isdoxy34; ///< isdoxy34 IS_DOXYGEN_SINGLE
|
|
140
|
|
141 ///< IS_DOXYGEN_NOT_ATTACHED
|
|
142 int isdoxy35, ///< isdoxy35 IS_DOXYGEN_SINGLE
|
|
143 isdoxy36; ///< isdoxy36 IS_DOXYGEN_SINGLE
|
|
144
|
|
145 ///< IS_DOXYGEN_NOT_ATTACHED
|
|
146 int isdoxy37 ///< isdoxy37 IS_DOXYGEN_SINGLE
|
|
147 , isdoxy38 ///< isdoxy38 IS_DOXYGEN_SINGLE
|
|
148 , isdoxy39; ///< isdoxy39 IS_DOXYGEN_SINGLE
|
|
149 };
|
|
150
|
|
151 // Verified that Doxygen attaches these.
|
|
152
|
|
153 /// isdoxy40 IS_DOXYGEN_SINGLE
|
|
154 // NOT_DOXYGEN
|
|
155 void isdoxy40(int);
|
|
156
|
|
157 unsigned
|
|
158 /// isdoxy41 IS_DOXYGEN_SINGLE
|
|
159 // NOT_DOXYGEN
|
|
160 int isdoxy41(int);
|
|
161
|
|
162 class test42 {
|
|
163 int isdoxy42; /* NOT_DOXYGEN */ ///< isdoxy42 IS_DOXYGEN_SINGLE
|
|
164 };
|
|
165
|
|
166 /// IS_DOXYGEN_START
|
|
167 /// It is fine to have a command at the end of comment.
|
|
168 ///\brief
|
|
169 ///
|
|
170 /// Some malformed command.
|
|
171 /** \*/
|
|
172 /**
|
|
173 * \brief Aaa aaaaaaa aaaa.
|
|
174 * IS_DOXYGEN_END
|
|
175 */
|
|
176 void isdoxy43(void);
|
|
177
|
|
178 /// IS_DOXYGEN_START Aaa bbb
|
|
179 /// ccc.
|
|
180 ///
|
|
181 /// Ddd eee.
|
|
182 /// Fff.
|
|
183 ///
|
|
184 /// Ggg. IS_DOXYGEN_END
|
|
185 void isdoxy44(void);
|
|
186
|
|
187 /// IS_DOXYGEN_START Aaa bbb
|
|
188 /// ccc.
|
|
189 ///
|
|
190 /// \brief
|
|
191 /// Ddd eee.
|
|
192 /// Fff.
|
|
193 ///
|
|
194 /// Ggg. IS_DOXYGEN_END
|
|
195 void isdoxy45(void);
|
|
196
|
|
197 /// IS_DOXYGEN_START Aaa bbb
|
|
198 /// ccc.
|
|
199 ///
|
|
200 /// \short
|
|
201 /// Ddd eee.
|
|
202 /// Fff.
|
|
203 ///
|
|
204 /// Ggg. IS_DOXYGEN_END
|
|
205 void isdoxy46(void);
|
|
206
|
|
207 /// IS_DOXYGEN_NOT_ATTACHED
|
|
208 #define FOO
|
|
209 void notdoxy47(void);
|
|
210
|
|
211 /// IS_DOXYGEN_START Aaa bbb
|
|
212 /// \param ccc
|
|
213 /// \returns ddd IS_DOXYGEN_END
|
|
214 void isdoxy48(int);
|
|
215
|
|
216 /// \brief IS_DOXYGEN_START Aaa
|
|
217 /// \returns bbb IS_DOXYGEN_END
|
|
218 void isdoxy49(void);
|
|
219
|
|
220 /// \param ccc IS_DOXYGEN_START
|
|
221 /// \returns ddd IS_DOXYGEN_END
|
|
222 void isdoxy50(int);
|
|
223
|
|
224 // One of the following lines has trailing whitespace. It is intended, don't
|
|
225 // fix it.
|
|
226 /**
|
|
227 * Aaa. IS_DOXYGEN_START
|
|
228 *
|
|
229 * Bbb. IS_DOXYGEN_END
|
|
230 */
|
|
231 void isdoxy51(int);
|
|
232
|
|
233 // One of the following lines has trailing whitespace. It is intended, don't
|
|
234 // fix it.
|
|
235 /**
|
|
236 * Aaa. IS_DOXYGEN_START
|
|
237 * Bbb.
|
|
238 *
|
|
239 * Ccc. IS_DOXYGEN_END
|
|
240 */
|
|
241 void isdoxy52(int);
|
|
242
|
|
243 /**
|
|
244 * \fn isdoxy53
|
|
245 *
|
|
246 * Aaa. IS_DOXYGEN_START IS_DOXYGEN_END
|
|
247 */
|
|
248 void isdoxy53(int);
|
|
249
|
|
250 #define MYMAC(x,y)
|
|
251 /**
|
|
252 * Aaa. IS_DOXYGEN_START IS_DOXYGEN_END
|
|
253 */
|
|
254 MYMAC(0,0)
|
|
255 void isdoxy54(int);
|
|
256
|
|
257 #endif
|
|
258
|
|
259 // RUN: rm -rf %t
|
|
260 // RUN: mkdir %t
|
|
261
|
|
262 // Check that we serialize comment source locations properly.
|
|
263 // RUN: %clang_cc1 -x c++ -std=c++11 -emit-pch -o %t/out.pch %s
|
|
264 // RUN: %clang_cc1 -x c++ -std=c++11 -include-pch %t/out.pch -fsyntax-only %s
|
|
265
|
|
266 // RUN: c-index-test -write-pch %t/out.pch -x c++ -std=c++11 %s
|
|
267 // RUN: c-index-test -test-load-source all -comments-xml-schema=%S/../../bindings/xml/comment-xml-schema.rng %s -std=c++11 > %t/out.c-index-direct
|
|
268 // RUN: c-index-test -test-load-tu %t/out.pch all > %t/out.c-index-pch
|
|
269
|
|
270 // RUN: FileCheck %s -check-prefix=WRONG < %t/out.c-index-direct
|
|
271 // RUN: FileCheck %s -check-prefix=WRONG < %t/out.c-index-pch
|
|
272
|
|
273 // Declarations without Doxygen comments should not pick up some Doxygen comments.
|
|
274 // WRONG-NOT: notdoxy{{.*}}Comment=
|
|
275 // WRONG-NOT: test{{.*}}Comment=
|
|
276
|
|
277 // Non-Doxygen comments should not be attached to anything.
|
|
278 // WRONG-NOT: NOT_DOXYGEN
|
|
279
|
|
280 // Some Doxygen comments are not attached to anything.
|
|
281 // WRONG-NOT: IS_DOXYGEN_NOT_ATTACHED
|
|
282
|
|
283 // Ensure we don't pick up extra comments.
|
|
284 // WRONG-NOT: IS_DOXYGEN_START{{.*}}IS_DOXYGEN_START{{.*}}BriefComment=
|
|
285 // WRONG-NOT: IS_DOXYGEN_END{{.*}}IS_DOXYGEN_END{{.*}}BriefComment=
|
|
286 //
|
|
287 // Ensure that XML is not invalid
|
|
288 // WRONG-NOT: CommentXMLInvalid
|
|
289
|
|
290 // RUN: FileCheck %s < %t/out.c-index-direct
|
|
291 // RUN: FileCheck %s < %t/out.c-index-pch
|
|
292
|
|
293 // These CHECK lines are not located near the code on purpose. This test
|
|
294 // checks that documentation comments are attached to declarations correctly.
|
|
295 // Adding a non-documentation comment with CHECK line between every two
|
|
296 // documentation comments will only test a single code path.
|
|
297 //
|
|
298 // CHECK: annotate-comments.cpp:16:6: FunctionDecl=isdoxy4:{{.*}} isdoxy4 IS_DOXYGEN_SINGLE
|
|
299 // CHECK: annotate-comments.cpp:20:6: FunctionDecl=isdoxy5:{{.*}} isdoxy5 IS_DOXYGEN_SINGLE
|
|
300 // CHECK: annotate-comments.cpp:25:6: FunctionDecl=isdoxy6:{{.*}} isdoxy6 IS_DOXYGEN_SINGLE
|
|
301 // CHECK: annotate-comments.cpp:31:6: FunctionDecl=isdoxy7:{{.*}} isdoxy7 IS_DOXYGEN_SINGLE
|
|
302 // CHECK: annotate-comments.cpp:34:6: FunctionDecl=isdoxy8:{{.*}} isdoxy8 IS_DOXYGEN_SINGLE
|
|
303 // CHECK: annotate-comments.cpp:37:6: FunctionDecl=isdoxy9:{{.*}} isdoxy9 IS_DOXYGEN_SINGLE
|
|
304 // CHECK: annotate-comments.cpp:41:6: FunctionDecl=isdoxy10:{{.*}} isdoxy10 IS_DOXYGEN_SINGLE
|
|
305 // CHECK: annotate-comments.cpp:53:6: FunctionDecl=isdoxy13:{{.*}} isdoxy13 IS_DOXYGEN_START{{.*}} IS_DOXYGEN_END
|
|
306 // CHECK: annotate-comments.cpp:58:6: FunctionDecl=isdoxy14:{{.*}} isdoxy14 IS_DOXYGEN_START{{.*}} IS_DOXYGEN_END
|
|
307 // CHECK: annotate-comments.cpp:63:6: FunctionDecl=isdoxy15:{{.*}} isdoxy15 IS_DOXYGEN_START{{.*}} IS_DOXYGEN_END
|
|
308 // CHECK: annotate-comments.cpp:67:6: FunctionDecl=isdoxy16:{{.*}} isdoxy16 IS_DOXYGEN_START{{.*}} IS_DOXYGEN_END
|
|
309 // CHECK: annotate-comments.cpp:72:6: FunctionDecl=isdoxy17:{{.*}} isdoxy17 IS_DOXYGEN_START{{.*}} IS_DOXYGEN_END
|
|
310 // CHECK: annotate-comments.cpp:80:5: FunctionDecl=isdoxy18:{{.*}} isdoxy18 IS_DOXYGEN_START{{.*}} IS_DOXYGEN_END
|
|
311 // CHECK: annotate-comments.cpp:90:6: FunctionDecl=isdoxy19:{{.*}} isdoxy19 IS_DOXYGEN_START{{.*}} IS_DOXYGEN_END
|
|
312 // CHECK: annotate-comments.cpp:96:6: FunctionDecl=isdoxy20:{{.*}} isdoxy20 IS_DOXYGEN_START{{.*}} IS_DOXYGEN_END
|
|
313 // CHECK: annotate-comments.cpp:107:8: StructDecl=isdoxy25:{{.*}} IS_DOXYGEN_SINGLE
|
|
314 // CHECK: annotate-comments.cpp:112:7: FieldDecl=isdoxy26:{{.*}} IS_DOXYGEN_SINGLE
|
|
315 // CHECK: annotate-comments.cpp:116:7: FieldDecl=isdoxy27:{{.*}} IS_DOXYGEN_SINGLE
|
|
316 // CHECK: annotate-comments.cpp:123:6: EnumDecl=isdoxy29:{{.*}} IS_DOXYGEN_SINGLE
|
|
317 // CHECK: annotate-comments.cpp:130:11: Namespace=isdoxy31:{{.*}} IS_DOXYGEN_SINGLE
|
|
318 // CHECK: annotate-comments.cpp:138:7: FieldDecl=isdoxy33:{{.*}} isdoxy33 IS_DOXYGEN_SINGLE
|
|
319 // CHECK: annotate-comments.cpp:139:7: FieldDecl=isdoxy34:{{.*}} isdoxy34 IS_DOXYGEN_SINGLE
|
|
320 // CHECK: annotate-comments.cpp:142:7: FieldDecl=isdoxy35:{{.*}} isdoxy35 IS_DOXYGEN_SINGLE
|
|
321 // CHECK: annotate-comments.cpp:143:7: FieldDecl=isdoxy36:{{.*}} isdoxy36 IS_DOXYGEN_SINGLE
|
|
322 // CHECK: annotate-comments.cpp:146:7: FieldDecl=isdoxy37:{{.*}} isdoxy37 IS_DOXYGEN_SINGLE
|
|
323 // CHECK: annotate-comments.cpp:147:7: FieldDecl=isdoxy38:{{.*}} isdoxy38 IS_DOXYGEN_SINGLE
|
|
324 // CHECK: annotate-comments.cpp:148:7: FieldDecl=isdoxy39:{{.*}} isdoxy39 IS_DOXYGEN_SINGLE
|
|
325 // CHECK: annotate-comments.cpp:155:6: FunctionDecl=isdoxy40:{{.*}} isdoxy40 IS_DOXYGEN_SINGLE
|
|
326 // CHECK: annotate-comments.cpp:160:5: FunctionDecl=isdoxy41:{{.*}} isdoxy41 IS_DOXYGEN_SINGLE
|
|
327 // CHECK: annotate-comments.cpp:163:7: FieldDecl=isdoxy42:{{.*}} isdoxy42 IS_DOXYGEN_SINGLE
|
|
328 // CHECK: annotate-comments.cpp:176:6: FunctionDecl=isdoxy43:{{.*}} IS_DOXYGEN_START{{.*}} IS_DOXYGEN_END
|
|
329
|
|
330 // CHECK: annotate-comments.cpp:185:6: FunctionDecl=isdoxy44:{{.*}} BriefComment=[IS_DOXYGEN_START Aaa bbb ccc.]
|
|
331 // CHECK: annotate-comments.cpp:195:6: FunctionDecl=isdoxy45:{{.*}} BriefComment=[Ddd eee. Fff.]
|
|
332 // CHECK: annotate-comments.cpp:205:6: FunctionDecl=isdoxy46:{{.*}} BriefComment=[Ddd eee. Fff.]
|
|
333 // CHECK: annotate-comments.cpp:214:6: FunctionDecl=isdoxy48:{{.*}} BriefComment=[IS_DOXYGEN_START Aaa bbb]
|
|
334 // CHECK: annotate-comments.cpp:218:6: FunctionDecl=isdoxy49:{{.*}} BriefComment=[IS_DOXYGEN_START Aaa]
|
|
335 // CHECK: annotate-comments.cpp:222:6: FunctionDecl=isdoxy50:{{.*}} BriefComment=[Returns ddd IS_DOXYGEN_END]
|
|
336 // CHECK: annotate-comments.cpp:231:6: FunctionDecl=isdoxy51:{{.*}} BriefComment=[Aaa. IS_DOXYGEN_START]
|
|
337 // CHECK: annotate-comments.cpp:241:6: FunctionDecl=isdoxy52:{{.*}} BriefComment=[Aaa. IS_DOXYGEN_START Bbb.]
|
|
338 // CHECK: annotate-comments.cpp:248:6: FunctionDecl=isdoxy53:{{.*}} BriefComment=[Aaa. IS_DOXYGEN_START IS_DOXYGEN_END]
|
|
339 // CHECK: annotate-comments.cpp:255:6: FunctionDecl=isdoxy54:{{.*}} BriefComment=[Aaa. IS_DOXYGEN_START IS_DOXYGEN_END]
|