Refactoring (use const std::set for strings). Omit some matching for C++ stuff within C code.
This commit is contained in:
parent
eebb5b8c77
commit
13c1c2c035
|
@ -61,34 +61,33 @@ static unsigned int countParameters(const Token *tok)
|
||||||
* This list contains function names with const parameters e.g.: atof(const char *)
|
* This list contains function names with const parameters e.g.: atof(const char *)
|
||||||
* Reference: http://www.aquaphoenix.com/ref/gnu_c_library/libc_492.html#SEC492
|
* Reference: http://www.aquaphoenix.com/ref/gnu_c_library/libc_492.html#SEC492
|
||||||
*/
|
*/
|
||||||
static const char * const call_func_white_list[] = {
|
static const std::set<std::string> call_func_white_list = make_container < std::set<std::string> > ()
|
||||||
"_open", "_wopen", "access", "adjtime", "asctime", "asctime_r", "asprintf", "assert"
|
<< "_open" << "_wopen" << "access" << "adjtime" << "asctime" << "asctime_r" << "asprintf" << "assert"
|
||||||
, "atof", "atoi", "atol", "chdir", "chmod", "chown"
|
<< "atof" << "atoi" << "atol" << "chdir" << "chmod" << "chown"
|
||||||
, "clearerr", "creat", "ctime", "ctime_r", "execl", "execle"
|
<< "clearerr" << "creat" << "ctime" << "ctime_r" << "execl" << "execle"
|
||||||
, "execlp", "execv", "execve", "fchmod", "fclose", "fcntl"
|
<< "execlp" << "execv" << "execve" << "fchmod" << "fclose" << "fcntl"
|
||||||
, "fdatasync", "feof", "ferror", "fflush", "fgetc", "fgetpos", "fgets"
|
<< "fdatasync" << "feof" << "ferror" << "fflush" << "fgetc" << "fgetpos" << "fgets"
|
||||||
, "flock", "fmemopen", "fnmatch", "fopen", "fopencookie", "for", "fprintf", "fputc", "fputs", "fread", "free"
|
<< "flock" << "fmemopen" << "fnmatch" << "fopen" << "fopencookie" << "for" << "fprintf" << "fputc" << "fputs" << "fread" << "free"
|
||||||
, "freopen", "fscanf", "fseek", "fseeko", "fsetpos", "fstat", "fsync", "ftell", "ftello"
|
<< "freopen" << "fscanf" << "fseek" << "fseeko" << "fsetpos" << "fstat" << "fsync" << "ftell" << "ftello"
|
||||||
, "ftruncate", "fwrite", "getc", "getenv","getgrnam", "gethostbyaddr", "gethostbyname", "getnetbyname"
|
<< "ftruncate" << "fwrite" << "getc" << "getenv" << "getgrnam" << "gethostbyaddr" << "gethostbyname" << "getnetbyname"
|
||||||
, "getopt", "getopt_long", "getprotobyname", "getpwnam", "gets", "getservbyname", "getservbyport"
|
<< "getopt" << "getopt_long" << "getprotobyname" << "getpwnam" << "gets" << "getservbyname" << "getservbyport"
|
||||||
, "glob", "gmtime", "gmtime_r", "if", "index", "inet_addr", "inet_aton", "inet_network", "initgroups", "ioctl"
|
<< "glob" << "gmtime" << "gmtime_r" << "if" << "index" << "inet_addr" << "inet_aton" << "inet_network" << "initgroups" << "ioctl"
|
||||||
, "link", "localtime", "localtime_r"
|
<< "link" << "localtime" << "localtime_r"
|
||||||
, "lockf", "lseek", "lstat", "mblen", "mbstowcs", "mbtowc", "memchr", "memcmp", "memcpy", "memmove", "memset"
|
<< "lockf" << "lseek" << "lstat" << "mblen" << "mbstowcs" << "mbtowc" << "memchr" << "memcmp" << "memcpy" << "memmove" << "memset"
|
||||||
, "mkdir", "mkfifo", "mknod", "mkstemp"
|
<< "mkdir" << "mkfifo" << "mknod" << "mkstemp"
|
||||||
, "obstack_printf", "obstack_vprintf", "open", "opendir", "parse_printf_format", "pathconf"
|
<< "obstack_printf" << "obstack_vprintf" << "open" << "opendir" << "parse_printf_format" << "pathconf"
|
||||||
, "perror", "popen" ,"posix_fadvise", "posix_fallocate", "pread"
|
<< "perror" << "popen" << "posix_fadvise" << "posix_fallocate" << "pread"
|
||||||
, "printf", "psignal", "puts", "pwrite", "qsort", "read", "readahead", "readdir", "readdir_r"
|
<< "printf" << "psignal" << "puts" << "pwrite" << "qsort" << "read" << "readahead" << "readdir" << "readdir_r"
|
||||||
, "readlink", "readv"
|
<< "readlink" << "readv"
|
||||||
, "realloc", "regcomp", "remove", "rename", "return", "rewind", "rewinddir", "rindex"
|
<< "realloc" << "regcomp" << "remove" << "rename" << "return" << "rewind" << "rewinddir" << "rindex"
|
||||||
, "rmdir" ,"scandir", "scanf", "seekdir"
|
<< "rmdir" << "scandir" << "scanf" << "seekdir"
|
||||||
, "setbuf", "setbuffer", "sethostname", "setlinebuf", "setlocale" ,"setvbuf", "sizeof" ,"snprintf", "sprintf", "sscanf"
|
<< "setbuf" << "setbuffer" << "sethostname" << "setlinebuf" << "setlocale" << "setvbuf" << "sizeof" << "snprintf" << "sprintf" << "sscanf"
|
||||||
, "stat", "stpcpy", "strcasecmp", "strcat", "strchr", "strcmp", "strcoll"
|
<< "stat" << "stpcpy" << "strcasecmp" << "strcat" << "strchr" << "strcmp" << "strcoll"
|
||||||
, "strcpy", "strcspn", "strdup", "stricmp", "strlen", "strncasecmp", "strncat", "strncmp"
|
<< "strcpy" << "strcspn" << "strdup" << "stricmp" << "strlen" << "strncasecmp" << "strncat" << "strncmp"
|
||||||
, "strncpy", "strpbrk","strrchr", "strspn", "strstr", "strtod", "strtok", "strtol", "strtoul", "strxfrm", "switch"
|
<< "strncpy" << "strpbrk" << "strrchr" << "strspn" << "strstr" << "strtod" << "strtok" << "strtol" << "strtoul" << "strxfrm" << "switch"
|
||||||
, "symlink", "sync_file_range", "system", "telldir", "tempnam", "time", "typeid", "unlink"
|
<< "symlink" << "sync_file_range" << "system" << "telldir" << "tempnam" << "time" << "typeid" << "unlink"
|
||||||
, "utime", "utimes", "vasprintf", "vfprintf", "vfscanf", "vprintf"
|
<< "utime" << "utimes" << "vasprintf" << "vfprintf" << "vfscanf" << "vprintf"
|
||||||
, "vscanf", "vsnprintf", "vsprintf", "vsscanf", "while", "wordexp","write", "writev"
|
<< "vscanf" << "vsnprintf" << "vsprintf" << "vsscanf" << "while" << "wordexp" << "write" << "writev";
|
||||||
};
|
|
||||||
|
|
||||||
//---------------------------------------------------------------------------
|
//---------------------------------------------------------------------------
|
||||||
|
|
||||||
|
@ -529,9 +528,7 @@ bool CheckMemoryLeakInFunction::notvar(const Token *tok, unsigned int varid, boo
|
||||||
|
|
||||||
bool CheckMemoryLeakInFunction::test_white_list(const std::string &funcname, const Settings *settings, bool cpp)
|
bool CheckMemoryLeakInFunction::test_white_list(const std::string &funcname, const Settings *settings, bool cpp)
|
||||||
{
|
{
|
||||||
return (std::binary_search(call_func_white_list,
|
return ((call_func_white_list.find(funcname)!=call_func_white_list.end()) || (settings->library.leakignore.find(funcname) != settings->library.leakignore.end()) || (cpp && funcname == "delete"));
|
||||||
call_func_white_list+sizeof(call_func_white_list) / sizeof(call_func_white_list[0]),
|
|
||||||
funcname) || (settings->library.leakignore.find(funcname) != settings->library.leakignore.end()) || (cpp && funcname == "delete"));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -466,7 +466,7 @@ void CheckOther::invalidPointerCast()
|
||||||
const Variable *var = nullptr;
|
const Variable *var = nullptr;
|
||||||
bool allocation = false;
|
bool allocation = false;
|
||||||
bool ref = false;
|
bool ref = false;
|
||||||
if (Token::Match(nextTok, "new %type%"))
|
if (_tokenizer->isCPP() && Token::Match(nextTok, "new %type%"))
|
||||||
allocation = true;
|
allocation = true;
|
||||||
else if (Token::Match(nextTok, "%var% !!["))
|
else if (Token::Match(nextTok, "%var% !!["))
|
||||||
var = nextTok->variable();
|
var = nextTok->variable();
|
||||||
|
|
|
@ -227,27 +227,20 @@ void CheckStl::mismatchingContainersError(const Token *tok)
|
||||||
}
|
}
|
||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
static const char* const algorithm2_strings[] = { // func(begin1, end1
|
const std::set<std::string> algorithm2 = make_container< std::set<std::string> >() // func(begin1, end1
|
||||||
"adjacent_find", "all_of", "any_of", "binary_search", "copy", "copy_if", "count", "count_if", "equal", "equal_range",
|
<< "adjacent_find" << "all_of" << "any_of" << "binary_search" << "copy" << "copy_if" << "count" << "count_if" << "equal" << "equal_range"
|
||||||
"find", "find_if", "find_if_not", "for_each", "generate", "is_heap", "is_heap_until", "is_partitioned",
|
<< "find" << "find_if" << "find_if_not" << "for_each" << "generate" << "is_heap" << "is_heap_until" << "is_partitioned"
|
||||||
"is_permutation", "is_sorted", "is_sorted_until", "lower_bound", "make_heap", "max_element", "minmax_element",
|
<< "is_permutation" << "is_sorted" << "is_sorted_until" << "lower_bound" << "make_heap" << "max_element" << "minmax_element"
|
||||||
"min_element", "mismatch", "move", "move_backward", "next_permutation", "none_of", "partition", "partition_copy",
|
<< "min_element" << "mismatch" << "move" << "move_backward" << "next_permutation" << "none_of" << "partition" << "partition_copy"
|
||||||
"partition_point", "pop_heap", "prev_permutation", "push_heap", "random_shuffle", "remove", "remove_copy",
|
<< "partition_point" << "pop_heap" << "prev_permutation" << "push_heap" << "random_shuffle" << "remove" << "remove_copy"
|
||||||
"remove_copy_if", "remove_if", "replace", "replace_copy", "replace_copy_if", "replace_if", "reverse", "reverse_copy",
|
<< "remove_copy_if" << "remove_if" << "replace" << "replace_copy" << "replace_copy_if" << "replace_if" << "reverse" << "reverse_copy"
|
||||||
"search_n", "shuffle", "sort", "sort_heap", "stable_partition", "stable_sort", "swap_ranges", "transform", "unique",
|
<< "search_n" << "shuffle" << "sort" << "sort_heap" << "stable_partition" << "stable_sort" << "swap_ranges" << "transform" << "unique"
|
||||||
"unique_copy", "upper_bound"
|
<< "unique_copy" << "upper_bound";
|
||||||
};
|
const std::set<std::string> algorithm22 = make_container< std::set<std::string> >() // func(begin1 << end1 << begin2 << end2
|
||||||
static const char* const algorithm22_strings[] = { // func(begin1, end1, begin2, end2
|
<< "find_end" << "find_first_of" << "includes" << "lexicographical_compare" << "merge" << "partial_sort_copy"
|
||||||
"find_end", "find_first_of", "includes", "lexicographical_compare", "merge", "partial_sort_copy",
|
<< "search" << "set_difference" << "set_intersection" << "set_symmetric_difference" << "set_union";
|
||||||
"search", "set_difference", "set_intersection", "set_symmetric_difference", "set_union"
|
const std::set<std::string> algorithm1x1 = make_container< std::set<std::string> >() // func(begin1 << x << end1
|
||||||
};
|
<< "inplace_merge" << "nth_element" << "partial_sort" << "rotate" << "rotate_copy";
|
||||||
static const char* const algorithm1x1_strings[] = { // func(begin1, x, end1
|
|
||||||
"inplace_merge", "nth_element", "partial_sort", "rotate", "rotate_copy"
|
|
||||||
};
|
|
||||||
|
|
||||||
static const std::set<std::string> algorithm2(algorithm2_strings, &algorithm2_strings[sizeof(algorithm2_strings) / sizeof(*algorithm2_strings)]);
|
|
||||||
static const std::set<std::string> algorithm22(algorithm22_strings, &algorithm22_strings[sizeof(algorithm22_strings) / sizeof(*algorithm22_strings)]);
|
|
||||||
static const std::set<std::string> algorithm1x1(algorithm1x1_strings, &algorithm1x1_strings[sizeof(algorithm1x1_strings) / sizeof(*algorithm1x1_strings)]);
|
|
||||||
|
|
||||||
static const std::string iteratorBeginFuncPattern = "begin|cbegin|rbegin|crbegin";
|
static const std::string iteratorBeginFuncPattern = "begin|cbegin|rbegin|crbegin";
|
||||||
static const std::string iteratorEndFuncPattern = "end|cend|rend|crend";
|
static const std::string iteratorEndFuncPattern = "end|cend|rend|crend";
|
||||||
|
|
|
@ -433,7 +433,7 @@ private:
|
||||||
if (var2->isPointer())
|
if (var2->isPointer())
|
||||||
checks.push_back(new UninitVar(owner, var2, symbolDatabase, library, isC));
|
checks.push_back(new UninitVar(owner, var2, symbolDatabase, library, isC));
|
||||||
else if (var2->typeEndToken()->str() != ">") {
|
else if (var2->typeEndToken()->str() != ">") {
|
||||||
bool stdtype = var2->typeStartToken()->isStandardType(); // TODO: change to isC to handle unknown types better
|
const bool stdtype = var2->typeStartToken()->isStandardType(); // TODO: change to isC to handle unknown types better
|
||||||
if (stdtype && (!var2->isArray() || var2->nameToken()->linkAt(1)->strAt(1) == ";"))
|
if (stdtype && (!var2->isArray() || var2->nameToken()->linkAt(1)->strAt(1) == ";"))
|
||||||
checks.push_back(new UninitVar(owner, var2, symbolDatabase, library, isC));
|
checks.push_back(new UninitVar(owner, var2, symbolDatabase, library, isC));
|
||||||
}
|
}
|
||||||
|
@ -571,7 +571,7 @@ private:
|
||||||
return &tok;
|
return &tok;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (Token::Match(tok.next(), "= malloc|kmalloc") || Token::simpleMatch(tok.next(), "= new char [") ||
|
if (Token::Match(tok.next(), "= malloc|kmalloc") || (!isC && Token::simpleMatch(tok.next(), "= new char [")) ||
|
||||||
(Token::Match(tok.next(), "= %name% (") && library->returnuninitdata.find(tok.strAt(2)) != library->returnuninitdata.end())) {
|
(Token::Match(tok.next(), "= %name% (") && library->returnuninitdata.find(tok.strAt(2)) != library->returnuninitdata.end())) {
|
||||||
alloc_pointer(checks, tok.varId());
|
alloc_pointer(checks, tok.varId());
|
||||||
if (tok.strAt(3) == "(")
|
if (tok.strAt(3) == "(")
|
||||||
|
|
|
@ -22,6 +22,7 @@
|
||||||
#include "tokenlist.h"
|
#include "tokenlist.h"
|
||||||
#include "token.h"
|
#include "token.h"
|
||||||
#include <cstring>
|
#include <cstring>
|
||||||
|
#include <sstream>
|
||||||
|
|
||||||
|
|
||||||
class TestTokenList : public TestFixture {
|
class TestTokenList : public TestFixture {
|
||||||
|
@ -44,6 +45,13 @@ private:
|
||||||
TokenList tokenlist(&settings);
|
TokenList tokenlist(&settings);
|
||||||
tokenlist.addtoken(code, 1, 1, false);
|
tokenlist.addtoken(code, 1, 1, false);
|
||||||
ASSERT_EQUALS("9894494448401390090", tokenlist.front()->str());
|
ASSERT_EQUALS("9894494448401390090", tokenlist.front()->str());
|
||||||
|
// that is supposed to break on 32bit
|
||||||
|
//unsigned long numberUL(0);
|
||||||
|
//std::istringstream(tokenlist.front()->str()) >> numberUL;
|
||||||
|
//ASSERT_EQUALS(9894494448401390090U, numberUL);
|
||||||
|
unsigned long long numberULL(0);
|
||||||
|
std::istringstream(tokenlist.front()->str()) >> numberULL;
|
||||||
|
ASSERT_EQUALS(9894494448401390090U, numberULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
void line1() const {
|
void line1() const {
|
||||||
|
|
Loading…
Reference in New Issue