代码风格检查指南¶
整洁、规范的代码风格,能够保证代码的可读性、易用性和健壮性。Paddle 使用 pre-commit 工具进行代码风格检查。它可以帮助检查提交代码的不规范问题并格式化(当前会检查 C++,Python 和 CMake 语言的代码);诸如 cpplint 等工具能提前发现代码的潜在静态逻辑错误,提高开发效率。
在 Paddle CI 中,由 PR-CI-Codestyle-Check 流水线对提交的 PR 进行代码风格检查,若该流水线执行失败,PR 将无法合入到 Paddle 仓库。此时需要根据流水线日志的报错信息,在本地修改代码,再次提交。一般情况下,本地使用pre-commit
进行代码风格检查的结果和 PR-CI-Codestyle-Check 流水线结果是一致的。下面介绍 pre-commit
的本地安装与使用方法。
Paddle 目前使用的 pre-commit 版本是 2.17.0。首先安装并在当前目录运行它:
➜ pip install pre-commit==2.17.0
➜ pre-commit install
注:通过
pip install pre-commit
和conda install -c conda-forge pre-commit
安装的yapf
稍有不同的,Paddle 开发人员使用的是pip install pre-commit
。
在使用 git commit
提交修改时,pre-commit 将自动检查修改文件的代码规范,并对不符合规范的文件进行格式化。此时,git commit
并未执行成功,需要将 pre-commit 对文件的修改添加到暂存区,再次 commit,直到 pre-commit 代码检查通过后,本次提交才算完成。 例如,对 Paddle/paddle/phi/kernels/abs_kernel.h 修改后,提交 commit,通过git diff
查看,会发现 clang-format 修改了该文件,需要添加修改后,再次git commit
,完成本次提交。
➜ git diff
diff --git a/paddle/phi/kernels/abs_kernel.h b/paddle/phi/kernels/abs_kernel.h
index e79216a..7e06204 100644
--- a/paddle/phi/kernels/abs_kernel.h
+++ b/paddle/phi/kernels/abs_kernel.h
@@ -22,4 +22,5 @@ namespace phi {
template <typename T, typename Context>
void AbsKernel(const Context& ctx, const DenseTensor& x, DenseTensor* out);
-} // namespace phi
+void test_func();
+} // namespace
➜ git add paddle/phi/kernels/abs_kernel.h
➜ git commit -m "test"
CRLF end-lines remover...............................(no files to check)Skipped
yapf.................................................(no files to check)Skipped
check for added large files..............................................Passed
check for merge conflicts................................................Passed
check for broken symlinks............................(no files to check)Skipped
detect private key...................................(no files to check)Skipped
fix end of files.........................................................Passed
sort simple yaml files...............................(no files to check)Skipped
clang-format.............................................................Failed
- hook id: clang-format-with-version-check
- files were modified by this hook
cpplint..................................................................Passed
pylint...............................................(no files to check)Skipped
copyright_checker........................................................Passed
cmake-format.........................................(no files to check)Skipped
CMake Lint...........................................(no files to check)Skipped
➜ git diff
diff --git a/paddle/phi/kernels/abs_kernel.h b/paddle/phi/kernels/abs_kernel.h
index 7e06204..c1b803b 100644
--- a/paddle/phi/kernels/abs_kernel.h
+++ b/paddle/phi/kernels/abs_kernel.h
@@ -23,4 +23,4 @@ template <typename T, typename Context>
void AbsKernel(const Context& ctx, const DenseTensor& x, DenseTensor* out);
void test_func();
-} // namespace
+} // namespace phi
➜ git add paddle/phi/kernels/abs_kernel.h
➜ git commit -m "test"
➜ git log
commit xxx
Author: xxx
Date: xxx
test
...
目前 pre-commit 主要执行 C++, Python, Cmake 语言的代码规范和格式化,以及 git 相关的通用检查和格式化。所有的检查工具信息如下:
检查工具名称 | 作用 | 当前版本 |
---|---|---|
pre-commit | hook 管理工具 | 2.17.0 |
remove-crlf | 将 CRLF 改为 LF | 1.1.14 |
pre-commit-hooks | pre-commit 自带的 hook,执行一些通用检查 | 4.1.0 |
cpplint | C++代码风格检查 | 1.6.0 |
clang-format | C++代码格式化 | 13.0.0 |
pylint | python 代码风格检查,仅用于检查示例代码 | 2.12.0 |
yapf | python 代码格式化 | 0.32.0 |
FAQ¶
pre-commit==2.17.0 要求 Python>=3.6.1,建议使用较高版本的 Python。
在首次 commit 时,pre-commit 需要初始化环境,执行时间会稍长一些,大概在 3min 左右。
在首次 commit 前,请先升级 pip,并使用 pypi 官方镜像源,否则,可能会导致 clang-format 或者 cmake-lint 安装失败。命令如下:
➜ pip install --upgrade pip
➜ pip config set global.index-url https://pypi.python.org/simple