static analysis of C/C++ code
Go to file
amai2012 e8ac4d8e87 #6847 segmentation fault (invalid code) in Token::multiCompare. Fix and simple refactoring in Tokenizer 2015-07-21 13:40:50 +02:00
Cppcheck.xcodeproj Synchronize source file list and enable C++11 build in XCode project. 2015-03-14 14:30:29 +01:00
addons cppcheckdata.py: Added comments 2015-06-21 13:26:32 +02:00
cfg Fix some invalid attributes in library 2015-07-15 18:41:41 +02:00
cli Try to address some Coverity issues. Add TODO testcase for #5783. Introduce TODO_ASSERT macro. 2015-07-19 15:03:35 +02:00
cmake Fixed typos. No functional changes. [ci-skip] 2015-03-30 16:41:53 +02:00
democlient astyle formatting 2014-11-20 14:20:09 +01:00
externals/tinyxml Add CMake files 2015-02-13 19:00:14 +01:00
gui GUI: show statistics after check is done 2015-07-14 18:48:51 +02:00
htmlreport PEP8 fixes. 2015-04-20 21:11:45 +03:00
lib #6847 segmentation fault (invalid code) in Token::multiCompare. Fix and simple refactoring in Tokenizer 2015-07-21 13:40:50 +02:00
man manual: rewrote the chapter about cppcheck extensions/addons 2015-06-21 15:18:24 +02:00
rules
samples std.cfg: snprintf(NULL,0,) is legal. Fix some testcases in test/cfg as well 2015-02-22 14:25:25 +01:00
test #6847 segmentation fault (invalid code) in Token::multiCompare. Fix and simple refactoring in Tokenizer 2015-07-21 13:40:50 +02:00
tools disable -Woverloaded-virtual warnings to avoid a few FPs 2015-06-30 20:38:15 +02:00
triage PEP8 fixes. 2015-04-20 21:11:45 +03:00
win_installer Set version to 1.69.99/1.70 dev 2015-05-03 08:15:13 +02:00
.gitignore Add CMake files 2015-02-13 19:00:14 +01:00
.mailmap
.travis.yml travis: use TEST_MATHLIB_VALUE define to test MathLib::value class 2015-07-16 11:14:58 +02:00
.travis_suppressions Remove a suppression for travis job since the FP has disappeared (see #6099 False positive: variable scope, macro with scope) 2015-04-19 10:53:35 +02:00
AUTHORS Updated AUTHORS 2015-05-01 18:46:52 +02:00
CMakeLists.txt Add CMake files 2015-02-13 19:00:14 +01:00
COPYING
Makefile disable -Woverloaded-virtual warnings to avoid a few FPs 2015-06-30 20:38:15 +02:00
appveyor.yml appveyor: disable 64-bit builds for now since there are link problem (LINK : fatal error LNK1104: cannot open file 'kernel32.lib') 2015-07-16 12:23:12 +02:00
build-pcre.txt
build.bat
console_common.pri
cppcheck.cbp Change "obsolete" in all filenames into "obsolescent", and also update all references to such files. 2014-09-23 16:18:04 +02:00
cppcheck.cppcheck
cppcheck.sln Updated WiX installer and VS solution to VS12 and Qt5 2014-08-02 11:52:37 +02:00
createrelease createrelease: updates 2015-01-03 17:31:52 +01:00
doxyfile
generate_coverage_report
readme.md Update readme.md badges. 2015-04-20 21:11:45 +03:00
readme.txt readme: To compile Cppcheck, partial C++11 support is needed. 2014-03-05 06:15:44 +01:00
readme_64-bit_Windows.txt Removed VS9 solution 2014-01-04 10:55:27 +01:00
readme_gui.txt Small ReadMe updates 2014-01-04 12:38:23 +01:00
runastyle runastyle: Output detected version on mismatch 2014-12-18 16:02:26 +01:00
runastyle.bat
webreport.sh

readme.md

Cppcheck Linux Build Status Windows Build status Coverity Scan Build Status

Donations

If you find Cppcheck useful for you, feel free to make a donation.

Donate

About the name

The original name of this program was "C++check", but it was later changed to "Cppcheck".

Despite the name, Cppcheck is designed for both C and C++.

Manual

A manual is available online.

Compiling

Any C++11 compiler should work. For compilers with partial C++11 support it may work. If your compiler has the C++11 features that are available in Visual Studio 2010 then it will work. If nullptr is not supported by your compiler then this can be emulated using the header lib/cxx11emu.h.

To build the GUI, you need Qt.

When building the command line tool, PCRE is optional. It is used if you build with rules.

There are multiple compilation choices:

  • qmake - cross platform build tool
  • Windows: Visual Studio (VS 2010 and above) or Qt Creator or MinGW
  • gnu make
  • g++ 4.4 (and above)
  • clang++ 2.9 (and above)

qmake

You can use the gui/gui.pro file to build the GUI.

cd gui
qmake
make

Visual Studio

Use the cppcheck.sln file. The rules are normally enabled.

To compile with rules (PCRE dependency):

  • the PCRE dll is needed. It can be downloaded from here.

To compile without rules (no dependencies):

  • remove the preprocessor define HAVE_RULES from the project
  • remove the pcre.lib from the project

Qt Creator + MinGW

The PCRE dll is needed to build the CLI. It can be downloaded here: http://software-download.name/pcre-library-windows/

GNU make

Simple build (no dependencies):

make

The recommended release build is:

make SRCDIR=build CFGDIR=cfg HAVE_RULES=yes

Flags:

  1. SRCDIR=build
    Python is used to optimise cppcheck

  2. CFGDIR=cfg
    Specify folder where .cfg files are found

  3. HAVE_RULES=yes
    Enable rules (PCRE is required if this is used)

g++ (for experts)

If you just want to build Cppcheck without dependencies then you can use this command:

g++ -o cppcheck -std=c++0x -include lib/cxx11emu.h -Iexternals/tinyxml -Ilib cli/*.cpp lib/*.cpp externals/tinyxml/*.cpp

If you want to use --rule and --rule-file then dependencies are needed:

g++ -o cppcheck -std=c++0x -include lib/cxx11emu.h -lpcre -DHAVE_RULES -Ilib -Iexternals/tinyxml cli/*.cpp lib/*.cpp externals/tinyxml/*.cpp

MinGW

make LDFLAGS=-lshlwapi

Other Compiler/IDE

  1. Create a empty project file / makefile.
  2. Add all cpp files in the cppcheck cli and lib folders to the project file / makefile.
  3. Compile.

Cross compiling Win32 (CLI) version of Cppcheck in Linux

sudo apt-get install mingw32
make CXX=i586-mingw32msvc-g++ LDFLAGS="-lshlwapi" RDYNAMIC=""
mv cppcheck cppcheck.exe

Webpage

http://cppcheck.sourceforge.net/