refactor last commit to move unknown type output to seperate function
This commit is contained in:
parent
989235b509
commit
9994218aa2
136
lib/tokenize.cpp
136
lib/tokenize.cpp
|
@ -4811,72 +4811,7 @@ bool Tokenizer::simplifyTokenList()
|
||||||
|
|
||||||
if (_settings->debugwarnings)
|
if (_settings->debugwarnings)
|
||||||
{
|
{
|
||||||
getSymbolDatabase();
|
printUnknownTypes();
|
||||||
|
|
||||||
std::set<std::string> unknowns;
|
|
||||||
|
|
||||||
for (size_t i = 1; i <= _varId; i++)
|
|
||||||
{
|
|
||||||
const Variable *var = _symbolDatabase->getVariableFromVarId(i);
|
|
||||||
|
|
||||||
// is unknown record type?
|
|
||||||
if (var && var->isClass() && !var->type())
|
|
||||||
{
|
|
||||||
std::string name;
|
|
||||||
|
|
||||||
// single token type?
|
|
||||||
if (var->typeStartToken() == var->typeEndToken())
|
|
||||||
name = var->typeStartToken()->str();
|
|
||||||
|
|
||||||
// complcated type
|
|
||||||
else
|
|
||||||
{
|
|
||||||
const Token *tok = var->typeStartToken();
|
|
||||||
int level = 0;
|
|
||||||
|
|
||||||
while (tok)
|
|
||||||
{
|
|
||||||
// skip pointer and reference part of type
|
|
||||||
if (level == 0 && (tok->str() == "*" || tok->str() == "&"))
|
|
||||||
break;
|
|
||||||
|
|
||||||
name += tok->str();
|
|
||||||
|
|
||||||
if (Token::Match(tok, "struct|union"))
|
|
||||||
name += " ";
|
|
||||||
|
|
||||||
// pointers and referennces are OK in template
|
|
||||||
else if (tok->str() == "<")
|
|
||||||
level++;
|
|
||||||
else if (tok->str() == ">")
|
|
||||||
level--;
|
|
||||||
|
|
||||||
if (tok == var->typeEndToken())
|
|
||||||
break;
|
|
||||||
|
|
||||||
tok = tok->next();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
unknowns.insert(name);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!unknowns.empty())
|
|
||||||
{
|
|
||||||
std::ostringstream ss;
|
|
||||||
|
|
||||||
ss << unknowns.size() << " unknown types:" << std::endl;
|
|
||||||
|
|
||||||
std::set<std::string>::const_iterator it;
|
|
||||||
size_t count = 1;
|
|
||||||
|
|
||||||
for (it = unknowns.begin(); it != unknowns.end(); ++it, ++count)
|
|
||||||
ss << count << ": " << *it << std::endl;
|
|
||||||
|
|
||||||
if (_errorLogger)
|
|
||||||
_errorLogger->reportOut(ss.str());
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
|
@ -11148,3 +11083,72 @@ void Tokenizer::simplifyReturn()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Tokenizer::printUnknownTypes()
|
||||||
|
{
|
||||||
|
getSymbolDatabase();
|
||||||
|
|
||||||
|
std::set<std::string> unknowns;
|
||||||
|
|
||||||
|
for (size_t i = 1; i <= _varId; i++)
|
||||||
|
{
|
||||||
|
const Variable *var = _symbolDatabase->getVariableFromVarId(i);
|
||||||
|
|
||||||
|
// is unknown record type?
|
||||||
|
if (var && var->isClass() && !var->type())
|
||||||
|
{
|
||||||
|
std::string name;
|
||||||
|
|
||||||
|
// single token type?
|
||||||
|
if (var->typeStartToken() == var->typeEndToken())
|
||||||
|
name = var->typeStartToken()->str();
|
||||||
|
|
||||||
|
// complcated type
|
||||||
|
else
|
||||||
|
{
|
||||||
|
const Token *tok = var->typeStartToken();
|
||||||
|
int level = 0;
|
||||||
|
|
||||||
|
while (tok)
|
||||||
|
{
|
||||||
|
// skip pointer and reference part of type
|
||||||
|
if (level == 0 && (tok->str() == "*" || tok->str() == "&"))
|
||||||
|
break;
|
||||||
|
|
||||||
|
name += tok->str();
|
||||||
|
|
||||||
|
if (Token::Match(tok, "struct|union"))
|
||||||
|
name += " ";
|
||||||
|
|
||||||
|
// pointers and referennces are OK in template
|
||||||
|
else if (tok->str() == "<")
|
||||||
|
level++;
|
||||||
|
else if (tok->str() == ">")
|
||||||
|
level--;
|
||||||
|
|
||||||
|
if (tok == var->typeEndToken())
|
||||||
|
break;
|
||||||
|
|
||||||
|
tok = tok->next();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
unknowns.insert(name);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!unknowns.empty())
|
||||||
|
{
|
||||||
|
std::ostringstream ss;
|
||||||
|
|
||||||
|
ss << unknowns.size() << " unknown types:" << std::endl;
|
||||||
|
|
||||||
|
std::set<std::string>::const_iterator it;
|
||||||
|
size_t count = 1;
|
||||||
|
|
||||||
|
for (it = unknowns.begin(); it != unknowns.end(); ++it, ++count)
|
||||||
|
ss << count << ": " << *it << std::endl;
|
||||||
|
|
||||||
|
if (_errorLogger)
|
||||||
|
_errorLogger->reportOut(ss.str());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
|
@ -709,6 +709,11 @@ public:
|
||||||
*/
|
*/
|
||||||
void simplifyReturn();
|
void simplifyReturn();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Output list of unknown types.
|
||||||
|
*/
|
||||||
|
void printUnknownTypes();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
/** Disable copy constructor, no implementation */
|
/** Disable copy constructor, no implementation */
|
||||||
Tokenizer(const Tokenizer &);
|
Tokenizer(const Tokenizer &);
|
||||||
|
|
Loading…
Reference in New Issue