代码review辅助工具
SourceMonitor:代码质量检测工具
SMSetupV3516.exe
主要分析方面是:行数、语句数、分支数、复杂度、函数深度及个数等
使用效果如下图:
SourceInsight_Scan:代码静态分析插件
SourceInsight_Scan_Setup.exe
需要结合SourceInsight3.5使用
主要分析方面是:空指针、越界、内存泄漏、潜在逻辑错误、未定义或初始化变量等
使用效果如下图:
simian:代码重复度检查工具
simian-2.5.10.rar
使用前需要将其添加到环境变量中
具体重复细节为:重复文件、重复行数、重复位置
注:免费版本的一次只能检查一个文件 使用方法见cpp-check-lint(推荐)
代码静态分析工具,在vscode中安装此插件
package.json:将.vscode\extensions\qiumingge.cpp-check-lint-1.4.7的此文件替换,原文件没有C99
platform.xml:存放与单片机环境匹配的平台配置
settings.json:存放cpp-check-lint的配置文件
注:
- 配置完成后,Ctrl+S后自动进行静态分析此文件
- Shift+Alt+P后运行cppcheck-dir对路径下所有文件进行静态分析
- 全局静态分析后,部分文件不进行分析,在settings.json中可查看
- 需要在settings.json中配置
- log级别
- 语言
- 平台
- std_c
- ···
- clang-format(推荐)
代码格式化软件,在vscode中安装C/C++(Microsoft)插件
.clang-format:文件格式规则
settings.json:存放clang-format的配置文件
注:
- 配置完成后使用Shift+Alt+F快速对文件进行格式化
- settings.json和cpp-check-lint中提到的settings.json是一个文件
- 格式中tab对应的空格数要和doxygen中的设置一致
- 需要在settings.json中配置:
- Clang_format_style:使用.clang-format
- Clang_format_path:使用.clang-format的位置
- .clang-format:格式化配置文件链接
---
# 语言: None, Cpp, Java, JavaScript, ObjC, Proto, TableGen, TextProto
Language: Cpp
# BasedOnStyle: LLVM
# 访问说明符(public、private等)的偏移
AccessModifierOffset: -4
# 开括号(开圆括号、开尖括号、开方括号)后的对齐: Align, DontAlign, AlwaysBreak(总是在开括号后换行)
AlignAfterOpenBracket: Align
# 连续赋值时,对齐所有等号
AlignConsecutiveAssignments: true
# 连续声明时,对齐所有声明的变量名
AlignConsecutiveDeclarations: true
# 左对齐逃脱换行(使用反斜杠换行)的反斜杠
AlignEscapedNewlinesLeft: true
# 水平对齐二元和三元表达式的操作数
AlignOperands: true
# 对齐连续的尾随的注释
AlignTrailingComments: true
# 允许函数声明的所有参数在放在下一行
AllowAllParametersOfDeclarationOnNextLine: true
# 允许短的块放在同一行
AllowShortBlocksOnASingleLine: false
# 允许短的case标签放在同一行
AllowShortCaseLabelsOnASingleLine: false
# 允许短的函数放在同一行: None, InlineOnly(定义在类中), Empty(空函数), Inline(定义在类中,空函数), All
AllowShortFunctionsOnASingleLine: Empty
# 允许短的if语句保持在同一行
AllowShortIfStatementsOnASingleLine: false
# 允许短的循环保持在同一行
AllowShortLoopsOnASingleLine: false
# 总是在定义返回类型后换行(deprecated)
AlwaysBreakAfterDefinitionReturnType: None
# 总是在返回类型后换行: None, All, TopLevel(顶级函数,不包括在类中的函数),
# AllDefinitions(所有的定义,不包括声明), TopLevelDefinitions(所有的顶级函数的定义)
AlwaysBreakAfterReturnType: None
# 总是在多行string字面量前换行
AlwaysBreakBeforeMultilineStrings: false
# 总是在template声明后换行
AlwaysBreakTemplateDeclarations: false
# false表示函数实参要么都在同一行,要么都各自一行
BinPackArguments: true
# false表示所有形参要么都在同一行,要么都各自一行
BinPackParameters: true
# 大括号换行,只有当BreakBeforeBraces设置为Custom时才有效
BraceWrapping: # class定义后面AfterClass: false# 控制语句后面AfterControlStatement: false# enum定义后面AfterEnum: false# 函数定义后面AfterFunction: false# 命名空间定义后面AfterNamespace: false# ObjC定义后面AfterObjCDeclaration: false# struct定义后面AfterStruct: false# union定义后面AfterUnion: false# catch之前BeforeCatch: true# else之前BeforeElse: true# 缩进大括号IndentBraces: false
# 在二元运算符前换行: None(在操作符后换行), NonAssignment(在非赋值的操作符前换行), All(在操作符前换行)
BreakBeforeBinaryOperators: NonAssignment
# 在大括号前换行: Attach(始终将大括号附加到周围的上下文), Linux(除函数、命名空间和类定义,与Attach类似),
# Mozilla(除枚举、函数、记录定义,与Attach类似), Stroustrup(除函数定义、catch、else,与Attach类似),
# Allman(总是在大括号前换行), GNU(总是在大括号前换行,并对于控制语句的大括号增加额外的缩进), WebKit(在函数前换行), Custom
# 注:这里认为语句块也属于函数
BreakBeforeBraces: Custom
# 在三元运算符前换行
BreakBeforeTernaryOperators: true
# 在构造函数的初始化列表的逗号前换行
BreakConstructorInitializersBeforeComma: false
# 每行字符的限制,0表示没有限制
ColumnLimit: 200
# 描述具有特殊意义的注释的正则表达式,它不应该被分割为多行或以其它方式改变
CommentPragmas: '^ IWYU pragma:'
# 构造函数的初始化列表要么都在同一行,要么都各自一行
ConstructorInitializerAllOnOneLineOrOnePerLine: false
# 构造函数的初始化列表的缩进宽度
ConstructorInitializerIndentWidth: 4
# 延续的行的缩进宽度
ContinuationIndentWidth: 4
# 去除C++11的列表初始化的大括号{后和}前的空格
Cpp11BracedListStyle: false
# 继承最常用的指针和引用的对齐方式
DerivePointerAlignment: false
# 关闭格式化
DisableFormat: false
# 自动检测函数的调用和定义是否被格式为每行一个参数(Experimental)
ExperimentalAutoDetectBinPacking: false
# 需要被解读为foreach循环而不是函数调用的宏
ForEachMacros: [ foreach, Q_FOREACH, BOOST_FOREACH ]
# 对#include进行排序,匹配了某正则表达式的#include拥有对应的优先级,匹配不到的则默认优先级为INT_MAX(优先级越小排序越靠前),
# 可以定义负数优先级从而保证某些#include永远在最前面
IncludeCategories: - Regex: '^"(llvm|llvm-c|clang|clang-c)/'Priority: 2- Regex: '^(<|"(gtest|isl|json)/)'Priority: 3- Regex: '.*'Priority: 1
# 缩进case标签
IndentCaseLabels: false
# 缩进宽度
IndentWidth: 4
# 函数返回类型换行时,缩进函数声明或函数定义的函数名
IndentWrappedFunctionNames: false
# 保留在块开始处的空行
KeepEmptyLinesAtTheStartOfBlocks: true
# 开始一个块的宏的正则表达式
MacroBlockBegin: ''
# 结束一个块的宏的正则表达式
MacroBlockEnd: ''
# 连续空行的最大数量
MaxEmptyLinesToKeep: 1
# 命名空间的缩进: None, Inner(缩进嵌套的命名空间中的内容), All
NamespaceIndentation: Inner
# 使用ObjC块时缩进宽度
ObjCBlockIndentWidth: 4
# 在ObjC的@property后添加一个空格
ObjCSpaceAfterProperty: false
# 在ObjC的protocol列表前添加一个空格
ObjCSpaceBeforeProtocolList: true
# 在call(后对函数调用换行的penalty
PenaltyBreakBeforeFirstCallParameter: 19
# 在一个注释中引入换行的penalty
PenaltyBreakComment: 300
# 第一次在<<前换行的penalty
PenaltyBreakFirstLessLess: 120
# 在一个字符串字面量中引入换行的penalty
PenaltyBreakString: 1000
# 对于每个在行字符数限制之外的字符的penalty
PenaltyExcessCharacter: 1000000
# 将函数的返回类型放到它自己的行的penalty
PenaltyReturnTypeOnItsOwnLine: 60
# 指针和引用的对齐: Left, Right, Middle
PointerAlignment: Left
# 允许重新排版注释
ReflowComments: true
# 允许排序#include
SortIncludes: true
# 在C风格类型转换后添加空格
SpaceAfterCStyleCast: false
# 在赋值运算符之前添加空格
SpaceBeforeAssignmentOperators: true
# 开圆括号之前添加一个空格: Never, ControlStatements, Always
SpaceBeforeParens: ControlStatements
# 在空的圆括号中添加空格
SpaceInEmptyParentheses: false
# 在尾随的评论前添加的空格数(只适用于//)
SpacesBeforeTrailingComments: 2
# 在尖括号的<后和>前添加空格
SpacesInAngles: true
# 在容器(ObjC和JavaScript的数组和字典等)字面量中添加空格
SpacesInContainerLiterals: true
# 在C风格类型转换的括号中添加空格
SpacesInCStyleCastParentheses: true
# 在圆括号的(后和)前添加空格
SpacesInParentheses: true
# 在方括号的[后和]前添加空格,lamda表达式和未指明大小的数组的声明不受影响
SpacesInSquareBrackets: true
# 标准: Cpp03, Cpp11, Auto
Standard: Cpp11
# tab宽度
TabWidth: 4
# 使用tab字符: Never, ForIndentation, ForContinuationAndIndentation, Always
UseTab: Never
代码review辅助工具相关推荐
- 代码review的流程
以前我们一直都是如果要进行代码review的时候,要不我们就直接用idea来进行查看,根据不同的来查看 但是我们都是看代码的不同来进行来实现的,其实我们不需要这样,我们可以使用工具Phabricato ...
- 15个最佳的代码评审(Code Review)工具
代码评审可以被看作是计算机源代码的测试,它的目的是查找和修复引入到开发阶段的应用程序的错误,提高软件的整体素质和开发者的技能.代码审查程序以各种形式,如结对编程,代码抽查等.在这个列表中,我们编制了1 ...
- 程序员终结者还是“白嫖”开源代码?GitHub推出的AI编程辅助工具陷入争议
整理 | 褚杏娟 微软是否违反了开源许可协议规定? 6 月 30 日,微软旗下代码托管平台 GitHub 推出了名为" Copilot "的 AI 编程辅助工具.但刚发布不久,这款 ...
- Python (百万答题类节目)辅助工具代码(实测有效)
前段时间很火的百万答题,现在编写了一个脚本辅助工具,思路如下: ①adb连接手机获取截屏,保存到本地 ②pytesseract获取图片指定位置的文字 ③网页查找答案 附代码如下:(亲测通过,执行时间6 ...
- 最强辅助!IDA 辅助工具Karta——二进制文件中搜索开源代码
介绍 " Karta"是IDA的python插件,其功能是在已经编译过的二进制文件中搜索是否使用了开源的代码.该插件是为了匹配大体积二进制文件中的开放源代码库的开源代码(通常是查找 ...
- java code review 工具_两款好用的代码Review工具 | 学步园
最近团队内部呼吁代码质量的声音越来越高,项目组引入了代码Review机制.上次我由于不了解主站URL替换的规则,险些造成客户端图片读取错误,而代码Review则有助于帮我们发现代码潜在的问题. 主讲的 ...
- Shader着色器代码辅助工具
借用二次元界一个传奇组合的话:"既然你诚心诚意地发问了,我们就大发慈悲地告诉你--"这次我为普罗开发者提供Shader代码辅助工具的安装指南,也是作为Unity着色器训练营第二期直 ...
- 平时资料综合汇总 eclipse开发代码辅助工具 普陀山
软件下载网址: http://www.xdowns.com/soft/188/215/2010/Soft_61286.html http://www.xdowns.com/soft/27/zhanlu ...
- 有人实践过 Phabricator 以及 Arcanist 作为 code review 的工具么?(转)
作者:覃超 链接:http://www.zhihu.com/question/19977889/answer/13539702 来源:知乎 平时就经常实践. 整个公司的code review就是使用这 ...
最新文章
- 小学生python-现在连小学生都会Python了吗?
- java 获取系统当前时间
- nagios利用pyfetion报警最新
- pycharm的项目文件中包括什么_工程建设施工招标项目的招标文件包括哪些内容?...
- the computational graph needed to compute the outputs报错解决
- .NET Core微服务之基于IdentityServer建立授权与验证服务
- 前端学习(2240):构造Vue的的利器-脚手架vue-cli3
- 【oracle】常用函数总结
- pandas不显示index_pandas层级索引
- cryptojs php 互通_如何实现PHP7和CryptoJS的AES加密方式互通?
- PPT实现倒计时功能(VBA实现)
- 专业心理性格测试软件,what is my color心理性格测试
- 管理,教育,励志系列合集600本电子书
- Android开发 匹配软键盘回车键
- thinkphp使用编辑器kindeditor
- 硅谷性能服务器介绍,美国RAKsmart服务器优势特点介绍
- iOS应用的内测签名、分发托管平台:蒲公英内测分发平台简介
- mysql自动备份工具_|Mysql自动备份工具(Auto MySQL Backup)下载v1.5 官方版 附教程 - 欧普软件下载...
- bt面板从7.1升级到7.5.2之后网络挂了
- 新视野大学英语读写教程第四册 答案
热门文章
- Electron-vue dialog.messageBox 组件使用
- 如何在 Linux、Windows 和 Mac 上查找 WiFi 密码?
- excel快速计算排名
- 阿里云总裁胡晓明:未来和合作伙伴一起_服务1000万家企业
- icefaces 真是我见过最垃圾的第三方组件。。竟然还敢收钱
- 十年偶像做成游戏,粉丝们会买账吗?
- Python取余/求余(%)问题,负数求余最简单的解释
- 机器人植入情感芯片利与弊_一个机器人被植入有感情的芯片,喜欢上教授的妻子,什么电影...
- python入门第三天(持续)
- leetcode_205. 同构字符串