Home | History | Annotate | Download | only in Index
      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 -test-load-source all -comments-xml-schema=%S/../../bindings/xml/comment-xml-schema.rng %s -std=c++11 > %t/out.c-index-direct
    267 // RUN: c-index-test -test-load-tu %t/out.pch all > %t/out.c-index-pch
    268 
    269 // RUN: FileCheck %s -check-prefix=WRONG < %t/out.c-index-direct
    270 // RUN: FileCheck %s -check-prefix=WRONG < %t/out.c-index-pch
    271 
    272 // Declarations without Doxygen comments should not pick up some Doxygen comments.
    273 // WRONG-NOT: notdoxy{{.*}}Comment=
    274 // WRONG-NOT: test{{.*}}Comment=
    275 
    276 // Non-Doxygen comments should not be attached to anything.
    277 // WRONG-NOT: NOT_DOXYGEN
    278 
    279 // Some Doxygen comments are not attached to anything.
    280 // WRONG-NOT: IS_DOXYGEN_NOT_ATTACHED
    281 
    282 // Ensure we don't pick up extra comments.
    283 // WRONG-NOT: IS_DOXYGEN_START{{.*}}IS_DOXYGEN_START{{.*}}BriefComment=
    284 // WRONG-NOT: IS_DOXYGEN_END{{.*}}IS_DOXYGEN_END{{.*}}BriefComment=
    285 //
    286 // Ensure that XML is not invalid
    287 // WRONG-NOT: CommentXMLInvalid
    288 
    289 // RUN: FileCheck %s < %t/out.c-index-direct
    290 // RUN: FileCheck %s < %t/out.c-index-pch
    291 
    292 // These CHECK lines are not located near the code on purpose.  This test
    293 // checks that documentation comments are attached to declarations correctly.
    294 // Adding a non-documentation comment with CHECK line between every two
    295 // documentation comments will only test a single code path.
    296 //
    297 // CHECK: annotate-comments.cpp:16:6: FunctionDecl=isdoxy4:{{.*}} isdoxy4 IS_DOXYGEN_SINGLE
    298 // CHECK: annotate-comments.cpp:20:6: FunctionDecl=isdoxy5:{{.*}} isdoxy5 IS_DOXYGEN_SINGLE
    299 // CHECK: annotate-comments.cpp:25:6: FunctionDecl=isdoxy6:{{.*}} isdoxy6 IS_DOXYGEN_SINGLE
    300 // CHECK: annotate-comments.cpp:31:6: FunctionDecl=isdoxy7:{{.*}} isdoxy7 IS_DOXYGEN_SINGLE
    301 // CHECK: annotate-comments.cpp:34:6: FunctionDecl=isdoxy8:{{.*}} isdoxy8 IS_DOXYGEN_SINGLE
    302 // CHECK: annotate-comments.cpp:37:6: FunctionDecl=isdoxy9:{{.*}} isdoxy9 IS_DOXYGEN_SINGLE
    303 // CHECK: annotate-comments.cpp:41:6: FunctionDecl=isdoxy10:{{.*}} isdoxy10 IS_DOXYGEN_SINGLE
    304 // CHECK: annotate-comments.cpp:53:6: FunctionDecl=isdoxy13:{{.*}} isdoxy13 IS_DOXYGEN_START{{.*}} IS_DOXYGEN_END
    305 // CHECK: annotate-comments.cpp:58:6: FunctionDecl=isdoxy14:{{.*}} isdoxy14 IS_DOXYGEN_START{{.*}} IS_DOXYGEN_END
    306 // CHECK: annotate-comments.cpp:63:6: FunctionDecl=isdoxy15:{{.*}} isdoxy15 IS_DOXYGEN_START{{.*}} IS_DOXYGEN_END
    307 // CHECK: annotate-comments.cpp:67:6: FunctionDecl=isdoxy16:{{.*}} isdoxy16 IS_DOXYGEN_START{{.*}} IS_DOXYGEN_END
    308 // CHECK: annotate-comments.cpp:72:6: FunctionDecl=isdoxy17:{{.*}} isdoxy17 IS_DOXYGEN_START{{.*}} IS_DOXYGEN_END
    309 // CHECK: annotate-comments.cpp:80:5: FunctionDecl=isdoxy18:{{.*}} isdoxy18 IS_DOXYGEN_START{{.*}} IS_DOXYGEN_END
    310 // CHECK: annotate-comments.cpp:90:6: FunctionDecl=isdoxy19:{{.*}} isdoxy19 IS_DOXYGEN_START{{.*}} IS_DOXYGEN_END
    311 // CHECK: annotate-comments.cpp:96:6: FunctionDecl=isdoxy20:{{.*}} isdoxy20 IS_DOXYGEN_START{{.*}} IS_DOXYGEN_END
    312 // CHECK: annotate-comments.cpp:107:8: StructDecl=isdoxy25:{{.*}} IS_DOXYGEN_SINGLE
    313 // CHECK: annotate-comments.cpp:112:7: FieldDecl=isdoxy26:{{.*}} IS_DOXYGEN_SINGLE
    314 // CHECK: annotate-comments.cpp:116:7: FieldDecl=isdoxy27:{{.*}} IS_DOXYGEN_SINGLE
    315 // CHECK: annotate-comments.cpp:123:6: EnumDecl=isdoxy29:{{.*}} IS_DOXYGEN_SINGLE
    316 // CHECK: annotate-comments.cpp:130:11: Namespace=isdoxy31:{{.*}} IS_DOXYGEN_SINGLE
    317 // CHECK: annotate-comments.cpp:138:7: FieldDecl=isdoxy33:{{.*}} isdoxy33 IS_DOXYGEN_SINGLE
    318 // CHECK: annotate-comments.cpp:139:7: FieldDecl=isdoxy34:{{.*}} isdoxy34 IS_DOXYGEN_SINGLE
    319 // CHECK: annotate-comments.cpp:142:7: FieldDecl=isdoxy35:{{.*}} isdoxy35 IS_DOXYGEN_SINGLE
    320 // CHECK: annotate-comments.cpp:143:7: FieldDecl=isdoxy36:{{.*}} isdoxy36 IS_DOXYGEN_SINGLE
    321 // CHECK: annotate-comments.cpp:146:7: FieldDecl=isdoxy37:{{.*}} isdoxy37 IS_DOXYGEN_SINGLE
    322 // CHECK: annotate-comments.cpp:147:7: FieldDecl=isdoxy38:{{.*}} isdoxy38 IS_DOXYGEN_SINGLE
    323 // CHECK: annotate-comments.cpp:148:7: FieldDecl=isdoxy39:{{.*}} isdoxy39 IS_DOXYGEN_SINGLE
    324 // CHECK: annotate-comments.cpp:155:6: FunctionDecl=isdoxy40:{{.*}} isdoxy40 IS_DOXYGEN_SINGLE
    325 // CHECK: annotate-comments.cpp:160:5: FunctionDecl=isdoxy41:{{.*}} isdoxy41 IS_DOXYGEN_SINGLE
    326 // CHECK: annotate-comments.cpp:163:7: FieldDecl=isdoxy42:{{.*}} isdoxy42 IS_DOXYGEN_SINGLE
    327 // CHECK: annotate-comments.cpp:176:6: FunctionDecl=isdoxy43:{{.*}} IS_DOXYGEN_START{{.*}} IS_DOXYGEN_END
    328 
    329 // CHECK: annotate-comments.cpp:185:6: FunctionDecl=isdoxy44:{{.*}} BriefComment=[IS_DOXYGEN_START Aaa bbb ccc.]
    330 // CHECK: annotate-comments.cpp:195:6: FunctionDecl=isdoxy45:{{.*}} BriefComment=[Ddd eee. Fff.]
    331 // CHECK: annotate-comments.cpp:205:6: FunctionDecl=isdoxy46:{{.*}} BriefComment=[Ddd eee. Fff.]
    332 // CHECK: annotate-comments.cpp:214:6: FunctionDecl=isdoxy48:{{.*}} BriefComment=[IS_DOXYGEN_START Aaa bbb]
    333 // CHECK: annotate-comments.cpp:218:6: FunctionDecl=isdoxy49:{{.*}} BriefComment=[IS_DOXYGEN_START Aaa]
    334 // CHECK: annotate-comments.cpp:222:6: FunctionDecl=isdoxy50:{{.*}} BriefComment=[Returns ddd IS_DOXYGEN_END]
    335 // CHECK: annotate-comments.cpp:231:6: FunctionDecl=isdoxy51:{{.*}} BriefComment=[Aaa. IS_DOXYGEN_START]
    336 // CHECK: annotate-comments.cpp:241:6: FunctionDecl=isdoxy52:{{.*}} BriefComment=[Aaa. IS_DOXYGEN_START Bbb.]
    337 // CHECK: annotate-comments.cpp:248:6: FunctionDecl=isdoxy53:{{.*}} BriefComment=[Aaa. IS_DOXYGEN_START IS_DOXYGEN_END]
    338 // CHECK: annotate-comments.cpp:255:6: FunctionDecl=isdoxy54:{{.*}} BriefComment=[Aaa. IS_DOXYGEN_START IS_DOXYGEN_END]
    339