Fixed #2198 (SymbolDatabase: separate SymbolDatabase from CheckClass)
This commit is contained in:
parent
f7ca4f09ef
commit
894586f4dd
12
Makefile
12
Makefile
|
@ -44,6 +44,7 @@ LIBOBJ = lib/checkautovariables.o \
|
||||||
lib/path.o \
|
lib/path.o \
|
||||||
lib/preprocessor.o \
|
lib/preprocessor.o \
|
||||||
lib/settings.o \
|
lib/settings.o \
|
||||||
|
lib/symboldatabase.o \
|
||||||
lib/timer.o \
|
lib/timer.o \
|
||||||
lib/token.o \
|
lib/token.o \
|
||||||
lib/tokenize.o
|
lib/tokenize.o
|
||||||
|
@ -135,7 +136,7 @@ lib/checkautovariables.o: lib/checkautovariables.cpp lib/checkautovariables.h li
|
||||||
lib/checkbufferoverrun.o: lib/checkbufferoverrun.cpp lib/checkbufferoverrun.h lib/check.h lib/token.h lib/tokenize.h lib/settings.h lib/errorlogger.h lib/mathlib.h lib/executionpath.h
|
lib/checkbufferoverrun.o: lib/checkbufferoverrun.cpp lib/checkbufferoverrun.h lib/check.h lib/token.h lib/tokenize.h lib/settings.h lib/errorlogger.h lib/mathlib.h lib/executionpath.h
|
||||||
$(CXX) $(CXXFLAGS) -Ilib -c -o lib/checkbufferoverrun.o lib/checkbufferoverrun.cpp
|
$(CXX) $(CXXFLAGS) -Ilib -c -o lib/checkbufferoverrun.o lib/checkbufferoverrun.cpp
|
||||||
|
|
||||||
lib/checkclass.o: lib/checkclass.cpp lib/checkclass.h lib/check.h lib/token.h lib/tokenize.h lib/settings.h lib/errorlogger.h
|
lib/checkclass.o: lib/checkclass.cpp lib/checkclass.h lib/check.h lib/token.h lib/tokenize.h lib/settings.h lib/errorlogger.h lib/symboldatabase.h
|
||||||
$(CXX) $(CXXFLAGS) -Ilib -c -o lib/checkclass.o lib/checkclass.cpp
|
$(CXX) $(CXXFLAGS) -Ilib -c -o lib/checkclass.o lib/checkclass.cpp
|
||||||
|
|
||||||
lib/checkexceptionsafety.o: lib/checkexceptionsafety.cpp lib/checkexceptionsafety.h lib/check.h lib/token.h lib/tokenize.h lib/settings.h lib/errorlogger.h
|
lib/checkexceptionsafety.o: lib/checkexceptionsafety.cpp lib/checkexceptionsafety.h lib/check.h lib/token.h lib/tokenize.h lib/settings.h lib/errorlogger.h
|
||||||
|
@ -195,6 +196,9 @@ lib/preprocessor.o: lib/preprocessor.cpp lib/preprocessor.h lib/tokenize.h lib/t
|
||||||
lib/settings.o: lib/settings.cpp lib/settings.h
|
lib/settings.o: lib/settings.cpp lib/settings.h
|
||||||
$(CXX) $(CXXFLAGS) -Ilib -c -o lib/settings.o lib/settings.cpp
|
$(CXX) $(CXXFLAGS) -Ilib -c -o lib/settings.o lib/settings.cpp
|
||||||
|
|
||||||
|
lib/symboldatabase.o: lib/symboldatabase.cpp lib/symboldatabase.h lib/tokenize.h lib/token.h lib/settings.h lib/errorlogger.h lib/check.h
|
||||||
|
$(CXX) $(CXXFLAGS) -Ilib -c -o lib/symboldatabase.o lib/symboldatabase.cpp
|
||||||
|
|
||||||
lib/timer.o: lib/timer.cpp lib/timer.h
|
lib/timer.o: lib/timer.cpp lib/timer.h
|
||||||
$(CXX) $(CXXFLAGS) -Ilib -c -o lib/timer.o lib/timer.cpp
|
$(CXX) $(CXXFLAGS) -Ilib -c -o lib/timer.o lib/timer.cpp
|
||||||
|
|
||||||
|
@ -228,13 +232,13 @@ test/testbufferoverrun.o: test/testbufferoverrun.cpp lib/tokenize.h lib/checkbuf
|
||||||
test/testcharvar.o: test/testcharvar.cpp lib/tokenize.h lib/checkother.h lib/check.h lib/token.h lib/settings.h lib/errorlogger.h test/testsuite.h test/redirect.h
|
test/testcharvar.o: test/testcharvar.cpp lib/tokenize.h lib/checkother.h lib/check.h lib/token.h lib/settings.h lib/errorlogger.h test/testsuite.h test/redirect.h
|
||||||
$(CXX) $(CXXFLAGS) -Ilib -Icli -c -o test/testcharvar.o test/testcharvar.cpp
|
$(CXX) $(CXXFLAGS) -Ilib -Icli -c -o test/testcharvar.o test/testcharvar.cpp
|
||||||
|
|
||||||
test/testclass.o: test/testclass.cpp lib/tokenize.h lib/checkclass.h lib/check.h lib/token.h lib/settings.h lib/errorlogger.h test/testsuite.h test/redirect.h
|
test/testclass.o: test/testclass.cpp lib/tokenize.h lib/checkclass.h lib/check.h lib/token.h lib/settings.h lib/errorlogger.h lib/symboldatabase.h test/testsuite.h test/redirect.h
|
||||||
$(CXX) $(CXXFLAGS) -Ilib -Icli -c -o test/testclass.o test/testclass.cpp
|
$(CXX) $(CXXFLAGS) -Ilib -Icli -c -o test/testclass.o test/testclass.cpp
|
||||||
|
|
||||||
test/testcmdlineparser.o: test/testcmdlineparser.cpp test/testsuite.h lib/errorlogger.h test/redirect.h lib/settings.h
|
test/testcmdlineparser.o: test/testcmdlineparser.cpp test/testsuite.h lib/errorlogger.h test/redirect.h lib/settings.h
|
||||||
$(CXX) $(CXXFLAGS) -Ilib -Icli -c -o test/testcmdlineparser.o test/testcmdlineparser.cpp
|
$(CXX) $(CXXFLAGS) -Ilib -Icli -c -o test/testcmdlineparser.o test/testcmdlineparser.cpp
|
||||||
|
|
||||||
test/testconstructors.o: test/testconstructors.cpp lib/tokenize.h lib/checkclass.h lib/check.h lib/token.h lib/settings.h lib/errorlogger.h test/testsuite.h test/redirect.h
|
test/testconstructors.o: test/testconstructors.cpp lib/tokenize.h lib/checkclass.h lib/check.h lib/token.h lib/settings.h lib/errorlogger.h lib/symboldatabase.h test/testsuite.h test/redirect.h
|
||||||
$(CXX) $(CXXFLAGS) -Ilib -Icli -c -o test/testconstructors.o test/testconstructors.cpp
|
$(CXX) $(CXXFLAGS) -Ilib -Icli -c -o test/testconstructors.o test/testconstructors.cpp
|
||||||
|
|
||||||
test/testcppcheck.o: test/testcppcheck.cpp lib/cppcheck.h lib/settings.h lib/errorlogger.h lib/checkunusedfunctions.h lib/check.h lib/token.h lib/tokenize.h test/testsuite.h test/redirect.h lib/path.h test/tinyxml/tinyxml.h test/tinyxml/tinystr.h
|
test/testcppcheck.o: test/testcppcheck.cpp lib/cppcheck.h lib/settings.h lib/errorlogger.h lib/checkunusedfunctions.h lib/check.h lib/token.h lib/tokenize.h test/testsuite.h test/redirect.h lib/path.h test/tinyxml/tinyxml.h test/tinyxml/tinystr.h
|
||||||
|
@ -306,7 +310,7 @@ test/testuninitvar.o: test/testuninitvar.cpp lib/tokenize.h lib/checkuninitvar.h
|
||||||
test/testunusedfunctions.o: test/testunusedfunctions.cpp lib/tokenize.h test/testsuite.h lib/errorlogger.h test/redirect.h lib/checkunusedfunctions.h lib/check.h lib/token.h lib/settings.h
|
test/testunusedfunctions.o: test/testunusedfunctions.cpp lib/tokenize.h test/testsuite.h lib/errorlogger.h test/redirect.h lib/checkunusedfunctions.h lib/check.h lib/token.h lib/settings.h
|
||||||
$(CXX) $(CXXFLAGS) -Ilib -Icli -c -o test/testunusedfunctions.o test/testunusedfunctions.cpp
|
$(CXX) $(CXXFLAGS) -Ilib -Icli -c -o test/testunusedfunctions.o test/testunusedfunctions.cpp
|
||||||
|
|
||||||
test/testunusedprivfunc.o: test/testunusedprivfunc.cpp lib/tokenize.h lib/checkclass.h lib/check.h lib/token.h lib/settings.h lib/errorlogger.h test/testsuite.h test/redirect.h
|
test/testunusedprivfunc.o: test/testunusedprivfunc.cpp lib/tokenize.h lib/checkclass.h lib/check.h lib/token.h lib/settings.h lib/errorlogger.h lib/symboldatabase.h test/testsuite.h test/redirect.h
|
||||||
$(CXX) $(CXXFLAGS) -Ilib -Icli -c -o test/testunusedprivfunc.o test/testunusedprivfunc.cpp
|
$(CXX) $(CXXFLAGS) -Ilib -Icli -c -o test/testunusedprivfunc.o test/testunusedprivfunc.cpp
|
||||||
|
|
||||||
test/testunusedvar.o: test/testunusedvar.cpp test/testsuite.h lib/errorlogger.h test/redirect.h lib/tokenize.h lib/checkother.h lib/check.h lib/token.h lib/settings.h
|
test/testunusedvar.o: test/testunusedvar.cpp test/testsuite.h lib/errorlogger.h test/redirect.h lib/tokenize.h lib/checkother.h lib/check.h lib/token.h lib/settings.h
|
||||||
|
|
1568
lib/checkclass.cpp
1568
lib/checkclass.cpp
File diff suppressed because it is too large
Load Diff
245
lib/checkclass.h
245
lib/checkclass.h
|
@ -23,6 +23,7 @@
|
||||||
|
|
||||||
#include "check.h"
|
#include "check.h"
|
||||||
#include "settings.h"
|
#include "settings.h"
|
||||||
|
#include "symboldatabase.h"
|
||||||
|
|
||||||
class Token;
|
class Token;
|
||||||
|
|
||||||
|
@ -35,7 +36,7 @@ class CheckClass : public Check
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
/** @brief This constructor is used when registering the CheckClass */
|
/** @brief This constructor is used when registering the CheckClass */
|
||||||
CheckClass() : Check(), hasSymbolDatabase(false)
|
CheckClass() : Check(), symbolDatabase(NULL)
|
||||||
{ }
|
{ }
|
||||||
|
|
||||||
/** @brief This constructor is used when running checks. */
|
/** @brief This constructor is used when running checks. */
|
||||||
|
@ -104,12 +105,6 @@ public:
|
||||||
/** @brief can member function be const? */
|
/** @brief can member function be const? */
|
||||||
void checkConst();
|
void checkConst();
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Access control. This needs to be public, otherwise it
|
|
||||||
* doesn't work to compile with Borland C++
|
|
||||||
*/
|
|
||||||
enum AccessControl { Public, Protected, Private };
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
/**
|
/**
|
||||||
* @brief Create symbol database. For performance reasons, only call
|
* @brief Create symbol database. For performance reasons, only call
|
||||||
|
@ -117,239 +112,7 @@ private:
|
||||||
*/
|
*/
|
||||||
void createSymbolDatabase();
|
void createSymbolDatabase();
|
||||||
|
|
||||||
/**
|
SymbolDatabase *symbolDatabase;
|
||||||
* @brief Prevent creating symbol database more than once.
|
|
||||||
*
|
|
||||||
* Initialize this flag to false in the constructors. If this flag
|
|
||||||
* is true the createSymbolDatabase should just bail out. If it is
|
|
||||||
* false the createSymbolDatabase will set it to true and create
|
|
||||||
* the symbol database.
|
|
||||||
*/
|
|
||||||
bool hasSymbolDatabase;
|
|
||||||
|
|
||||||
/** @brief Information about a member variable. Used when checking for uninitialized variables */
|
|
||||||
class Var
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
Var(const Token *token_, unsigned int index_, AccessControl access_ = Public, bool mutable_ = false, bool static_ = false, bool class_ = false)
|
|
||||||
: token(token_),
|
|
||||||
index(index_),
|
|
||||||
assign(false),
|
|
||||||
init(false),
|
|
||||||
access(access_),
|
|
||||||
isMutable(mutable_),
|
|
||||||
isStatic(static_),
|
|
||||||
isClass(class_)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
/** @brief variable token */
|
|
||||||
const Token *token;
|
|
||||||
|
|
||||||
/** @brief order declared */
|
|
||||||
unsigned int index;
|
|
||||||
|
|
||||||
/** @brief has this variable been assigned? */
|
|
||||||
bool assign;
|
|
||||||
|
|
||||||
/** @brief has this variable been initialized? */
|
|
||||||
bool init;
|
|
||||||
|
|
||||||
/** @brief what section is this variable declared in? */
|
|
||||||
AccessControl access; // public/protected/private
|
|
||||||
|
|
||||||
/** @brief is this variable mutable? */
|
|
||||||
bool isMutable;
|
|
||||||
|
|
||||||
/** @brief is this variable static? */
|
|
||||||
bool isStatic;
|
|
||||||
|
|
||||||
/** @brief is this variable a class (or unknown type)? */
|
|
||||||
bool isClass;
|
|
||||||
};
|
|
||||||
|
|
||||||
class Func
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
enum Type { Constructor, CopyConstructor, OperatorEqual, Destructor, Function };
|
|
||||||
|
|
||||||
Func()
|
|
||||||
: tokenDef(NULL),
|
|
||||||
argDef(NULL),
|
|
||||||
token(NULL),
|
|
||||||
arg(NULL),
|
|
||||||
access(Public),
|
|
||||||
hasBody(false),
|
|
||||||
isInline(false),
|
|
||||||
isConst(false),
|
|
||||||
isVirtual(false),
|
|
||||||
isPure(false),
|
|
||||||
isStatic(false),
|
|
||||||
isFriend(false),
|
|
||||||
isExplicit(false),
|
|
||||||
isOperator(false),
|
|
||||||
retFuncPtr(false),
|
|
||||||
type(Function)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
const Token *tokenDef; // function name token in class definition
|
|
||||||
const Token *argDef; // function argument start '(' in class definition
|
|
||||||
const Token *token; // function name token in implementation
|
|
||||||
const Token *arg; // function argument start '('
|
|
||||||
AccessControl access; // public/protected/private
|
|
||||||
bool hasBody; // has implementation
|
|
||||||
bool isInline; // implementation in class definition
|
|
||||||
bool isConst; // is const
|
|
||||||
bool isVirtual; // is virtual
|
|
||||||
bool isPure; // is pure virtual
|
|
||||||
bool isStatic; // is static
|
|
||||||
bool isFriend; // is friend
|
|
||||||
bool isExplicit; // is explicit
|
|
||||||
bool isOperator; // is operator
|
|
||||||
bool retFuncPtr; // returns function pointer
|
|
||||||
Type type; // constructor, destructor, ...
|
|
||||||
};
|
|
||||||
|
|
||||||
class SpaceInfo;
|
|
||||||
|
|
||||||
struct BaseInfo
|
|
||||||
{
|
|
||||||
AccessControl access; // public/protected/private
|
|
||||||
std::string name;
|
|
||||||
SpaceInfo *spaceInfo;
|
|
||||||
};
|
|
||||||
|
|
||||||
struct FriendInfo
|
|
||||||
{
|
|
||||||
std::string name;
|
|
||||||
SpaceInfo *spaceInfo;
|
|
||||||
};
|
|
||||||
|
|
||||||
class SpaceInfo
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
enum SpaceType { Class, Struct, Union, Namespace, Function };
|
|
||||||
|
|
||||||
SpaceInfo(CheckClass *check_, const Token *classDef_, SpaceInfo *nestedIn_);
|
|
||||||
|
|
||||||
CheckClass *check;
|
|
||||||
SpaceType type;
|
|
||||||
std::string className;
|
|
||||||
const Token *classDef; // class/struct/union/namespace token
|
|
||||||
const Token *classStart; // '{' token
|
|
||||||
const Token *classEnd; // '}' token
|
|
||||||
std::list<Func> functionList;
|
|
||||||
std::list<Var> varlist;
|
|
||||||
std::vector<BaseInfo> derivedFrom;
|
|
||||||
std::list<FriendInfo> friendList;
|
|
||||||
SpaceInfo *nestedIn;
|
|
||||||
std::list<SpaceInfo *> nestedList;
|
|
||||||
AccessControl access;
|
|
||||||
unsigned int numConstructors;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief find if name is in nested list
|
|
||||||
* @param name name of nested space
|
|
||||||
*/
|
|
||||||
SpaceInfo * findInNestedList(const std::string & name)
|
|
||||||
{
|
|
||||||
std::list<SpaceInfo *>::iterator it;
|
|
||||||
|
|
||||||
for (it = nestedList.begin(); it != nestedList.end(); ++it)
|
|
||||||
{
|
|
||||||
if ((*it)->className == name)
|
|
||||||
return (*it);
|
|
||||||
}
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief assign a variable in the varlist
|
|
||||||
* @param varname name of variable to mark assigned
|
|
||||||
*/
|
|
||||||
void assignVar(const std::string &varname);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief initialize a variable in the varlist
|
|
||||||
* @param varname name of variable to mark initialized
|
|
||||||
*/
|
|
||||||
void initVar(const std::string &varname);
|
|
||||||
|
|
||||||
void addVar(const Token *token_, AccessControl access_, bool mutable_, bool static_, bool class_)
|
|
||||||
{
|
|
||||||
varlist.push_back(Var(token_, varlist.size(), access_, mutable_, static_, class_));
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief set all variables in list assigned
|
|
||||||
*/
|
|
||||||
void assignAllVar();
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief set all variables in list not assigned and not initialized
|
|
||||||
*/
|
|
||||||
void clearAllVar();
|
|
||||||
|
|
||||||
/** @brief initialize varlist */
|
|
||||||
void getVarList();
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief parse a scope for a constructor or member function and set the "init" flags in the provided varlist
|
|
||||||
* @param func reference to the function that should be checked
|
|
||||||
* @param callstack the function doesn't look into recursive function calls.
|
|
||||||
*/
|
|
||||||
void initializeVarList(const Func &func, std::list<std::string> &callstack);
|
|
||||||
|
|
||||||
const Func *getDestructor() const
|
|
||||||
{
|
|
||||||
std::list<Func>::const_iterator it;
|
|
||||||
for (it = functionList.begin(); it != functionList.end(); ++it)
|
|
||||||
{
|
|
||||||
if (it->type == Func::Destructor)
|
|
||||||
return &*it;
|
|
||||||
}
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief get the number of nested spaces that are not functions
|
|
||||||
*
|
|
||||||
* This returns the number of user defined types (class, struct, union)
|
|
||||||
* that are defined in this user defined type or namespace.
|
|
||||||
*/
|
|
||||||
unsigned int getNestedNonFunctions() const
|
|
||||||
{
|
|
||||||
unsigned int nested = 0;
|
|
||||||
std::list<SpaceInfo *>::const_iterator ni;
|
|
||||||
for (ni = nestedList.begin(); ni != nestedList.end(); ++ni)
|
|
||||||
{
|
|
||||||
if ((*ni)->type != SpaceInfo::Function)
|
|
||||||
nested++;
|
|
||||||
}
|
|
||||||
return nested;
|
|
||||||
}
|
|
||||||
|
|
||||||
bool isBaseClassFunc(const Token *tok);
|
|
||||||
};
|
|
||||||
|
|
||||||
void addFunction(SpaceInfo **info, const Token **tok, const Token *argStart);
|
|
||||||
void addNewFunction(SpaceInfo **info, const Token **tok);
|
|
||||||
void addIfFunction(SpaceInfo **info, const Token **tok);
|
|
||||||
|
|
||||||
/** @brief Information about all namespaces/classes/structrues */
|
|
||||||
std::list<SpaceInfo *> spaceInfoList;
|
|
||||||
|
|
||||||
bool argsMatch(const Token *first, const Token *second, const std::string &path, unsigned int depth) const;
|
|
||||||
|
|
||||||
bool isMemberVar(const SpaceInfo *info, const Token *tok);
|
|
||||||
bool isConstMemberFunc(const SpaceInfo *info, const Token *tok);
|
|
||||||
bool checkConstFunc(const SpaceInfo *info, const Token *tok);
|
|
||||||
|
|
||||||
const Token *initBaseInfo(SpaceInfo *info, const Token *tok);
|
|
||||||
|
|
||||||
/** @brief check if this function is virtual in the base classes */
|
|
||||||
bool isVirtual(const SpaceInfo *info, const Token *functionToken) const;
|
|
||||||
|
|
||||||
// Reporting errors..
|
// Reporting errors..
|
||||||
void noConstructorError(const Token *tok, const std::string &classname, bool isStruct);
|
void noConstructorError(const Token *tok, const std::string &classname, bool isStruct);
|
||||||
|
@ -402,7 +165,7 @@ private:
|
||||||
}
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
void checkReturnPtrThis(const SpaceInfo *info, const Func *func, const Token *tok, const Token *last);
|
void checkReturnPtrThis(const SymbolDatabase::SpaceInfo *info, const SymbolDatabase::Func *func, const Token *tok, const Token *last);
|
||||||
};
|
};
|
||||||
/// @}
|
/// @}
|
||||||
//---------------------------------------------------------------------------
|
//---------------------------------------------------------------------------
|
||||||
|
|
|
@ -23,6 +23,7 @@ HEADERS += $$PWD/check.h \
|
||||||
$$PWD/path.h \
|
$$PWD/path.h \
|
||||||
$$PWD/preprocessor.h \
|
$$PWD/preprocessor.h \
|
||||||
$$PWD/settings.h \
|
$$PWD/settings.h \
|
||||||
|
$$PWD/symboldatabase.h \
|
||||||
$$PWD/timer.h \
|
$$PWD/timer.h \
|
||||||
$$PWD/token.h \
|
$$PWD/token.h \
|
||||||
$$PWD/tokenize.h
|
$$PWD/tokenize.h
|
||||||
|
@ -49,6 +50,7 @@ SOURCES += $$PWD/checkautovariables.cpp \
|
||||||
$$PWD/path.cpp \
|
$$PWD/path.cpp \
|
||||||
$$PWD/preprocessor.cpp \
|
$$PWD/preprocessor.cpp \
|
||||||
$$PWD/settings.cpp \
|
$$PWD/settings.cpp \
|
||||||
|
$$PWD/symboldatabase.cpp \
|
||||||
$$PWD/timer.cpp \
|
$$PWD/timer.cpp \
|
||||||
$$PWD/token.cpp \
|
$$PWD/token.cpp \
|
||||||
$$PWD/tokenize.cpp
|
$$PWD/tokenize.cpp
|
||||||
|
|
Loading…
Reference in New Issue