We still allow the escape hatch foo(int /*x*/) and also suggest this
in a fixit. This is more powerful than the corresponding cpplint.py check
it also flags functions with multiple arguments as naming all arguments is
recommended by the google style guide.
Details
Diff Detail
Event Timeline
clang-tidy/google/NamedParameterCheck.cpp | ||
---|---|---|
63 | IMO, most functions with unnamed parameters will be derived from some base method. Otherwise, why would they have an unnamed parameter (yes, there are cases, but not that many)? To this end:
|
clang-tidy/google/NamedParameterCheck.cpp | ||
---|---|---|
31 | Why don't you check for isImplicit()? | |
36 | Alternatively this could be done in the swapped arguments check. Both places seem good for this. | |
50 | I'm curious where does Parm->getLocation() point in case where there is a parameter name (to the identifier?) and where there is not? | |
clang-tidy/google/NamedParameterCheck.h | ||
19 | nit: Do we need an empty line to separate the \brief from the rest of the class comment? | |
test/clang-tidy/google-readability-function.cpp | ||
1 | Please add tests with multiple instantiations of the same template. I suspect, currently the check will suggest multiple replacements. |
clang-tidy/google/NamedParameterCheck.cpp | ||
---|---|---|
50 | It always points to the name or the place where the name *would* be. This behavior is a bit strange sometimes but makes things like getting the name in function pointers right very easy, | |
test/clang-tidy/google-readability-function.cpp | ||
1 | I checked that and it doesn't (do warnings get deduplicated somewhere)? I'll add another test. |
- Added a testcase with multiple template instantiations.
- If a method has an unnamed argument and is overriding a method from a base cla
ss try to copy the argument name from the base class first.
test/clang-tidy/google-readability-function.cpp | ||
---|---|---|
1 | Warnings get deduplicated by location and message text, and in your test case deduplication worked correctly. But it's not a good idea to rely on the deduplication in general. | |
70 | What does the check do in this case? struct Base1 { virtual void f(int i) {} }; struct Base2 { virtual void f(bool b) {} }; template <typename T, typename Y> struct Derived : public T { void f(Y) {} }; int main() { Derived<Base1, int>(); Derived<Base2, bool>(); } |
test/clang-tidy/google-readability-function.cpp | ||
---|---|---|
70 | I think it works because we see the template definition first. But I'll add the bulky template instance matcher, safe is better. 5:13: warning: all parameters should be named in a function [google-readability-function] void f(Y) {} ^ /*unused*/ |
Looks good!
clang-tidy/google/NamedParameterCheck.cpp | ||
---|---|---|
74 | Add a comma after "overridden"? |
nit: Do we need an empty line to separate the \brief from the rest of the class comment?