/* * Cppcheck - A tool for static C/C++ code analysis * Copyright (C) 2007-2009 Daniel Marjamäki and Cppcheck team. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see _checkCodingStyle) { checkClass.constructors(); checkClass.operatorEq(); checkClass.privateFunctions(); if (settings->_showAll) checkClass.thisSubtraction(); } checkClass.virtualDestructor(); } // Check that all class constructors are ok. void constructors(); // Check that all private functions are called. void privateFunctions(); // Check that the memsets are valid. // The 'memset' function can do dangerous things if used wrong. // Important: The checking doesn't work on simplified tokens list. void noMemset(); // 'operator=' should return something.. void operatorEq(); // Warning upon "void operator=(.." // The destructor in a base class should be virtual void virtualDestructor(); void thisSubtraction(); private: class Var { public: Var(const char *name = 0, bool init = false, Var *next = 0) { this->name = name; this->init = init; this->next = next; } const char *name; bool init; Var *next; }; void initializeVarList(const Token *tok1, const Token *ftok, Var *varlist, const char classname[], std::list &callstack); void initVar(Var *varlist, const char varname[]); Var *getVarList(const Token *tok1, bool withClasses); // Check constructors for a specified class void checkConstructors(const Token *tok1, const char funcname[]); // Reporting errors.. void noConstructorError(const Token *tok, const std::string &classname); void uninitVarError(const Token *tok, const std::string &classname, const std::string &varname); void operatorEqVarError(const Token *tok, const std::string &classname, const std::string &varname); void unusedPrivateFunctionError(const Token *tok, const std::string &classname, const std::string &funcname); void memsetClassError(const Token *tok, const std::string &memfunc); void memsetStructError(const Token *tok, const std::string &memfunc, const std::string &classname); void operatorEqReturnError(const Token *tok); void virtualDestructorError(const Token *tok, const std::string &Base, const std::string &Derived); void thisSubtractionError(const Token *tok); void getErrorMessages() { noConstructorError(0, "classname"); uninitVarError(0, "classname", "varname"); operatorEqVarError(0, "classname", ""); unusedPrivateFunctionError(0, "classname", "funcname"); memsetClassError(0, "memfunc"); memsetStructError(0, "memfunc", "classname"); operatorEqReturnError(0); virtualDestructorError(0, "Base", "Derived"); thisSubtractionError(0); } std::string name() const { return "Class"; } std::string classInfo() const { return "Check the code for each class.\n" " * Missing constructors\n" " * Are all variables initialized by the constructors?\n" " * [[CheckMemset|Warn if memset, memcpy etc are used on a class]]\n" " * If it's a base class, check that the destructor is virtual\n" " * The operator= should return a constant reference to itself\n" " * Are there unused private functions\n"; } }; /// @} //--------------------------------------------------------------------------- #endif