<table border="1" cellspacing="0" cellpadding="8">
<tr>
<th>Issue</th>
<td>
<a href=https://github.com/llvm/llvm-project/issues/84705>84705</a>
</td>
</tr>
<tr>
<th>Summary</th>
<td>
`bugprone-unused-return-value` reported on iterator increment in loop condition
</td>
</tr>
<tr>
<th>Labels</th>
<td>
new issue
</td>
</tr>
<tr>
<th>Assignees</th>
<td>
</td>
</tr>
<tr>
<th>Reporter</th>
<td>
firewave
</td>
</tr>
</table>
<pre>
With `bugprone-unused-return-value.CheckFunctions` set to `::.*`.
```cpp
#include <string>
void f()
{
std::string s;
for (std::string::const_iterator it = s.cbegin(); it != s.cend(); ++it) {}
for (std::string::const_iterator it = s.cbegin(); it != s.cend(); it++) {}
}
```
```
test.cpp:6:71: error: the value returned by this function should not be disregarded; neglecting it may lead to errors [bugprone-unused-return-value,-warnings-as-errors]
6 | for (std::string::const_iterator it = s.cbegin(); it != s.cend(); ++it) {}
| ^~~~
test.cpp:6:71: note: cast the expression to void to silence this warning
test.cpp:7:71: error: the value returned by this function should not be disregarded; neglecting it may lead to errors [bugprone-unused-return-value,-warnings-as-errors]
7 | for (std::string::const_iterator it = s.cbegin(); it != s.cend(); it++) {}
| ^~~~
test.cpp:7:71: note: cast the expression to void to silence this warning
```
The result is actually used by the loop condition.
Some context on why I am trying to match all functions which might seem excessive.
This is actually something I wanted for quite a while. The idea was a bit more limited in that I wanted to find functions within test code which do not check the results. But simply enabling it in the context of the test folder actually has the same effect and actually goes a bit further.
</pre>
<img width="1px" height="1px" alt="" src="http://email.email.llvm.org/o/eJzUVUGP4zYP_TXKhYjhyHGcHHxIZjbAnr8P6LGQJdpWK0upSE82l_ntheRMM9MuppeiiwJGLJsmH_keGSoiO3jEVtQnUT-v1MxjiG1vI17VC666YG7tT5ZHELuym4dLDB7Xs58JzToiz9GvX5SbsXgaUf96nr1mGzyJXQmEDBySo6iOojoWQh7FrixE-SzK4_13Vy6Xvlzub2RlvXazQRDVE3G0fhDVl_dOL8Ea6IXcC3m4v29OywGIzYK2eAKJ6s0EAH2IIOT-Tx8tZx088c-WMSoOESyDqJ6BCt3hYP0drTplg9zcbejNwyLkSciTZSEPkDJqnv8t5IR5ytdH5Mfhjefvkr88MhIXSYfquBPVsdmI6ggYY4jpwCNCVhoW2dFAdwMeLUF_Vx1oDLMz4ANDh2AsRRxUNGhSjh4Hh5qTKJZhUjdwqEzqkIxBIOrTZx0m5NP6qqK3fqC1ovXiJep3JO9ANE8_UGTI-KL-8vr6-gmnPjCmu1bEmVf8dolIlCjkALm9OQBZh17jwvG98r9Ebf6bSjWZqR83GJ8J1fxzQn137P4_JmVodgyWQGmelXM3SDQuQiG4EC6ggzc2qfXhH_N_YcJkYvzGEDxcxxt8BTUBx1tSjANMivUIyrk_9Ca4jlaPMNlhZCDECfCbTpW8YPGWlaUP-VCYkMcU8itclWc0WavfZssIKgV0WEAqxhpUcFUECrrUMCEiODvZ5GI98Kj4EYMD9Nab96nZBANJAdDB4D1XE3J76rRXMikLZ1TAaWYgO13cDdCrzt0bNUO946bPjzlsH5zB-KhtVJSNpCYE7HvUDMqbxwdDwLdy-jnyiLFYmbYyh-qgVthumk25kWVZ71Zj21Rmv93r0pSl2WxRVWWlsawOO6z3O12blW1lKbdltclO9a6ot_2hafQB9wclN50R2xInZV3h3MtUhDisLNGM7X7blPXKqQ4d5Q0tpccrZKOQMi3s2CafdTcPJLals8T0iMKWHbZ_s7nTqo54CTGpEzw8xs3riBP6zOzHjlzN0bUj84XSoMqzkOfB8jh3hQ6TkOeUwf22vsTwC2oW8pzzJiHPua7fAwAA__-x3a74">