diff --git a/lib/checkcondition.cpp b/lib/checkcondition.cpp index 5d0e77957..3455ef009 100644 --- a/lib/checkcondition.cpp +++ b/lib/checkcondition.cpp @@ -1764,10 +1764,13 @@ void CheckCondition::checkDuplicateConditionalAssign() continue; bool isRedundant = false; if (isBoolVar) { - if (!astIsBool(condTok)) - continue; const bool isNegation = condTok->str() == "!"; - if (!(assignTok->astOperand1() && assignTok->astOperand1()->varId() == (isNegation ? condTok->next() : condTok)->varId())) + const Token* const varTok = isNegation ? condTok->next() : condTok; + const ValueType* vt = varTok->variable() ? varTok->variable()->valueType() : nullptr; + if (!(vt && vt->type == ValueType::Type::BOOL && !vt->pointer)) + continue; + + if (!(assignTok->astOperand1() && assignTok->astOperand1()->varId() == varTok->varId())) continue; if (!(assignTok->astOperand2() && assignTok->astOperand2()->hasKnownIntValue())) continue; diff --git a/test/testcondition.cpp b/test/testcondition.cpp index a1152b212..7fc125370 100644 --- a/test/testcondition.cpp +++ b/test/testcondition.cpp @@ -5441,6 +5441,12 @@ private: "}\n"); ASSERT_EQUALS("", errout.str()); + check("void f(int& i) {\n" + " if (!i)\n" + " i = 1; \n" + "}\n"); + ASSERT_EQUALS("", errout.str()); + check("struct S {\n" // #9406 " S() : b(false) {}\n" " void f() {\n"