diff options
author | Anna Zaks <ganna@apple.com> | 2011-07-19 19:49:12 +0000 |
---|---|---|
committer | Anna Zaks <ganna@apple.com> | 2011-07-19 19:49:12 +0000 |
commit | b89fe6b04c5b8a2d080c1c5605b72f809fc9ee68 (patch) | |
tree | 0be56fae1040f8ee024eec595f1c877c84fa9068 /test/FixIt/fixit-function-call.cpp | |
parent | b536a1565c9d72a8caacf75d97dffd19cb2777ad (diff) |
Add FixItHints in case a C++ function call is missing * or & operators on one/several of it's parameters (addresses http://llvm.org/PR5941).
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@135509 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'test/FixIt/fixit-function-call.cpp')
-rw-r--r-- | test/FixIt/fixit-function-call.cpp | 87 |
1 files changed, 87 insertions, 0 deletions
diff --git a/test/FixIt/fixit-function-call.cpp b/test/FixIt/fixit-function-call.cpp new file mode 100644 index 0000000000..e59e21b933 --- /dev/null +++ b/test/FixIt/fixit-function-call.cpp @@ -0,0 +1,87 @@ +// RUN: %clang_cc1 -fdiagnostics-parseable-fixits -x c++ %s 2> %t || true +// RUN: FileCheck %s < %t +// PR5941 +// END. + +/* Test fixits for * and & mismatch in function arguments. + * Since fixits are on the notes, they cannot be applied automatically. */ + +typedef int intTy; +typedef int intTy2; + +void f0(int *a); +void f1(double *a); +void f1(intTy &a); + +void f2(intTy2 *a) { +// CHECK: error: no matching function for call to 'f1 +// CHECK: dereference the argument with * +// CHECK: void f1(intTy &a); +// CHECK: fix-it{{.*}}*( +// CHECK-NEXT: fix-it{{.*}}) +// CHECK: void f1(double *a); + f1(a + 1); + +// This call cannot be fixed since without resulting in null pointer dereference. +// CHECK: error: no matching function for call to 'f1 +// CHECK-NOT: take the address of the argument with & +// CHECK-NOT: fix-it + f1((int *)0); +} + +void f3(int &a) { +// CHECK: error: no matching function for call to 'f0 +// CHECK: fix-it{{.*}}& + f0(a); +} + + +void m(int *a, const int *b); // match 2 +void m(double *a, int *b); // no match +void m(int *a, double *b); // no match +void m(intTy &a, int *b); // match 1 + +void mcaller(intTy2 a, int b) { +// CHECK: error: no matching function for call to 'm +// CHECK: take the address of the argument with & +// CHECK: fix-it{{.*}}& +// CHECK: take the address of the argument with & +// CHECK: fix-it{{.*}}& +// CHECK: fix-it{{.*}}& + m(a, b); + +// This call cannot be fixed because (a + 1) is not an l-value. +// CHECK: error: no matching function for call to 'm +// CHECK-NOT: fix-it + m(a + 1, b); +} + +// Test derived to base conversions. +struct A { + int xx; +}; + +struct B : public A { + double y; +}; + +bool br(A &a); +bool bp(A *a); +bool dv(B b); + +void dbcaller(A *ptra, B *ptrb) { + B b; + +// CHECK: error: no matching function for call to 'br +// CHECK: fix-it{{.*}}* + br(ptrb); // good +// CHECK: error: no matching function for call to 'bp +// CHECK: fix-it{{.*}}& + bp(b); // good + +// CHECK: error: no matching function for call to 'dv +// CHECK-NOT: fix-it + dv(ptra); // bad: base to derived +} + +// CHECK: errors generated |