2015-10-22 19:31:44 +08:00
|
|
|
// RUN: %check_clang_tidy %s misc-argument-comment %t
|
2014-03-18 12:46:45 +08:00
|
|
|
|
|
|
|
// FIXME: clang-tidy should provide a -verify mode to make writing these checks
|
|
|
|
// easier and more accurate.
|
|
|
|
|
|
|
|
void ffff(int xxxx, int yyyy);
|
|
|
|
|
2014-07-30 22:31:36 +08:00
|
|
|
void f(int x, int y);
|
2014-03-18 12:46:45 +08:00
|
|
|
void g() {
|
2014-10-26 10:58:07 +08:00
|
|
|
// CHECK-MESSAGES: [[@LINE+4]]:5: warning: argument name 'y' in comment does not match parameter name 'x'
|
|
|
|
// CHECK-MESSAGES: :[[@LINE-3]]:12: note: 'x' declared here
|
|
|
|
// CHECK-MESSAGES: [[@LINE+2]]:14: warning: argument name 'z' in comment does not match parameter name 'y'
|
|
|
|
// CHECK-MESSAGES: :[[@LINE-5]]:19: note: 'y' declared here
|
2014-03-18 12:46:45 +08:00
|
|
|
f(/*y=*/0, /*z=*/0);
|
|
|
|
}
|
|
|
|
|
2014-07-30 22:31:36 +08:00
|
|
|
struct Closure {};
|
|
|
|
|
|
|
|
template <typename T1, typename T2>
|
|
|
|
Closure *NewCallback(void (*f)(T1, T2), T1 arg1, T2 arg2) { return nullptr; }
|
|
|
|
|
|
|
|
template <typename T1, typename T2>
|
|
|
|
Closure *NewPermanentCallback(void (*f)(T1, T2), T1 arg1, T2 arg2) { return nullptr; }
|
|
|
|
|
|
|
|
void h() {
|
|
|
|
(void)NewCallback(&ffff, /*xxxx=*/11, /*yyyy=*/22);
|
|
|
|
(void)NewPermanentCallback(&ffff, /*xxxx=*/11, /*yyyy=*/22);
|
|
|
|
}
|
2014-09-03 22:56:30 +08:00
|
|
|
|
|
|
|
template<typename... Args>
|
|
|
|
void variadic(Args&&... args);
|
|
|
|
|
|
|
|
template<typename... Args>
|
|
|
|
void variadic2(int zzz, Args&&... args);
|
|
|
|
|
|
|
|
void templates() {
|
|
|
|
variadic(/*xxx=*/0, /*yyy=*/1);
|
|
|
|
variadic2(/*zzZ=*/0, /*xxx=*/1, /*yyy=*/2);
|
2014-10-26 10:58:07 +08:00
|
|
|
// CHECK-MESSAGES: [[@LINE-1]]:13: warning: argument name 'zzZ' in comment does not match parameter name 'zzz'
|
2014-09-03 22:56:30 +08:00
|
|
|
}
|