[clang-tidy] Fix bugprone-inc-dec-in-conditions FP with lambda condition (#189145)

Fixes https://github.com/llvm/llvm-project/issues/163913.
This commit is contained in:
Baranov Victor 2026-03-29 09:11:28 +03:00 committed by GitHub
parent cf3a0f2553
commit 71263dc615
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
3 changed files with 53 additions and 1 deletions

View File

@ -39,6 +39,9 @@ void IncDecInConditionsCheck::registerMatchers(MatchFinder *Finder) {
expr(anyOf(hasAncestor(expr(matchers::hasUnevaluatedContext())),
hasAncestor(typeLoc())));
auto IsInLambda =
hasAncestor(lambdaExpr(hasAncestor(expr(equalsBoundNode("parent")))));
Finder->addMatcher(
expr(
OperatorMatcher, unless(hasAncestor(OperatorMatcher)),
@ -50,7 +53,7 @@ void IncDecInConditionsCheck::registerMatchers(MatchFinder *Finder) {
cxxOperatorCallExpr(
isPrePostOperator(),
hasUnaryOperand(expr().bind("operand")))),
unless(IsInUnevaluatedContext),
unless(IsInUnevaluatedContext), unless(IsInLambda),
hasAncestor(
expr(equalsBoundNode("parent"),
hasDescendant(

View File

@ -219,6 +219,11 @@ Changes in existing checks
loss in overloads with transparent standard functors (e.g. ``std::plus<>``)
for ``std::accumulate``, ``std::reduce``, and ``std::inner_product``.
- Improved :doc:`bugprone-inc-dec-in-conditions
<clang-tidy/checks/bugprone/inc-dec-in-conditions>` check by fixing a false
positive when increment/decrement operators appear inside lambda bodies that
are part of a condition expression.
- Improved :doc:`bugprone-macro-parentheses
<clang-tidy/checks/bugprone/macro-parentheses>` check by printing the macro
definition in the warning message if the macro is defined on command line.

View File

@ -78,3 +78,47 @@ namespace PR85838 {
if (static_cast<decltype(++foo)>(bar) < foo) {}
}
}
namespace GH163913 {
void lambdaWithIncrement(int size) {
if ([](int n) {
++n;
return n;
}(size) < 42) {}
}
void lambdaWithDecrement(int size) {
if ([](int n) {
--n;
return n;
}(size) < 42) {}
}
template <typename Func>
auto eval(Func&& fn) -> decltype(fn()) {
return fn();
}
void lambdaWithForLoop(int size) {
if (eval([&] {
int result = 0;
for (int i = 0; i < size; i++) {
result += i;
}
return result;
}) < 42) {}
}
void outsideLambda(int size) {
if ([](int n) {
--n;
return n;
}(size) < ++size) {}
// CHECK-MESSAGES: :[[@LINE-1]]:15: warning: incrementing and referencing a variable in a complex condition
if (++size > [](int n) {
--n;
return n;
}(size)) {}
// CHECK-MESSAGES: :[[@LINE-4]]:9: warning: incrementing and referencing a variable in a complex condition
}
}