CheckClass: Refactor hasAssignSelf to use AST
This commit is contained in:
parent
62b84e31ab
commit
01f023dc0a
|
@ -30,6 +30,7 @@
|
||||||
|
|
||||||
#include <algorithm>
|
#include <algorithm>
|
||||||
#include <cstdlib>
|
#include <cstdlib>
|
||||||
|
#include <stack>
|
||||||
#include <utility>
|
#include <utility>
|
||||||
//---------------------------------------------------------------------------
|
//---------------------------------------------------------------------------
|
||||||
|
|
||||||
|
@ -1486,21 +1487,28 @@ bool CheckClass::hasAssignSelf(const Function *func, const Token *rhs)
|
||||||
return false;
|
return false;
|
||||||
const Token *last = func->functionScope->classEnd;
|
const Token *last = func->functionScope->classEnd;
|
||||||
for (const Token *tok = func->functionScope->classStart; tok && tok != last; tok = tok->next()) {
|
for (const Token *tok = func->functionScope->classStart; tok && tok != last; tok = tok->next()) {
|
||||||
if (Token::simpleMatch(tok, "if (")) {
|
if (!Token::simpleMatch(tok, "if ("))
|
||||||
const Token *tok1 = tok->tokAt(2);
|
continue;
|
||||||
const Token *tok2 = tok->next()->link();
|
|
||||||
|
|
||||||
if (tok1 && tok2) {
|
std::stack<const Token *> tokens;
|
||||||
for (; tok1 && tok1 != tok2; tok1 = tok1->next()) {
|
tokens.push(tok->next()->astOperand2());
|
||||||
if (Token::Match(tok1, "this ==|!= & %name%")) {
|
while (!tokens.empty()) {
|
||||||
if (tok1->strAt(3) == rhs->str())
|
const Token *tok2 = tokens.top();
|
||||||
return true;
|
tokens.pop();
|
||||||
} else if (Token::Match(tok1, "& %name% ==|!= this")) {
|
if (!tok2)
|
||||||
if (tok1->strAt(1) == rhs->str())
|
continue;
|
||||||
return true;
|
tokens.push(tok2->astOperand1());
|
||||||
}
|
tokens.push(tok2->astOperand2());
|
||||||
}
|
if (!Token::Match(tok2, "==|!="))
|
||||||
}
|
continue;
|
||||||
|
if (Token::simpleMatch(tok2->astOperand1(), "this"))
|
||||||
|
tok2 = tok2->astOperand2();
|
||||||
|
else if (Token::simpleMatch(tok2->astOperand2(), "this"))
|
||||||
|
tok2 = tok2->astOperand1();
|
||||||
|
else
|
||||||
|
continue;
|
||||||
|
if (tok2 && tok2->str() == "&" && !tok2->astOperand2() && tok2->astOperand1() && tok2->astOperand1()->str() == rhs->str())
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue