Git Hooks
Ce contenu n’est pas encore disponible dans votre langue.
Git 允许在运行 git 命令的过程中执行 Git Hooks 脚本。 例如,你可以在提交或者推送之前格式化及 lint 暂存(staged)的文件。 有几款工具来简化 git hook 的管理。 在接下来的章节里,我们将会介绍几款工具以及如何将他们与 Biome 集成。
Lefthook
Section titled LefthookLefthook 是一款快速的,跨平台且无依赖的 hook 管理器。 它可以通过 NPM 进行安装。
在你的 git 仓库的根路径下新增一个文件并命名为 lefthook.yml
。
一些 Lefthook 的配置案例:
-
提交前检查代码格式及 lint
-
提交前进行格式化,lint,以及进行安全的代码修复
stage_fixed: true
参数用于将更新的文件再次暂存。 -
推送前进行格式化和 lint
注意你并不需要使用 glob
和 --files-ignore-unknown=true
Lefthook。
只使用 --files-ignore-unknown=true
来允许目前和接下来支持通过 Biome 处理过的文件。
如果你希望能够更多地管理哪些文件被处理过,你应该使用 glob
。
--no-errors-on-unmatched
参数用于消除在无文件处理时候可能出现的异常。
配置之后,运行 lefthook install
来设置 hooks。
Husky
Section titled HuskyHusky 是一款在 JavaScript 生态系统内广泛使用的 hook 管理工具。 Husky 并不会隐藏未暂存的变更,也不能提供暂存的文件列表。 这也是为什么其通常和诸如 lint-staged 或 git-format-staged 等其他工具搭配使用。
如果你的项目包含 package.json
文件,
你可以通过 scripts.prepare
命令,在包安装完成后自动设置 husky。
lint-staged
Section titled lint-stagedlint-staged 是一款在 JavaScript 生态系统中最常使用的工具之一。
增加如下的 husky 配置:
lint-staged 的配置直接集成在 package.json
内。
这里包含了一些可能在运行 Git hooks 时会有帮助的命令的使用案例:
记得在你的命令中使用命令行配置项 --no-errors-on-unmatched
,消除可能出现的 无文件处理 异常。
git-format-staged
Section titled git-format-staged相较于诸如 lefthook、pre-commit 和 lint-staged 等其他工具,
git-format-staged 并没有在内部使用 git stash
命令。
这避免了当未暂存变更和更新后的已暂存变更存在冲突时需要手动处理。
参见comparison of git-format-staged with other tools。
一些配置案例:
-
提交前检查代码格式及 lint
-
提交前进行格式化,lint,以及进行安全的代码修复
pre-commit
Section titled pre-commitpre-commit 是一款跨语言的 hook 管理工具。 Biome 通过 biomejs/pre-commit 仓库提供了四个 pre-commit hooks。
hook id | 描述 |
---|---|
biome-ci | 检查格式,检查导入项是否规范,以及 lint 执行 |
biome-check | 对已提交文件进行格式化,导入项规范,lint,安全地代码修复 |
biome-format | 格式化已提交的文件 |
biome-lint | 对已提交代码执行 lint 及安全地代码修复 |
在接下来的案例,我们假设你安装了 pre-commit 并在你的仓库里运行了 pre-commit install
命令。
如果你想要实用 biome-check
hook,将下面的 pre-commit 配置添加到你的项目的根目录中的 .pre-commit-config.yaml
文件里:
这将会在你运行 git commit
命令时候,执行 biome check --write
。
要注意的是,根据配置项 additional_dependencies
,你必须要指定要使用哪个版本的 Biome。
pre-commit 单独安装工具并且需要知道安装哪个工具。
如果 Biome 已经作为 npm
包安装在你的本地仓库,
之后当你更新 Biome 时,它将负责更新 package.json
和 .pre-commit-config.yaml
。
你可以指定你自己的 本地 hook,而不是使用 Biome 提供的 hook。
例如,如果你使用 npm
,你可以在 .pre-commit-config.yaml
文件里写下如下的 hook 配置:
pre-commit 配置项 files
是可选的,
因为 Biome 能够忽略位置的文件(使用配置项 --files-ignore-unknown=true
)。
Shell 脚本
Section titled Shell 脚本你也可以使用自定义的 shell 脚本。 注意你需要考虑跨平台兼容的问题。 我们推荐你使用前面章节所提到的其中一款专业工具。
相关 shell 脚本案例:
-
提交前检查代码格式及 lint
-
提交前进行格式化,lint,以及进行安全地代码修复
注意当暂存文件有未暂存变更时,我们将会让 hook 运行失败。