/* * cppcheck - c/c++ syntax checking * Copyright (C) 2007-2008 Daniel Marjamäki, Reijo Tomperi, Nicolas Le Cam * * 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 #include #include #include #include #include "settings.h" #include "errorlogger.h" #include "checkfunctionusage.h" /** * This is the base class which will use other classes to do * static code analysis for C and C++ code to find possible * errors or places that could be improved. * Usage: See check() for more info. */ class CppCheck : public ErrorLogger { public: /** * Constructor. */ CppCheck( ErrorLogger &errorLogger ); /** * Destructor. */ virtual ~CppCheck(); /** * This starts the actual checking. Note that you must call * parseFromArgs() or settings() and addFile() before calling this. */ void check(); /** * Adjust the settings before doing the check. E.g. show only * actual bugs or also coding style issues. * * @param settings New settings which will overwrite the old. */ void settings( const Settings &settings ); /** * Add new file to be checked. * * @param path Relative or absolute path to the file to be checked, * e.g. "cppcheck.cpp". Note that only source files (.c, .cc or .cpp) * should be added to the list. Include filese are gathered automatically. */ void addFile( const std::string &path ); /** * Add new unreal file to be checked. * * @param path File name (used for error reporting). * @param content If the file would be a real file, this should be * the content of the file. */ void addFile( const std::string &path, const std::string &content ); /** * Parse command line args and get settings and file lists * from there. * * @param argc argc from main() * @param argv argv from main() * @return Empty string if parameters were accepted, or * string containing "help" text if no files were found to be * checked. */ std::string parseFromArgs( int argc, const char* const argv[] ); private: void checkFile(const std::string &code, const char FileName[]); /** * Errors and warnings are directed here. * * @param errmsg Errors messages are normally in format * "[filepath:line number] Message", e.g. * "[main.cpp:4] Uninitialized member variable" */ virtual void reportErr( const std::string &errmsg); /** * Information about progress is directed here. * * @param outmsg, E.g. "Checking main.cpp..." */ virtual void reportOut( const std::string &outmsg); std::list _errorList; std::ostringstream _errout; Settings _settings; std::vector _filenames; /** Key is file name, and value is the content of the file */ std::map _fileContents; CheckFunctionUsage _checkFunctionUsage; ErrorLogger *_errorLogger; /** Current configuration */ std::string cfg; }; #endif // CPPCHECK_H