cppcheck
| 释放窗口 | oss-fuzz | 封面扫描构建状态 | 包括您使用的内容 | 执照 |
|---|---|---|---|---|
关于名称
该程序的原始名称是“ C ++检查”,但后来更改为“ cppcheck ”。
尽管有名字,但cppcheck还是为C ++设计的。
手动的
手册可在线提供。
捐赠CPU
cppcheck是一个爱好项目,资源有限。您可以通过捐赠CPU(1个核心或任意数量)来帮助我们。很简单:
- 下载(和提取) cppcheck源代码。
- 跑步: cppcheck/
virtualenv .env
.env/bin/pip install -r tools/donate–cpu-requirements.txt
.env/bin/python tools/donate-cpu.py\”>cd cppcheck / virtualenv .env .env/bin/pip install -r tools/donate-cpu-requirements.txt .env/bin/python tools/donate-cpu.py
该脚本将分析Debian源代码,并将结果上传到cppcheck服务器。我们需要这些结果来改善cppcheck和检测回归。
您可以随时随地使用CTRL C停止脚本。
编译
cppcheck需要一个具有(部分)C ++ 11支持的C ++编译器。最低要求的版本是GCC 5.1 / Clang 3.5 / Visual Studio 2015。
要构建GUI应用程序,您需要使用CMAKE构建系统。
构建命令行工具时,PCRE是可选的。如果您使用规则构建,则使用它。
有多种汇编选择:
- CMAKE-跨平台构建工具
- Windows:Visual Studio
- Windows:QT Creator + Mingw
- GNU制作
- GCC(G ++)
- clang(clang ++)
所需的最低Python版本为3.6。
cmake
最低要求的版本是Cmake 3.13。
例如,用cmake编译cppcheck :
mkdir build cd build cmake .. cmake --build .
如果要编译GUI,则可以使用标志。 -dbuild_gui = on
为了规则支持(需要PCRE),请使用标志。 -dhave_rules = on
对于释放构建,建议您使用:-duse_matchcompiler = on
用于构建测试,请使用标志。 -dbuild_tests = on
使用CMAKE您可以为Visual Studio,Xcode等生成项目文件。
建立特定的配置
对于单个配置生成器(例如“ Unix Makefiles”),您可以使用:
mkdir build_RelWithDebInfo cd build_RelWithDebInfo cmake -DCMAKE_BUILD_TYPE=RelWithDebInfo .. cmake --build . --config RelWithDebInfo
对于多种配置发生器(例如“ Visual Studio 17 2022”),使用:
mkdir build cd build cmake .. cmake --build . --config RelWithDebInfo
视觉工作室
使用cppcheck .sln文件。该文件是为Visual Studio 2019配置的,但是平台工具集可以轻松地更改为较旧版本或更新版本。该解决方案包含X86和X64的平台目标。
要使用规则进行编译,请选择“ Release-Pcre”或“ Debug-Pcre”配置。当时预计将在 /外部使用pcre.lib(用于X64构建的pcre64.lib)和pcre.h。可以使用VCPKG获得当前版本的用于Visual Studio的PCRE。
Visual Studio(来自命令行)
如果您不希望使用Visual Studio IDE,则可以从命令行中cppcheck以下命令。
msbuild cppcheck .sln
VS代码(在Windows上)
安装MSYS2以获取具有G ++和GDB(https://www.m**sys*2.org/)的GNU工具链。在.vScode文件夹中创建一个settings.json文件,其中包含以下内容(必要时调整路径):
{
\"terminal.integrated.shell.windows\": \"C:\\\\msys64\\\\usr\\\\bin\\\\bash.exe\",
\"terminal.integrated.shellArgs.windows\": [
\"--login\",
],
\"terminal.integrated.env.windows\": {
\"CHERE_INVOKING\": \"1\",
\"MSYSTEM\": \"MINGW64\",
}
}
在终端中运行“ make”以构建cppcheck 。
要调试,请在.vscode文件夹中使用以下内容创建一个启动.json文件,该文件涵盖了用于调试cppcheck和misra.py的配置:
cppcheck\”,
\”type\”: \”cppdbg\”,
\”request\”: \”launch\”,
\”program\”: \”${workspaceFolder}/ cppcheck .exe\”,
\”args\”: [
\”–dump\”,
\”${workspaceFolder}/addons/test/misra/misra-test.c\”
],
\”stopAtEntry\”: false,
\”cwd\”: \”${workspaceFolder}\”,
\”environment\”: [],
\”externalConsole\”: true,
\”MIMode\”: \”gdb\”,
\”miDebuggerPath\”: \”C:/msys64/mingw64/bin/gdb.exe\”,
\”setupCommands\”: [
{
\”description\”: \”Enable pretty-printing for gdb\”,
\”text\”: \”-enable-pretty-printing\”,
\”ignoreFailures\”: true
}
]
},
{
\”name\”: \”misra.py\”,
\”type\”: \”python\”,
\”request\”: \”launch\”,
\”program\”: \”${workspaceFolder}/addons/misra.py\”,
\”console\”: \”integratedTerminal\”,
\”args\”: [
\”${workspaceFolder}/addons/test/misra/misra-test.c.dump\”
]
}
]
}\”>
{
// Use IntelliSense to learn about possible attributes.
// Hover to view descriptions of existing attributes.
// For more information, visit: https://go.micr**oso*ft.com/fwlink/?linkid=830387
\"version\": \"0.2.0\",
\"configurations\": [
{
\"name\": \" cppcheck \",
\"type\": \"cppdbg\",
\"request\": \"launch\",
\"program\": \"${workspaceFolder}/ cppcheck .exe\",
\"args\": [
\"--dump\",
\"${workspaceFolder}/addons/test/misra/misra-test.c\"
],
\"stopAtEntry\": false,
\"cwd\": \"${workspaceFolder}\",
\"environment\": [],
\"externalConsole\": true,
\"MIMode\": \"gdb\",
\"miDebuggerPath\": \"C:/msys64/mingw64/bin/gdb.exe\",
\"setupCommands\": [
{
\"description\": \"Enable pretty-printing for gdb\",
\"text\": \"-enable-pretty-printing\",
\"ignoreFailures\": true
}
]
},
{
\"name\": \"misra.py\",
\"type\": \"python\",
\"request\": \"launch\",
\"program\": \"${workspaceFolder}/addons/misra.py\",
\"console\": \"integratedTerminal\",
\"args\": [
\"${workspaceFolder}/addons/test/misra/misra-test.c.dump\"
]
}
]
}
QT创建者 + mingw
需要PCRE DLL来构建CLI。它可以在此处下载:http://software-download.name/pcre-library-windows/
GNU制作
简单,不优化的构建(无依赖性):
make
建议的发布构建是:
make MATCHCOMPILER=yes FILESDIR=/usr/share/ cppcheck HAVE_RULES=yes CXXFLAGS= \" -O2 -DNDEBUG -Wall -Wno-sign-compare -Wno-unused-function \"
标志:
-
MATCHCOMPILER=yesPython用于优化cppcheck 。令牌::匹配模式在编译时转换为C ++代码。 -
FILESDIR=/usr/share/ cppcheck指定安装cppcheck文件的文件夹(addons,cfg,platform) -
HAVE_RULES=yes启用规则(使用此规则,需要PCRE) -
CXXFLAGS=\"-O2 -DNDEBUG -Wall -Wno-sign-compare -Wno-unused-function\"启用大多数编译器优化,禁用cppcheck内部调试代码并启用基本的编译器警告。
G ++(专家)
如果您只想在没有依赖关系的情况下构建cppcheck ,则可以使用此命令:
g++ -o cppcheck -std=c++11 -Iexternals -Iexternals/simplecpp -Iexternals/tinyxml2 -Iexternals/picojson -Ilib cli/ * .cpp lib/ * .cpp externals/simplecpp/simplecpp.cpp externals/tinyxml2/ * .cpp
如果要使用--rule和--rule-file ,则需要依赖关系:
g++ -o cppcheck -std=c++11 -lpcre -DHAVE_RULES -Ilib -Iexternals -Iexternals/simplecpp -Iexternals/tinyxml2 cli/ * .cpp lib/ * .cpp externals/simplecpp/simplecpp.cpp externals/tinyxml2/ * .cpp
明格
mingw32-make
如果您遇到了MATCHCOMPILER=yes以下错误,则需要通过PYTHON_INTERPRETER指定Python解释器。
process_begin: CreateProcess(NULL, which python3, ...) failed.
makefile:24: pipe: No error
process_begin: CreateProcess(NULL, which python, ...) failed.
makefile:27: pipe: No error
makefile:30: *** Did not find a Python interpreter. Stop.
其他编译器/IDE
- 创建一个空的项目文件 / makefile。
- 将所有CPP文件在cppcheck CLI和LIB文件夹中添加到项目文件 / makefile中。
- 将所有CPP文件添加到外部文件夹中的所有CPP文件中。
- 编译。
Cross汇编Win32(CLI)在Linux中的cppcheck
cppcheck .exe\”>
sudo apt-get install mingw32 make CXX=i586-mingw32msvc-g++ LDFLAGS= \" -lshlwapi \" RDYNAMIC= \" \" mv cppcheck cppcheck .exe
软件包
除了在您选择的平台上建立自己,还有几种获取预制包装的方法。
cppcheck团队维护的官方套餐:
- (Windows)可以通过官方的cppcheck SourceForge页面提供官方Windows安装程序:https://cppcheck.sourceforge.io。
- (Windows)当前开发版本的官方构建可通过Release-Windows Workflow获得。它们是
main分支机构的每晚建造的,也是为发布分支的每个承诺。由于这些是开发版本,请不要在生产环境中使用它们!- 便携式软件包(即不需要安装)可作为
portable工件。有关详细信息,这仍然是一个工作 – 请参阅https://trac.cppcheck.net/ticket/10771。 - 可以通过
installer工件获得安装程序。
- 便携式软件包(即不需要安装)可作为
- (多平台)可通过https://www.cpp*c*he*ck.com购买,具有由cppcheck原始作者提供的其他功能的高级版本。
cppcheck团队没有维护的非官方包,而是他们各自的包装者:
- (Windows/utatest)可通过https://portab**le*apps.com/apps/development/cppcheck-portable获得便携式软件包。
- (Windows/uteDated)可以通过https://community.*c*ho*calyy.org/packages/cppcheck获得一个软件包。
- (Windows/utatest)可以通过https://winge*t.*ru*n/pkg/cppcheck/ cppcheck获得一个软件包。
- (Windows/utatest)可以通过https://osdn*.net**/projects/sfnet_cppcheck获得一个软件包。
- (Windows)可以通过https://**sc*oop.sh/#/apps?q=cppcheck获得一个软件包。
- (Linux/Unix)许多主要发行版通过其集成的软件包经理(
yum,apt,pacman等)提供cppcheck软件包。请参阅https://*pkgs.o*r*g/search/?q=cppcheck或https://repology.org/project/project/cppcheck以获取概述。 - (Linux/Unix)除非您使用“滚动”发行版,否则它们可能不会携带最新版本。有几个外部(主要是不支持的)存储库,例如AUR(Archlinux),PPA(Ubuntu),Epel(Centos/fedora)等,它们可能提供最新的软件包。
- (linux/unix/uteDated)典型的快照软件包(https://*snap*cra*ft.io/cppcheck/ https://s*na*pc*raft.io/cppcheckgui)都不是且包含非常旧的(开发)版本。请不要使用它们!有关更多详细信息,请参见https://trac.cppcheck.net/ticket/11641。
- (MacOS)可以通过Homebrew(
brew)获得一个包装。请参阅https://formulae.br***ew.sh/formula/cppcheck。 - (MacOS)可以通过https://ports.*macport**s.org/port/cppcheck获得一个软件包
- (多平台)可以通过https://anaconda.*o**rg/conda-forge/cppcheck获得软件包。
- 也可以从各种下载门户(主要是Windows安装程序 – 有时重新包装)中获得包装。
注意:这是纯粹的信息列表,没有特定顺序列出。
注意:请始终尝试从操作系统/发行版的主要官方来源获取包裹,并确保您获得了最新发布的版本。
注意:某些问题可能与这些软件包或包装本身中构建的其他补丁有关。在这种情况下,可能需要将问题报告给相应的项目。
网页
https://cppcheck.s*ou*rce*forge.io/
