Skip to content


Subversion checkout URL

You can clone with
Download ZIP
static analysis of C/C++ code
C++ C Makefile Python CMake HTML Other
Failed to load latest commit information.
Cppcheck.xcodeproj Synchronize source file list and enable C++11 build in XCode project.
addons remove messages for reading struct padding data. in the EXP-…
cfg std.cfg: fixed configuration for snprintf. destination string can be …
cli Fix possible segmentation fault in un*x signal handler. Use SIGUSR1 f…
cmake Update the cmake version to the current version
democlient astyle formatting
externals/tinyxml Updated TinyXML
gui Update Spanish translation
htmlreport PEP8 fixes.
lib astutils: remove unused functions isSignedChar and isChar.
man Added description of -I to manual, improved formatting.
rules Rules: Make it possible to write rules that check #define macros
samples Tokenizer::syntaxError: put the character that we have an invalid num…
test CheckIO: Handle AST pointer type better
tools dmake: don't compile clang build with -D_GLIBCXX_DEBUG since it break…
triage PEP8 fixes.
win_installer Set version to 1.70.99/1.71 dev
.gitignore Add CMake files
.mailmap Revert "Revert "Add a .mailmap file.""
.travis.yml Revert "Travis: try to fix build problem by installing xml library"
.travis_suppressions Remove a suppression for travis job since the FP has disappeared (see…
CMakeLists.txt Add CMake files
COPYING Licensing: Using the GPL 3 license
Makefile dmake: don't compile clang build with -D_GLIBCXX_DEBUG since it break…
appveyor.yml appveyor: disable 64-bit builds for now since there are link problem …
build-pcre.txt Update PCRE instructions.
build.bat batch files: switch to the batch file directory before doing anything…
console_common.pri pro and pri files: remove unneeded empty lines, use spaces for consis…
cppcheck.cbp Removed ExecutionPath
cppcheck.cppcheck Fixed: some gui/temp headers reported missing includes from gui/ folder.
cppcheck.sln Updated WiX installer and VS solution to VS12 and Qt5
createrelease createrelease: updates
doxyfile doxyfile: disable dot support.
generate_coverage_report generate_coverage_report: Execute library tests when generating the c… Improved layout of
readme.txt Refactorized readme files.
readme_gui.txt Refactorized readme files.
runastyle test/cfg: Improved testing of functions from standard namespace. Adde…
runastyle.bat updated runastyle scripts webreport: try to fix generation of cppcheckdata doxygen output


Linux Build Status Windows Build Status Coverity Scan Build Status
Linux Build Status Windows Build Status Coverity Scan Build Status


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


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++.


A manual is available online.


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
  • cmake - cross platform build tool
  • Windows: Visual Studio (VS 2010 and above)
  • Windows: Qt Creator + mingw
  • gnu make
  • g++ 4.6 (or later)
  • clang++


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

cd gui

Visual Studio

Use the cppcheck.sln file. The file is configured for Visual Studio 2013, but the platform toolset can be changed easily to older or newer versions. The solution contains platform targets for both x86 and x64.

To compile with rules, select "Release-PCRE" or "Debug-PCRE" configuration. pcre.lib (pcre64.lib for x64 builds) and pcre.h are expected to be in /extlibs then.

Qt Creator + MinGW

The PCRE dll is needed to build the CLI. It can be downloaded here:

GNU make

Simple build (no dependencies):


The recommended release build is:

make SRCDIR=build CFGDIR=cfg HAVE_RULES=yes


  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


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


Something went wrong with that request. Please try again.