格式化工具
OpenCode 使用特定语言的格式化工具。
OpenCode 会在文件写入或编辑后,自动使用特定语言的格式化工具对其进行格式化。这确保了生成的代码遵循你项目的代码风格。
内置格式化工具
OpenCode 内置了多种适用于主流语言和框架的格式化工具。下表列出了各格式化工具、支持的文件扩展名以及所需的命令或配置选项。
| 格式化工具 | 扩展名 | 要求 |
|---|---|---|
| air | .R | air 命令可用 |
| biome | .js, .jsx, .ts, .tsx, .html, .css, .md, .json, .yaml 及更多 | biome.json(c) 配置文件 |
| cargofmt | .rs | cargo fmt 命令可用 |
| clang-format | .c, .cpp, .h, .hpp, .ino 及更多 | .clang-format 配置文件 |
| cljfmt | .clj, .cljs, .cljc, .edn | cljfmt 命令可用 |
| dart | .dart | dart 命令可用 |
| dfmt | .d | dfmt 命令可用 |
| gleam | .gleam | gleam 命令可用 |
| gofmt | .go | gofmt 命令可用 |
| htmlbeautifier | .erb, .html.erb | htmlbeautifier 命令可用 |
| ktlint | .kt, .kts | ktlint 命令可用 |
| mix | .ex, .exs, .eex, .heex, .leex, .neex, .sface | mix 命令可用 |
| nixfmt | .nix | nixfmt 命令可用 |
| ocamlformat | .ml, .mli | ocamlformat 命令可用且存在 .ocamlformat 配置文件 |
| ormolu | .hs | ormolu 命令可用 |
| oxfmt (Experimental) | .js, .jsx, .ts, .tsx | package.json 中有 oxfmt 依赖,且设置了实验性环境变量标志 |
| pint | .php | composer.json 中有 laravel/pint 依赖 |
| prettier | .js, .jsx, .ts, .tsx, .html, .css, .md, .json, .yaml 及更多 | package.json 中有 prettier 依赖 |
| rubocop | .rb, .rake, .gemspec, .ru | rubocop 命令可用 |
| ruff | .py, .pyi | ruff 命令可用且有相应配置 |
| rustfmt | .rs | rustfmt 命令可用 |
| shfmt | .sh, .bash | shfmt 命令可用 |
| standardrb | .rb, .rake, .gemspec, .ru | standardrb 命令可用 |
| terraform | .tf, .tfvars | terraform 命令可用 |
| uv | .py, .pyi | uv 命令可用 |
| zig | .zig, .zon | zig 命令可用 |
因此,如果你的项目 package.json 中包含 prettier,OpenCode 会自动使用它进行格式化。
工作原理
当 OpenCode 写入或编辑文件时,它会:
- 根据所有已启用的格式化工具检查文件扩展名。
- 对文件运行相应的格式化命令。
- 自动应用格式化更改。
整个过程在后台完成,无需任何手动操作即可保持代码风格的一致性。
配置
你可以通过 OpenCode 配置中的 formatter 部分自定义格式化工具。
{ "$schema": "https://opencode.ai/config.json", "formatter": {}}每个格式化工具的配置支持以下属性:
| 属性 | 类型 | 描述 |
|---|---|---|
disabled | boolean | 设为 true 可禁用该格式化工具 |
command | string[] | 执行格式化的命令 |
environment | object | 运行格式化工具时设置的环境变量 |
extensions | string[] | 该格式化工具处理的文件扩展名 |
下面来看一些示例。
禁用格式化工具
要全局禁用所有格式化工具,将 formatter 设为 false:
{ "$schema": "https://opencode.ai/config.json", "formatter": false}要禁用特定格式化工具,将 disabled 设为 true:
{ "$schema": "https://opencode.ai/config.json", "formatter": { "prettier": { "disabled": true } }}自定义格式化工具
你可以通过指定命令、环境变量和文件扩展名来覆盖内置格式化工具或添加新的格式化工具:
{ "$schema": "https://opencode.ai/config.json", "formatter": { "prettier": { "command": ["npx", "prettier", "--write", "$FILE"], "environment": { "NODE_ENV": "development" }, "extensions": [".js", ".ts", ".jsx", ".tsx"] }, "custom-markdown-formatter": { "command": ["deno", "fmt", "$FILE"], "extensions": [".md"] } }}命令中的 $FILE 占位符会被替换为待格式化文件的路径。