<table border="1" cellspacing="0" cellpadding="8">
<tr>
<th>Issue</th>
<td>
<a href=https://github.com/llvm/llvm-project/issues/104569>104569</a>
</td>
</tr>
<tr>
<th>Summary</th>
<td>
suggest `modernize-use-auto` for predicate arguments
</td>
</tr>
<tr>
<th>Labels</th>
<td>
clang-tidy,
c++14
</td>
</tr>
<tr>
<th>Assignees</th>
<td>
</td>
</tr>
<tr>
<th>Reporter</th>
<td>
firewave
</td>
</tr>
</table>
<pre>
```cpp
#include <algorithm>
#include <map>
#include <string>
void f()
{
const std::map<int, std::string> m;
auto it = std::find_if(m.cbegin(), m.cend(), [&](const std::pair<const int, std::string>& p){
return p.second.empty();
});
it = std::find_if(m.cbegin(), m.cend(), [&](const decltype(m.cbegin())::value_type& p){
return p.second.empty();
});
(void)it;
}
```
https://godbolt.org/z/4jea1G55e
Starting with C++14 you can use `auto` for the argument in the predicate. This might also prevent issues where a wrong argument might lead to unexpected behavior (like omitting `const` on the first part of the pair leading to the pair being copied for each invocation).
It should probably only be suggested if the existing expression match the result of `decltype(<first>)::value_type` as starting with C++11 by-value is allowed "for VT a move is equivalent to a copy" according to https://en.cppreference.com/w/cpp/algorithm/find.
I think this should be opt-in as it might not desirable in some code bases.
This might be out of scope of the check though based on the current documentation which states it is about "using the auto type specifier for variable declarations". As the check has a very generic name I think this extension would be valid.
</pre>
<img width="1px" height="1px" alt="" src="http://email.email.llvm.org/o/eJysVcGSozYQ_Rr50mUKC4zNgcOMHadyzlauW0JqQ-8KiUgCj_frUxL22DPZPSVTUwy0pKfXr1_3CO-pM4gN276y7XElptBb15zJ4UXMuGqtujasypdfOY4sP7L8hfGCjNSTQmDFQejOOgr9wIrffrY-iPEXKz44Mt1jMT1nSwrOjO8Zr2_x3evyAtIaH8AHxYoXVrwk5AOZwPjhEX1HhYEV95MA8HgTU7BAAVhxfBw7k1FfKV48ZLLFjsyNAz_AkEk06vEd5eIV2x4Z33_iNApyrDgs0V9SY7yCMYLtngjGH4dhcgbGzKO0RmU4jOF6u_hDMrvj59D_m5BCqcN1xJ8crxf8WegJvy57_ks2n1NhfB89wHhN4T0aNy0vdzc-e6YPYfSRFT8xfuqsaq0OmXUd46cfjJ_Kbyg2v2-3-HzozyBcINPBhUIPB8ZfGX_dlHC1E0hhYPIIrMqjWViVw9k6CD2CcN00oInFTd-jQ0VSBMzgS08eBur6AEJ7G5fmtNP7CT1cenQIAi7Omu6BsxzQKBQEC5PBtxFlQAUt9mIm66Iimr4j2IFCYhybMVYp8rILjTM5H2AULoA9L8QEuQQbTwT7iLUYI9KOhCqlhUL2QGa2UgSyhvE6exbqjwC-t5NWMDrbilZfwRp9hRbBT12HPpKl5VJ8I58o4tvo0HuyBgYRZJ9WHfpJJ4Ksyp8cxopD4p8649_2qnIQHvxP67WB9rpOe4E8CK3tBRUwzmNif30BAYOd0xr-PdEsdJQ8WBBRgCvjHISU1t1F-ugkNJkcR4dndGgkZtIOjJ8ujJ_iLOSnx-jjp9huH2WD0JP5Hp_-LmCLYMewJhMTonvtjY395smJVmP0lbcDgrQKoRUe_QfYJ5NFtCnJ6aUd8V542aOM19qp6xOAuptETs7F_JWVyXup3HDpSfZR3oCJVNSxjcCM88knYaLv49CM5QA_oqQzoUvmmYWjxDvWU7gE6RnnGbz4Jzq98CBgRneFDg06kmDEgPBBJXwLaJJnLne5ZqFJZSvVFKouarHCZrPjxT7Py7xe9Y3at2dRFqhQbUvcbGvOq0rsy2IvMK-KckUNz3mZ7zdVXvOqrDNVtdvNbsvrVspdLveszHEQpDOt5yHOjFVq12aTl9uqXmnRovbpHyTnUgvTrQOpaBzGDzF0nxsxsj2uXBNx1u3UeVbmmnzwD-RAQWNza5rYA4NV6Az9wPXkcf08at7Hyvug8KvJ6ebTqKPQT-3Nl_Ga25_16Ow3lIHx0zJ8GD_dEpob_k8AAAD__52hgUw">