CheckClass: Refactor hasAssignSelf to use AST

This commit is contained in:
Daniel Marjamäki 2017-07-28 23:49:11 +02:00
parent 62b84e31ab
commit 01f023dc0a
1 changed files with 22 additions and 14 deletions

View File

@ -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;
} }
} }