Форматеры
opencode использует средства форматирования, специфичные для языка.
opencode автоматически форматирует файлы после их записи или редактирования с использованием средств форматирования для конкретного языка. Это гарантирует, что создаваемый код будет соответствовать стилям кода вашего проекта.
Built-in
opencode поставляется с несколькими встроенными форматировщиками для популярных языков и платформ. Ниже приведен список форматтеров, поддерживаемых расширений файлов, а также необходимых команд или параметров конфигурации.
| Formatter | Расширения | Требования |
|---|---|---|
| gofmt | .go | Доступна команда gofmt |
| mix | .ex, .exs, .eex, .heex, .leex, .neex, .sface | Доступна команда mix |
| prettier | .js, .jsx, .ts, .tsx, .html, .css, .md, .json, .yaml и подробнее | Зависимость prettier в package.json |
| biome | .js, .jsx, .ts, .tsx, .html, .css, .md, .json, .yaml и подробнее | Конфигурационный файл biome.json(c) |
| zig | .zig, .zon | Доступна команда zig |
| clang-format | .c, .cpp, .h, .hpp, .ino и подробнее | Конфигурационный файл .clang-format |
| ktlint | .kt, .kts | Доступна команда ktlint |
| ruff | .py, .pyi | Команда ruff доступна в конфигурации |
| rustfmt | .rs | Доступна команда rustfmt |
| cargofmt | .rs | Доступна команда cargo fmt |
| uv | .py, .pyi | Доступна команда uv |
| rubocop | .rb, .rake, .gemspec, .ru | Доступна команда rubocop |
| standardrb | .rb, .rake, .gemspec, .ru | Доступна команда standardrb |
| htmlbeautifier | .erb, .html.erb | Доступна команда htmlbeautifier |
| air | .R | Доступна команда air |
| dart | .dart | Доступна команда dart |
| ocamlformat | .ml, .mli | Доступна команда ocamlformat и файл конфигурации .ocamlformat. |
| terraform | .tf, .tfvars | Доступна команда terraform |
| gleam | .gleam | Доступна команда gleam |
| nixfmt | .nix | Доступна команда nixfmt |
| shfmt | .sh, .bash | Доступна команда shfmt |
| pint | .php | Зависимость laravel/pint в composer.json |
| oxfmt (Experimental) | .js, .jsx, .ts, .tsx | Зависимость oxfmt в package.json и экспериментальная переменная окружения flag |
| ormolu | .hs | Доступна команда ormolu |
Поэтому, если ваш проект имеет prettier в вашем package.json, opencode автоматически его использует.
Configure
Вы можете настроить форматтеры через раздел formatter в конфигурации opencode.
{ "$schema": "https://opencode.ai/config.json", "formatter": {}}Каждая конфигурация форматтера поддерживает следующее:
| Свойство | Тип | Описание |
|---|---|---|
disabled | boolean | Установите для этого параметра значение true, чтобы отключить форматтер. |
command | string[] | Команда для форматирования |
environment | объект | Переменные среды, которые необходимо установить при запуске средства форматирования |
extensions | string[] | Расширения файлов, которые должен обрабатывать этот форматтер |
Давайте посмотрим на несколько примеров.
Disabling Formatters
Чтобы глобально отключить все средства форматирования, установите для formatter значение false:
{ "$schema": "https://opencode.ai/config.json", "formatter": false}Чтобы отключить конкретный форматтер, установите для disabled значение true:
{ "$schema": "https://opencode.ai/config.json", "formatter": { "prettier": { "disabled": true } }}Custom Formatters
Вы можете переопределить встроенные средства форматирования или добавить новые, указав команду, переменные среды и расширения файлов:
{ "$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 в команде будет заменен путем к форматируемому файлу.