123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264 |
- // Run lines are sensitive to line numbers and come below the code.
- #ifndef HEADER
- #define HEADER
- // Not a Doxygen comment. NOT_DOXYGEN
- void notdoxy1(void);
- /* Not a Doxygen comment. NOT_DOXYGEN */
- void notdoxy2(void);
- /*/ Not a Doxygen comment. NOT_DOXYGEN */
- void notdoxy3(void);
- /** Doxygen comment. isdoxy4 IS_DOXYGEN_SINGLE */
- void isdoxy4(void);
- /**
- * Doxygen comment. isdoxy5 IS_DOXYGEN_SINGLE */
- void isdoxy5(void);
- /**
- * Doxygen comment.
- * isdoxy6 IS_DOXYGEN_SINGLE */
- void isdoxy6(void);
- /**
- * Doxygen comment.
- * isdoxy7 IS_DOXYGEN_SINGLE
- */
- void isdoxy7(void);
- /*! Doxygen comment. isdoxy8 IS_DOXYGEN_SINGLE */
- void isdoxy8(void);
- /// Doxygen comment. isdoxy9 IS_DOXYGEN_SINGLE
- void isdoxy9(void);
- // Not a Doxygen comment. NOT_DOXYGEN
- /// Doxygen comment. isdoxy10 IS_DOXYGEN_SINGLE
- void isdoxy10(void);
- /// Doxygen comment. isdoxy11 IS_DOXYGEN_SINGLE
- // Not a Doxygen comment. NOT_DOXYGEN
- void isdoxy11(void);
- /** Doxygen comment. isdoxy12 IS_DOXYGEN_SINGLE */
- /* Not a Doxygen comment. NOT_DOXYGEN */
- void isdoxy12(void);
- /// Doxygen comment. isdoxy13 IS_DOXYGEN_START
- /// Doxygen comment. IS_DOXYGEN_END
- void isdoxy13(void);
- /// Doxygen comment. isdoxy14 IS_DOXYGEN_START
- /// Blah-blah-blah.
- /// Doxygen comment. IS_DOXYGEN_END
- void isdoxy14(void);
- /// Doxygen comment. isdoxy15 IS_DOXYGEN_START
- /** Blah-blah-blah */
- /// Doxygen comment. IS_DOXYGEN_END
- void isdoxy15(void);
- /** Blah-blah-blah. isdoxy16 IS_DOXYGEN_START *//** Blah */
- /// Doxygen comment. IS_DOXYGEN_END
- void isdoxy16(void);
- /// isdoxy17 IS_DOXYGEN_START
- // Not a Doxygen comment, but still picked up.
- /// IS_DOXYGEN_END
- void isdoxy17(void);
- unsigned
- // NOT_DOXYGEN
- /// isdoxy18 IS_DOXYGEN_START
- // Not a Doxygen comment, but still picked up.
- /// IS_DOXYGEN_END
- // NOT_DOXYGEN
- int isdoxy18(void);
- //! It all starts here. isdoxy19 IS_DOXYGEN_START
- /*! It's a little odd to continue line this,
- *
- * but we need more multi-line comments. */
- /// This comment comes before my other comments
- /** This is a block comment that is associated with the function f. It
- * runs for three lines. IS_DOXYGEN_END
- */
- void isdoxy19(int, int);
- // NOT IN THE COMMENT NOT_DOXYGEN
- /// This is a BCPL comment. isdoxy20 IS_DOXYGEN_START
- /// It has only two lines.
- /** But there are other blocks that are part of the comment, too. IS_DOXYGEN_END */
- void isdoxy20(int);
- void isdoxy21(int); ///< This is a member comment. isdoxy21 IS_DOXYGEN_SINGLE
- void isdoxy22(int); /*!< This is a member comment. isdoxy22 IS_DOXYGEN_SINGLE */
- void isdoxy23(int); /**< This is a member comment. isdoxy23 IS_DOXYGEN_SINGLE */
- void notdoxy24(int); // NOT_DOXYGEN
- /// IS_DOXYGEN_SINGLE
- struct isdoxy25 {
- };
- struct test26 {
- /// IS_DOXYGEN_SINGLE
- int isdoxy26;
- };
- struct test27 {
- int isdoxy27; ///< IS_DOXYGEN_SINGLE
- };
- struct notdoxy28 {
- }; ///< IS_DOXYGEN_NOT_ATTACHED
- /// IS_DOXYGEN_SINGLE
- enum isdoxy29 {
- };
- enum notdoxy30 {
- }; ///< IS_DOXYGEN_NOT_ATTACHED
- /// IS_DOXYGEN_SINGLE
- namespace isdoxy31 {
- };
- namespace notdoxy32 {
- }; ///< IS_DOXYGEN_NOT_ATTACHED
- class test33 {
- ///< IS_DOXYGEN_NOT_ATTACHED
- int isdoxy33; ///< isdoxy33 IS_DOXYGEN_SINGLE
- int isdoxy34; ///< isdoxy34 IS_DOXYGEN_SINGLE
- ///< IS_DOXYGEN_NOT_ATTACHED
- int isdoxy35, ///< isdoxy35 IS_DOXYGEN_SINGLE
- isdoxy36; ///< isdoxy36 IS_DOXYGEN_SINGLE
- ///< IS_DOXYGEN_NOT_ATTACHED
- int isdoxy37 ///< isdoxy37 IS_DOXYGEN_SINGLE
- , isdoxy38 ///< isdoxy38 IS_DOXYGEN_SINGLE
- , isdoxy39; ///< isdoxy39 IS_DOXYGEN_SINGLE
- };
- // Verified that Doxygen attaches these.
- /// isdoxy40 IS_DOXYGEN_SINGLE
- // NOT_DOXYGEN
- void isdoxy40(int);
- unsigned
- /// isdoxy41 IS_DOXYGEN_SINGLE
- // NOT_DOXYGEN
- int isdoxy41(int);
- class test42 {
- int isdoxy42; /* NOT_DOXYGEN */ ///< isdoxy42 IS_DOXYGEN_SINGLE
- };
- /// IS_DOXYGEN_START
- /// It is fine to have a command at the end of comment.
- ///\brief
- ///
- /// Some malformed command.
- /* \*/
- /**
- * \brief Aaa aaaaaaa aaaa.
- * IS_DOXYGEN_END
- */
- void isdoxy43(void);
- /// IS_DOXYGEN_START Aaa bbb
- /// ccc.
- ///
- /// Ddd eee.
- /// Fff.
- ///
- /// Ggg. IS_DOXYGEN_END
- void isdoxy44(void);
- /// IS_DOXYGEN_START Aaa bbb
- /// ccc.
- ///
- /// \brief
- /// Ddd eee.
- /// Fff.
- ///
- /// Ggg. IS_DOXYGEN_END
- void isdoxy45(void);
- #endif
- // RUN: rm -rf %t
- // RUN: mkdir %t
- // RUN: %clang_cc1 -x c++ -emit-pch -o %t/out.pch %s
- // RUN: %clang_cc1 -x c++ -include-pch %t/out.pch -fsyntax-only %s
- // RUN: c-index-test -test-load-source all %s > %t/out.c-index-direct
- // RUN: c-index-test -test-load-tu %t/out.pch all > %t/out.c-index-pch
- // RUN: FileCheck %s -check-prefix=WRONG < %t/out.c-index-direct
- // RUN: FileCheck %s -check-prefix=WRONG < %t/out.c-index-pch
- // Declarations without Doxygen comments should not pick up some Doxygen comments.
- // WRONG-NOT: notdoxy{{.*}}Comment=
- // WRONG-NOT: test{{.*}}Comment=
- // Non-Doxygen comments should not be attached to anything.
- // WRONG-NOT: NOT_DOXYGEN
- // Some Doxygen comments are not attached to anything.
- // WRONG-NOT: IS_DOXYGEN_NOT_ATTACHED
- // Ensure we don't pick up extra comments.
- // WRONG-NOT: IS_DOXYGEN_START{{.*}}IS_DOXYGEN_START{{.*}}BriefComment=
- // WRONG-NOT: IS_DOXYGEN_END{{.*}}IS_DOXYGEN_END{{.*}}BriefComment=
- // RUN: FileCheck %s < %t/out.c-index-direct
- // RUN: FileCheck %s < %t/out.c-index-pch
- // CHECK: annotate-comments.cpp:16:6: FunctionDecl=isdoxy4:{{.*}} isdoxy4 IS_DOXYGEN_SINGLE
- // CHECK: annotate-comments.cpp:20:6: FunctionDecl=isdoxy5:{{.*}} isdoxy5 IS_DOXYGEN_SINGLE
- // CHECK: annotate-comments.cpp:25:6: FunctionDecl=isdoxy6:{{.*}} isdoxy6 IS_DOXYGEN_SINGLE
- // CHECK: annotate-comments.cpp:31:6: FunctionDecl=isdoxy7:{{.*}} isdoxy7 IS_DOXYGEN_SINGLE
- // CHECK: annotate-comments.cpp:34:6: FunctionDecl=isdoxy8:{{.*}} isdoxy8 IS_DOXYGEN_SINGLE
- // CHECK: annotate-comments.cpp:37:6: FunctionDecl=isdoxy9:{{.*}} isdoxy9 IS_DOXYGEN_SINGLE
- // CHECK: annotate-comments.cpp:41:6: FunctionDecl=isdoxy10:{{.*}} isdoxy10 IS_DOXYGEN_SINGLE
- // CHECK: annotate-comments.cpp:53:6: FunctionDecl=isdoxy13:{{.*}} isdoxy13 IS_DOXYGEN_START{{.*}} IS_DOXYGEN_END
- // CHECK: annotate-comments.cpp:58:6: FunctionDecl=isdoxy14:{{.*}} isdoxy14 IS_DOXYGEN_START{{.*}} IS_DOXYGEN_END
- // CHECK: annotate-comments.cpp:63:6: FunctionDecl=isdoxy15:{{.*}} isdoxy15 IS_DOXYGEN_START{{.*}} IS_DOXYGEN_END
- // CHECK: annotate-comments.cpp:67:6: FunctionDecl=isdoxy16:{{.*}} isdoxy16 IS_DOXYGEN_START{{.*}} IS_DOXYGEN_END
- // CHECK: annotate-comments.cpp:72:6: FunctionDecl=isdoxy17:{{.*}} isdoxy17 IS_DOXYGEN_START{{.*}} IS_DOXYGEN_END
- // CHECK: annotate-comments.cpp:80:5: FunctionDecl=isdoxy18:{{.*}} isdoxy18 IS_DOXYGEN_START{{.*}} IS_DOXYGEN_END
- // CHECK: annotate-comments.cpp:90:6: FunctionDecl=isdoxy19:{{.*}} isdoxy19 IS_DOXYGEN_START{{.*}} IS_DOXYGEN_END
- // CHECK: annotate-comments.cpp:96:6: FunctionDecl=isdoxy20:{{.*}} isdoxy20 IS_DOXYGEN_START{{.*}} IS_DOXYGEN_END
- // CHECK: annotate-comments.cpp:98:6: FunctionDecl=isdoxy21:{{.*}} isdoxy21 IS_DOXYGEN_SINGLE
- // CHECK: annotate-comments.cpp:100:6: FunctionDecl=isdoxy22:{{.*}} isdoxy22 IS_DOXYGEN_SINGLE
- // CHECK: annotate-comments.cpp:102:6: FunctionDecl=isdoxy23:{{.*}} isdoxy23 IS_DOXYGEN_SINGLE
- // CHECK: annotate-comments.cpp:107:8: StructDecl=isdoxy25:{{.*}} IS_DOXYGEN_SINGLE
- // CHECK: annotate-comments.cpp:112:7: FieldDecl=isdoxy26:{{.*}} IS_DOXYGEN_SINGLE
- // CHECK: annotate-comments.cpp:116:7: FieldDecl=isdoxy27:{{.*}} IS_DOXYGEN_SINGLE
- // CHECK: annotate-comments.cpp:123:6: EnumDecl=isdoxy29:{{.*}} IS_DOXYGEN_SINGLE
- // CHECK: annotate-comments.cpp:130:11: Namespace=isdoxy31:{{.*}} IS_DOXYGEN_SINGLE
- // CHECK: annotate-comments.cpp:138:7: FieldDecl=isdoxy33:{{.*}} isdoxy33 IS_DOXYGEN_SINGLE
- // CHECK: annotate-comments.cpp:139:7: FieldDecl=isdoxy34:{{.*}} isdoxy34 IS_DOXYGEN_SINGLE
- // CHECK: annotate-comments.cpp:142:7: FieldDecl=isdoxy35:{{.*}} isdoxy35 IS_DOXYGEN_SINGLE
- // CHECK: annotate-comments.cpp:143:7: FieldDecl=isdoxy36:{{.*}} isdoxy36 IS_DOXYGEN_SINGLE
- // CHECK: annotate-comments.cpp:146:7: FieldDecl=isdoxy37:{{.*}} isdoxy37 IS_DOXYGEN_SINGLE
- // CHECK: annotate-comments.cpp:147:7: FieldDecl=isdoxy38:{{.*}} isdoxy38 IS_DOXYGEN_SINGLE
- // CHECK: annotate-comments.cpp:148:7: FieldDecl=isdoxy39:{{.*}} isdoxy39 IS_DOXYGEN_SINGLE
- // CHECK: annotate-comments.cpp:155:6: FunctionDecl=isdoxy40:{{.*}} isdoxy40 IS_DOXYGEN_SINGLE
- // CHECK: annotate-comments.cpp:160:5: FunctionDecl=isdoxy41:{{.*}} isdoxy41 IS_DOXYGEN_SINGLE
- // CHECK: annotate-comments.cpp:163:7: FieldDecl=isdoxy42:{{.*}} isdoxy42 IS_DOXYGEN_SINGLE
- // CHECK: annotate-comments.cpp:176:6: FunctionDecl=isdoxy43:{{.*}} IS_DOXYGEN_START{{.*}} IS_DOXYGEN_END
- // CHECK: annotate-comments.cpp:185:6: FunctionDecl=isdoxy44:{{.*}} BriefComment=[ IS_DOXYGEN_START Aaa bbb\n ccc.\n]
- // CHECK: annotate-comments.cpp:195:6: FunctionDecl=isdoxy45:{{.*}} BriefComment=[\n Ddd eee.\n Fff.\n]
|