Home | History | Annotate | Download | only in Sema
      1 // RUN: %clang_cc1 -fsyntax-only -Wdocumentation -Wdocumentation-pedantic -fcomment-block-commands=foobar -verify %s
      2 // RUN: %clang_cc1 -fsyntax-only -Wdocumentation -Wdocumentation-pedantic -fcomment-block-commands=foobar -fdiagnostics-parseable-fixits %s 2>&1 | FileCheck %s
      3 
      4 // expected-warning@+1 {{parameter 'ZZZZZZZZZZ' not found in the function declaration}} expected-note@+1 {{did you mean 'a'?}}
      5 /// \param ZZZZZZZZZZ Blah blah.
      6 int test1(int a);
      7 
      8 // expected-warning@+1 {{parameter 'aab' not found in the function declaration}} expected-note@+1 {{did you mean 'aaa'?}}
      9 /// \param aab Blah blah.
     10 int test2(int aaa, int bbb);
     11 
     12 // expected-warning@+1 {{template parameter 'ZZZZZZZZZZ' not found in the template declaration}} expected-note@+1 {{did you mean 'T'?}}
     13 /// \tparam ZZZZZZZZZZ Aaa
     14 template<typename T>
     15 void test3(T aaa);
     16 
     17 // expected-warning@+1 {{template parameter 'SomTy' not found in the template declaration}} expected-note@+1 {{did you mean 'SomeTy'?}}
     18 /// \tparam SomTy Aaa
     19 /// \tparam OtherTy Bbb
     20 template<typename SomeTy, typename OtherTy>
     21 void test4(SomeTy aaa, OtherTy bbb);
     22 
     23 // expected-warning@+1 {{declaration is marked with '\deprecated' command but does not have a deprecation attribute}} expected-note@+2 {{add a deprecation attribute to the declaration to silence this warning}}
     24 /// \deprecated
     25 void test_deprecated_1();
     26 
     27 // expected-warning@+1 {{declaration is marked with '\deprecated' command but does not have a deprecation attribute}} expected-note@+2 {{add a deprecation attribute to the declaration to silence this warning}}
     28 /// \deprecated
     29 void test_deprecated_2(int a);
     30 
     31 struct test_deprecated_3 {
     32   // expected-warning@+1 {{declaration is marked with '\deprecated' command but does not have a deprecation attribute}} expected-note@+2 {{add a deprecation attribute to the declaration to silence this warning}}
     33   /// \deprecated
     34   void test_deprecated_4();
     35 
     36   // expected-warning@+1 {{declaration is marked with '\deprecated' command but does not have a deprecation attribute}} expected-note@+2 {{add a deprecation attribute to the declaration to silence this warning}}
     37   /// \deprecated
     38   void test_deprecated_5() {
     39   }
     40 };
     41 
     42 template<typename T>
     43 struct test_deprecated_6 {
     44   // expected-warning@+1 {{declaration is marked with '\deprecated' command but does not have a deprecation attribute}} expected-note@+2 {{add a deprecation attribute to the declaration to silence this warning}}
     45   /// \deprecated
     46   void test_deprecated_7();
     47 
     48   // expected-warning@+1 {{declaration is marked with '\deprecated' command but does not have a deprecation attribute}} expected-note@+2 {{add a deprecation attribute to the declaration to silence this warning}}
     49   /// \deprecated
     50   void test_deprecated_8() {
     51   }
     52 };
     53 
     54 #define MY_ATTR_DEPRECATED __attribute__((deprecated))
     55 
     56 // expected-warning@+1 {{declaration is marked with '\deprecated' command but does not have a deprecation attribute}} expected-note@+2 {{add a deprecation attribute to the declaration to silence this warning}}
     57 /// \deprecated
     58 void test_deprecated_9(int a);
     59 
     60 // rdar://12381408
     61 // expected-warning@+2  {{unknown command tag name 'retur'; did you mean 'return'?}}
     62 /// \brief testing fixit
     63 /// \retur int in FooBar
     64 int FooBar();
     65 
     66 // expected-warning@+1  {{unknown command tag name 'fooba'; did you mean 'foobar'?}}
     67 /// \fooba bbb IS_DOXYGEN_END
     68 int gorf();
     69 
     70 // expected-warning@+1 {{unknown command tag name}}
     71 /// \t bbb IS_DOXYGEN_END
     72 int Bar();
     73 
     74 // expected-warning@+2  {{unknown command tag name 'encode'; did you mean 'endcode'?}}
     75 // expected-warning@+1  {{'\endcode' command does not terminate a verbatim text block}}
     76 /// \encode PR18051
     77 int PR18051();
     78 
     79 // CHECK: fix-it:"{{.*}}":{5:12-5:22}:"a"
     80 // CHECK: fix-it:"{{.*}}":{9:12-9:15}:"aaa"
     81 // CHECK: fix-it:"{{.*}}":{13:13-13:23}:"T"
     82 // CHECK: fix-it:"{{.*}}":{18:13-18:18}:"SomeTy"
     83 // CHECK: fix-it:"{{.*}}":{25:25-25:25}:" __attribute__((deprecated))"
     84 // CHECK: fix-it:"{{.*}}":{29:30-29:30}:" __attribute__((deprecated))"
     85 // CHECK: fix-it:"{{.*}}":{34:27-34:27}:" __attribute__((deprecated))"
     86 // CHECK: fix-it:"{{.*}}":{38:27-38:27}:" __attribute__((deprecated))"
     87 // CHECK: fix-it:"{{.*}}":{46:27-46:27}:" __attribute__((deprecated))"
     88 // CHECK: fix-it:"{{.*}}":{50:27-50:27}:" __attribute__((deprecated))"
     89 // CHECK: fix-it:"{{.*}}":{58:30-58:30}:" MY_ATTR_DEPRECATED"
     90 // CHECK: fix-it:"{{.*}}":{63:6-63:11}:"return"
     91 // CHECK: fix-it:"{{.*}}":{67:6-67:11}:"foobar"
     92 // CHECK: fix-it:"{{.*}}":{76:6-76:12}:"endcode"
     93