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:
Slava Semushin 2009-08-16 16:29:48 +07:00
parent 2dccf150ab
commit 743d5331ee
1 changed files with 3 additions and 5 deletions

View File

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