CheckAutoVariables(returnPointerToLocalArray): replace std::list to std::set
Use std::set and std::set::find() instead of std::list and std::find(). First should be faster (runs in the logarithmic time) than second (runs in linear time). No functional change.
This commit is contained in:
parent
2dccf150ab
commit
743d5331ee
|
@ -22,9 +22,7 @@
|
||||||
|
|
||||||
#include "checkautovariables.h"
|
#include "checkautovariables.h"
|
||||||
|
|
||||||
#include <algorithm>
|
|
||||||
#include <sstream>
|
#include <sstream>
|
||||||
#include <list>
|
|
||||||
#include <iostream>
|
#include <iostream>
|
||||||
#include <string>
|
#include <string>
|
||||||
|
|
||||||
|
@ -212,7 +210,7 @@ void CheckAutoVariables::returnPointerToLocalArray()
|
||||||
{
|
{
|
||||||
bool infunc = false;
|
bool infunc = false;
|
||||||
int indentlevel = 0;
|
int indentlevel = 0;
|
||||||
std::list<unsigned int> arrayVar;
|
std::set<unsigned int> arrayVar;
|
||||||
for (const Token *tok = _tokenizer->tokens(); tok; tok = tok->next())
|
for (const Token *tok = _tokenizer->tokens(); tok; tok = tok->next())
|
||||||
{
|
{
|
||||||
// Is there a function declaration for a function that returns a pointer?
|
// Is there a function declaration for a function that returns a pointer?
|
||||||
|
@ -250,14 +248,14 @@ void CheckAutoVariables::returnPointerToLocalArray()
|
||||||
// Declaring a local array..
|
// Declaring a local array..
|
||||||
if (Token::Match(tok, "[;{}] %type% %var% ["))
|
if (Token::Match(tok, "[;{}] %type% %var% ["))
|
||||||
{
|
{
|
||||||
arrayVar.push_back(tok->tokAt(2)->varId());
|
arrayVar.insert(tok->tokAt(2)->varId());
|
||||||
}
|
}
|
||||||
|
|
||||||
// Return pointer to local array variable..
|
// Return pointer to local array variable..
|
||||||
if (Token::Match(tok, "return %var% ;"))
|
if (Token::Match(tok, "return %var% ;"))
|
||||||
{
|
{
|
||||||
unsigned int varid = tok->next()->varId();
|
unsigned int varid = tok->next()->varId();
|
||||||
if (varid > 0 && std::find(arrayVar.begin(), arrayVar.end(), varid) != arrayVar.end())
|
if (varid > 0 && arrayVar.find(varid) != arrayVar.end())
|
||||||
errorReturnPointerToLocalArray(tok);
|
errorReturnPointerToLocalArray(tok);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue