bugprone-argument-comment¶
Checks that argument comments match parameter names and can optionally add missing comments for literals, init-lists, and constructed temporaries.
The check understands argument comments in the form /*parameter_name=*/
that are placed right before the argument.
void f(bool foo);
...
f(/*bar=*/true);
// warning: argument name 'bar' in comment does not match parameter name 'foo'
The check tries to detect typos and suggest automated fixes for them. It can also insert missing comments for configured argument kinds.
Options¶
- StrictMode¶
When false, the check will ignore leading and trailing underscores and case when comparing names – otherwise they are taken into account. Default is false.
- IgnoreSingleArgument¶
When true, the check will ignore the single argument. Default is false.
- CommentAnonymousInitLists¶
When true, the check will add argument comments in the format
/*ParameterName=*/right before anonymous braced-init list arguments such as{}and{1, 2, 3}. Default is false.
Before:
void foo(const std::vector<int> &Dims);
foo({});
After:
void foo(const std::vector<int> &Dims);
foo(/*Dims=*/{});
- CommentBoolLiterals¶
When true, the check will add argument comments in the format
/*ParameterName=*/right before the boolean literal argument. Default is false.
Before:
void foo(bool TurnKey, bool PressButton);
foo(true, false);
After:
void foo(bool TurnKey, bool PressButton);
foo(/*TurnKey=*/true, /*PressButton=*/false);
- CommentCharacterLiterals¶
When true, the check will add argument comments in the format
/*ParameterName=*/right before the character literal argument. Default is false.
Before:
void foo(char *Character);
foo('A');
After:
void foo(char *Character);
foo(/*Character=*/'A');
- CommentFloatLiterals¶
When true, the check will add argument comments in the format
/*ParameterName=*/right before the float/double literal argument. Default is false.
Before:
void foo(float Pi);
foo(3.14159);
After:
void foo(float Pi);
foo(/*Pi=*/3.14159);
- CommentIntegerLiterals¶
When true, the check will add argument comments in the format
/*ParameterName=*/right before the integer literal argument. Default is false.
Before:
void foo(int MeaningOfLife);
foo(42);
After:
void foo(int MeaningOfLife);
foo(/*MeaningOfLife=*/42);
- CommentNullPtrs¶
When true, the check will add argument comments in the format
/*ParameterName=*/right before the nullptr literal argument. Default is false.
Before:
void foo(A* Value);
foo(nullptr);
After:
void foo(A* Value);
foo(/*Value=*/nullptr);
- CommentParenthesizedTemporaries¶
When true, the check will add argument comments in the format
/*ParameterName=*/right before explicit temporary constructions such asType()andType(1, 2, 3). Default is false.
Before:
struct Dims {
Dims();
Dims(int, int, int);
};
void foo(const Dims &DimsValue);
foo(Dims());
foo(Dims(1, 2, 3));
After:
struct Dims {
Dims();
Dims(int, int, int);
};
void foo(const Dims &DimsValue);
foo(/*DimsValue=*/Dims());
foo(/*DimsValue=*/Dims(1, 2, 3));
- CommentStringLiterals¶
When true, the check will add argument comments in the format
/*ParameterName=*/right before the string literal argument. Default is false.
Before:
void foo(const char *String);
void foo(const wchar_t *WideString);
foo("Hello World");
foo(L"Hello World");
After:
void foo(const char *String);
void foo(const wchar_t *WideString);
foo(/*String=*/"Hello World");
foo(/*WideString=*/L"Hello World");
- CommentTypedInitLists¶
When true, the check will add argument comments in the format
/*ParameterName=*/right before typed braced-init list arguments such asType{}. Default is false.
Before:
void foo(const std::vector<int> &Dims);
foo(std::vector<int>{});
After:
void foo(const std::vector<int> &Dims);
foo(/*Dims=*/std::vector<int>{});
- CommentUserDefinedLiterals¶
When true, the check will add argument comments in the format
/*ParameterName=*/right before the user defined literal argument. Default is false.
Before:
void foo(double Distance);
double operator"" _km(long double);
foo(402.0_km);
After:
void foo(double Distance);
double operator"" _km(long double);
foo(/*Distance=*/402.0_km);