You've already forked linux-packaging-mono
							
							
		
			
	
	
		
			90 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
		
		
			
		
	
	
			90 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
|   | // RUN: %check_clang_tidy %s bugprone-argument-comment %t
 | ||
|  | 
 | ||
|  | // FIXME: clang-tidy should provide a -verify mode to make writing these checks
 | ||
|  | // easier and more accurate.
 | ||
|  | 
 | ||
|  | void ffff(int xxxx, int yyyy); | ||
|  | 
 | ||
|  | void f(int x, int y); | ||
|  | void g() { | ||
|  |   // 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
 | ||
|  |   f(/*y=*/0, /*z=*/0); | ||
|  |   // CHECK-FIXES: {{^}}  f(/*y=*/0, /*z=*/0);
 | ||
|  | 
 | ||
|  |   f(/*x=*/1, /*y=*/1); | ||
|  | 
 | ||
|  |   ffff(0 /*aaaa=*/, /*bbbb*/ 0); // Unsupported formats.
 | ||
|  | } | ||
|  | 
 | ||
|  | struct C { | ||
|  |   C(int x, int y); | ||
|  | }; | ||
|  | C c(/*x=*/0, /*y=*/0); | ||
|  | 
 | ||
|  | 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); | ||
|  | } | ||
|  | 
 | ||
|  | template<typename... Args> | ||
|  | void variadic(Args&&... args); | ||
|  | 
 | ||
|  | template<typename... Args> | ||
|  | void variadic2(int zzz, Args&&... args); | ||
|  | 
 | ||
|  | void templates() { | ||
|  |   variadic(/*xxx=*/0, /*yyy=*/1); | ||
|  |   variadic2(/*zzU=*/0, /*xxx=*/1, /*yyy=*/2); | ||
|  |   // CHECK-MESSAGES: [[@LINE-1]]:13: warning: argument name 'zzU' in comment does not match parameter name 'zzz'
 | ||
|  |   // CHECK-FIXES: variadic2(/*zzz=*/0, /*xxx=*/1, /*yyy=*/2);
 | ||
|  | } | ||
|  | 
 | ||
|  | #define FALSE 0
 | ||
|  | void qqq(bool aaa); | ||
|  | void f2() { qqq(/*bbb=*/FALSE); } | ||
|  | // CHECK-MESSAGES: [[@LINE-1]]:17: warning: argument name 'bbb' in comment does not match parameter name 'aaa'
 | ||
|  | // CHECK-FIXES: void f2() { qqq(/*bbb=*/FALSE); }
 | ||
|  | 
 | ||
|  | void f3(bool _with_underscores_); | ||
|  | void ignores_underscores() { | ||
|  |   f3(/*With_Underscores=*/false); | ||
|  | } | ||
|  | 
 | ||
|  | namespace ThisEditDistanceAboveThreshold { | ||
|  | void f4(int xxx); | ||
|  | void g() { f4(/*xyz=*/0); } | ||
|  | // CHECK-MESSAGES: [[@LINE-1]]:15: warning: argument name 'xyz' in comment does not match parameter name 'xxx'
 | ||
|  | // CHECK-FIXES: void g() { f4(/*xyz=*/0); }
 | ||
|  | } | ||
|  | 
 | ||
|  | namespace OtherEditDistanceAboveThreshold { | ||
|  | void f5(int xxx, int yyy); | ||
|  | void g() { f5(/*Zxx=*/0, 0); } | ||
|  | // CHECK-MESSAGES: [[@LINE-1]]:15: warning: argument name 'Zxx' in comment does not match parameter name 'xxx'
 | ||
|  | // CHECK-FIXES: void g() { f5(/*xxx=*/0, 0); }
 | ||
|  | struct C2 { | ||
|  |   C2(int xxx, int yyy); | ||
|  | }; | ||
|  | C2 c2(/*Zxx=*/0, 0); | ||
|  | // CHECK-MESSAGES: [[@LINE-1]]:7: warning: argument name 'Zxx' in comment does not match parameter name 'xxx'
 | ||
|  | // CHECK-FIXES: C2 c2(/*xxx=*/0, 0);
 | ||
|  | } | ||
|  | 
 | ||
|  | namespace OtherEditDistanceBelowThreshold { | ||
|  | void f6(int xxx, int yyy); | ||
|  | void g() { f6(/*xxy=*/0, 0); } | ||
|  | // CHECK-MESSAGES: [[@LINE-1]]:15: warning: argument name 'xxy' in comment does not match parameter name 'xxx'
 | ||
|  | // CHECK-FIXES: void g() { f6(/*xxy=*/0, 0); }
 | ||
|  | } |