Formattatori
OpenCode utilizza formattatori specifici per linguaggio.
OpenCode formatta automaticamente i file dopo che sono stati scritti o modificati utilizzando formattatori specifici per linguaggio. Questo garantisce che il codice generato segua gli stili di codice del tuo progetto.
Integrati
OpenCode include diversi formattatori integrati per linguaggi e framework popolari. Di seguito e riportato un elenco dei formattatori, delle estensioni di file supportate e dei comandi o opzioni di configurazione necessari.
| Formatter | Extensions | Requirements |
|---|---|---|
| gofmt | .go | comando gofmt disponibile |
| mix | .ex, .exs, .eex, .heex, .leex, .neex, .sface | comando mix disponibile |
| prettier | .js, .jsx, .ts, .tsx, .html, .css, .md, .json, .yaml, e altro | dipendenza prettier in package.json |
| biome | .js, .jsx, .ts, .tsx, .html, .css, .md, .json, .yaml, e altro | file di configurazione biome.json(c) |
| zig | .zig, .zon | comando zig disponibile |
| clang-format | .c, .cpp, .h, .hpp, .ino, e altro | file di configurazione .clang-format |
| ktlint | .kt, .kts | comando ktlint disponibile |
| ruff | .py, .pyi | comando ruff disponibile con configurazione |
| rustfmt | .rs | comando rustfmt disponibile |
| cargofmt | .rs | comando cargo fmt disponibile |
| uv | .py, .pyi | comando uv disponibile |
| rubocop | .rb, .rake, .gemspec, .ru | comando rubocop disponibile |
| standardrb | .rb, .rake, .gemspec, .ru | comando standardrb disponibile |
| htmlbeautifier | .erb, .html.erb | comando htmlbeautifier disponibile |
| air | .R | comando air disponibile |
| dart | .dart | comando dart disponibile |
| ocamlformat | .ml, .mli | comando ocamlformat disponibile e file di configurazione .ocamlformat |
| terraform | .tf, .tfvars | comando terraform disponibile |
| gleam | .gleam | comando gleam disponibile |
| nixfmt | .nix | comando nixfmt disponibile |
| shfmt | .sh, .bash | comando shfmt disponibile |
| oxfmt (Experimental) | .js, .jsx, .ts, .tsx | dipendenza oxfmt in package.json e un flag sperimentale |
Quindi se il tuo progetto ha prettier nel tuo package.json, OpenCode lo utilizzera automaticamente.
Come funziona
Quando OpenCode scrive o modifica un file, esegue questi passaggi:
- Verifica l’estensione del file rispetto a tutti i formattatori abilitati.
- Esegue il comando di formattazione appropriato sul file.
- Applica automaticamente le modifiche di formattazione.
Questo processo avviene in background, garantendo che gli stili di codice vengano mantenuti senza alcun passaggio manuale.
Configurazione
Puoi personalizzare i formattatori tramite la sezione formatter nella tua configurazione OpenCode.
{ "$schema": "https://opencode.ai/config.json", "formatter": {}}Ogni configurazione del formattatore supporta quanto segue:
| Property | Type | Description |
|---|---|---|
disabled | boolean | Imposta su true per disabilitare il formattatore |
command | string[] | Il comando da eseguire per la formattazione |
environment | object | Variabili d’ambiente da impostare durante la formattazione |
extensions | string[] | Estensioni di file che questo formattatore deve gestire |
Vediamo alcuni esempi.
Disabilitare i formattatori
Per disabilitare tutti i formattatori globalmente, imposta formatter su false:
{ "$schema": "https://opencode.ai/config.json", "formatter": false}Per disabilitare un formattatore specifico, imposta disabled su true:
{ "$schema": "https://opencode.ai/config.json", "formatter": { "prettier": { "disabled": true } }}Formattatori personalizzati
Puoi sostituire i formattatori integrati o aggiungerne di nuovi specificando il comando, le variabili d’ambiente e le estensioni dei file:
{ "$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"] } }}Il segnaposto $FILE nel comando verra sostituito con il percorso del file che viene formattato.