La barra di stato è una barra personalizzabile nella parte inferiore di Claude Code che esegue qualsiasi script di shell che configuri. Riceve dati di sessione JSON su stdin e visualizza tutto ciò che il tuo script stampa, fornendoti una visualizzazione persistente e immediata dell’utilizzo del contesto, dei costi, dello stato git o di qualsiasi altra cosa tu voglia tracciare. Le barre di stato sono utili quando:Documentation Index
Fetch the complete documentation index at: https://code.claude.com/docs/llms.txt
Use this file to discover all available pages before exploring further.
- Vuoi monitorare l’utilizzo della finestra di contesto mentre lavori
- Hai bisogno di tracciare i costi della sessione
- Lavori su più sessioni e hai bisogno di distinguerle
- Vuoi che il ramo git e lo stato siano sempre visibili

Configura una barra di stato
Usa il comando/statusline per far generare uno script a Claude Code, oppure crea manualmente uno script e aggiungilo alle tue impostazioni.
Usa il comando /statusline
Il comando/statusline accetta istruzioni in linguaggio naturale che descrivono cosa vuoi visualizzare. Claude Code genera un file di script in ~/.claude/ e aggiorna automaticamente le tue impostazioni:
Configura manualmente una barra di stato
Aggiungi un campostatusLine alle tue impostazioni utente (~/.claude/settings.json, dove ~ è la tua directory home) o alle impostazioni del progetto. Imposta type su "command" e punta command a un percorso di script o a un comando di shell inline. Per una procedura dettagliata sulla creazione di uno script, vedi Costruisci una barra di stato passo dopo passo.
command viene eseguito in una shell, quindi puoi anche usare comandi inline invece di un file di script. Questo esempio usa jq per analizzare l’input JSON e visualizzare il nome del modello e la percentuale di contesto:
padding aggiunge spazi orizzontali extra (in caratteri) al contenuto della barra di stato. Il valore predefinito è 0. Questo padding è in aggiunta alla spaziatura integrata dell’interfaccia, quindi controlla l’indentazione relativa piuttosto che la distanza assoluta dal bordo del terminale.
Il campo opzionale refreshInterval esegue nuovamente il tuo comando ogni N secondi oltre agli aggiornamenti guidati da eventi. Il minimo è 1. Impostalo quando la tua barra di stato mostra dati basati sul tempo come un orologio, o quando i subagent in background cambiano lo stato git mentre la sessione principale è inattiva. Lascialo non impostato per eseguire solo su eventi.
Il campo opzionale hideVimModeIndicator sopprime il testo integrato -- INSERT -- sotto il prompt. Impostalo su true quando il tuo script renderizza vim.mode stesso, in modo che la modalità non venga visualizzata due volte.
Disabilita la barra di stato
Esegui/statusline e chiedigli di rimuovere o cancellare la tua barra di stato (ad esempio, /statusline delete, /statusline clear, /statusline remove it). Puoi anche eliminare manualmente il campo statusLine dal tuo settings.json.
Costruisci una barra di stato passo dopo passo
Questa procedura mostra cosa sta accadendo dietro le quinte creando manualmente una barra di stato che visualizza il modello corrente, la directory di lavoro e la percentuale di utilizzo della finestra di contesto.Eseguire
/statusline con una descrizione di quello che vuoi configura tutto questo automaticamente per te.
Crea uno script che legge JSON e stampa l'output
Claude Code invia dati JSON al tuo script tramite stdin. Questo script usa
jq, un parser JSON da riga di comando che potrebbe essere necessario installare, per estrarre il nome del modello, la directory e la percentuale di contesto, quindi stampa una riga formattata.Salva questo in ~/.claude/statusline.sh (dove ~ è la tua directory home, come /Users/username su macOS o /home/username su Linux):Aggiungi alle impostazioni
Dì a Claude Code di eseguire il tuo script come barra di stato. Aggiungi questa configurazione a La tua barra di stato appare nella parte inferiore dell’interfaccia. Le impostazioni si ricaricano automaticamente, ma le modifiche non appariranno fino alla tua prossima interazione con Claude Code.
~/.claude/settings.json, che imposta type su "command" (che significa “esegui questo comando di shell”) e punta command al tuo script:Come funzionano le barre di stato
Claude Code esegue il tuo script e invia i dati di sessione JSON ad esso tramite stdin. Il tuo script legge il JSON, estrae quello di cui ha bisogno e stampa il testo su stdout. Claude Code visualizza tutto ciò che il tuo script stampa. Quando si aggiorna Il tuo script viene eseguito dopo ogni nuovo messaggio dell’assistente, dopo che/compact termina, quando cambia la modalità di autorizzazione o quando la modalità vim si attiva/disattiva. Gli aggiornamenti vengono debounced a 300ms, il che significa che i cambiamenti rapidi si raggruppano insieme e il tuo script viene eseguito una volta che le cose si stabilizzano. Se un nuovo aggiornamento si attiva mentre il tuo script è ancora in esecuzione, l’esecuzione in corso viene annullata. Se modifichi il tuo script, le modifiche non appariranno fino al prossimo aggiornamento di Claude Code.
Questi trigger possono diventare silenziosi quando la sessione principale è inattiva, ad esempio mentre un coordinatore attende i subagent in background. Per mantenere i segmenti basati sul tempo o provenienti da fonti esterne aggiornati durante i periodi di inattività, imposta refreshInterval per eseguire nuovamente il comando anche su un timer fisso.
Cosa può produrre il tuo script
- Più righe: ogni istruzione
echooprintviene visualizzata come una riga separata. Vedi l’esempio multi-riga. - Colori: usa codici di escape ANSI come
\033[32mper il verde (il terminale deve supportarli). Vedi l’esempio di stato git. - Link: usa sequenze di escape OSC 8 per rendere il testo cliccabile (Cmd+clic su macOS, Ctrl+clic su Windows/Linux). Richiede un terminale che supporti i hyperlink come iTerm2, Kitty o WezTerm. Vedi l’esempio di link cliccabili.
La barra di stato viene eseguita localmente e non consuma token API. Si nasconde temporaneamente durante determinate interazioni dell’interfaccia utente, inclusi i suggerimenti di completamento automatico, il menu della guida e i prompt di autorizzazione.
Dati disponibili
Claude Code invia i seguenti campi JSON al tuo script tramite stdin:| Campo | Descrizione |
|---|---|
model.id, model.display_name | Identificatore del modello corrente e nome visualizzato |
cwd, workspace.current_dir | Directory di lavoro corrente. Entrambi i campi contengono lo stesso valore; workspace.current_dir è preferito per coerenza con workspace.project_dir. |
workspace.project_dir | Directory in cui Claude Code è stato avviato, che potrebbe differire da cwd se la directory di lavoro cambia durante una sessione |
workspace.added_dirs | Directory aggiuntive aggiunte tramite /add-dir o --add-dir. Array vuoto se nessuna è stata aggiunta |
workspace.git_worktree | Nome del Git worktree quando la directory corrente si trova all’interno di un worktree collegato creato con git worktree add. Assente nel worktree principale. Popolato per qualsiasi git worktree, a differenza di worktree.* che si applica solo alle sessioni --worktree |
cost.total_cost_usd | Costo totale stimato della sessione in USD, calcolato lato client. Potrebbe differire dalla tua fattura effettiva |
cost.total_duration_ms | Tempo totale trascorso dal momento dell’avvio della sessione, in millisecondi |
cost.total_api_duration_ms | Tempo totale trascorso in attesa delle risposte API in millisecondi |
cost.total_lines_added, cost.total_lines_removed | Righe di codice modificate |
context_window.total_input_tokens, context_window.total_output_tokens | Conteggi dei token attualmente nella finestra di contesto, dalla risposta API più recente. L’input include letture e scritture della cache. Prima della v2.1.132 questi erano totali cumulativi della sessione |
context_window.context_window_size | Dimensione massima della finestra di contesto in token. 200000 per impostazione predefinita, o 1000000 per i modelli con contesto esteso. |
context_window.used_percentage | Percentuale pre-calcolata della finestra di contesto utilizzata |
context_window.remaining_percentage | Percentuale pre-calcolata della finestra di contesto rimanente |
context_window.current_usage | Conteggi dei token dall’ultima chiamata API, descritti in campi della finestra di contesto |
exceeds_200k_tokens | Se il conteggio totale dei token (token di input, cache e output combinati) dalla risposta API più recente supera 200k. Questo è un limite fisso indipendentemente dalla dimensione effettiva della finestra di contesto. |
effort.level | Livello di sforzo di ragionamento corrente (low, medium, high, xhigh, o max). Riflette il valore della sessione attiva, inclusi i cambiamenti di /effort durante la sessione. Assente quando il modello corrente non supporta il parametro effort |
thinking.enabled | Se il pensiero esteso è abilitato per la sessione |
rate_limits.five_hour.used_percentage, rate_limits.seven_day.used_percentage | Percentuale del limite di velocità di 5 ore o 7 giorni consumato, da 0 a 100 |
rate_limits.five_hour.resets_at, rate_limits.seven_day.resets_at | Secondi di epoca Unix quando la finestra del limite di velocità di 5 ore o 7 giorni si ripristina |
session_id | Identificatore univoco della sessione |
session_name | Nome della sessione personalizzato impostato con il flag --name o /rename. Assente se nessun nome personalizzato è stato impostato |
transcript_path | Percorso del file di trascrizione della conversazione |
version | Versione di Claude Code |
output_style.name | Nome dello stile di output corrente |
vim.mode | Modalità vim corrente (NORMAL, INSERT, VISUAL, o VISUAL LINE) quando la modalità vim è abilitata |
agent.name | Nome dell’agente quando si esegue con il flag --agent o le impostazioni dell’agente configurate |
worktree.name | Nome del worktree attivo. Presente solo durante le sessioni --worktree |
worktree.path | Percorso assoluto della directory del worktree |
worktree.branch | Nome del ramo git per il worktree (ad esempio, "worktree-my-feature"). Assente per i worktree basati su hook |
worktree.original_cwd | La directory in cui Claude si trovava prima di entrare nel worktree |
worktree.original_branch | Ramo git estratto prima di entrare nel worktree. Assente per i worktree basati su hook |
Schema JSON completo
Schema JSON completo
Il tuo comando della barra di stato riceve questa struttura JSON tramite stdin:Campi che potrebbero essere assenti (non presenti in JSON):
session_name: appare solo quando un nome personalizzato è stato impostato con--nameo/renameworkspace.git_worktree: appare solo quando la directory corrente si trova all’interno di un git worktree collegatoeffort: appare solo quando il modello corrente supporta il parametro di sforzo di ragionamentovim: appare solo quando la modalità vim è abilitataagent: appare solo quando si esegue con il flag--agento le impostazioni dell’agente configurateworktree: appare solo durante le sessioni--worktree. Quando presente,brancheoriginal_branchpotrebbero anche essere assenti per i worktree basati su hookrate_limits: appare solo per gli abbonati Claude.ai (Pro/Max) dopo la prima risposta API nella sessione. Ogni finestra (five_hour,seven_day) potrebbe essere indipendentemente assente. Usajq -r '.rate_limits.five_hour.used_percentage // empty'per gestire l’assenza con eleganza.
null:context_window.current_usage:nullprima della prima chiamata API in una sessione, e di nuovo dopo/compactfino a quando la prossima chiamata API non lo ripopolacontext_window.used_percentage,context_window.remaining_percentage: potrebbero esserenullall’inizio della sessione
Campi della finestra di contesto
L’oggettocontext_window descrive la finestra di contesto attiva dalla risposta API più recente. A partire dalla v2.1.132, total_input_tokens e total_output_tokens riflettono l’utilizzo del contesto corrente, non i totali cumulativi della sessione.
- Totali combinati (
total_input_tokens,total_output_tokens): token attualmente nella finestra di contesto.total_input_tokensè la somma diinput_tokens,cache_creation_input_tokensecache_read_input_tokens;total_output_tokenssono i token di output dalla risposta più recente. Entrambi sono0prima della prima risposta API. - Utilizzo per componente (
current_usage): gli stessi conteggi dei token suddivisi per categoria. Usa questo quando hai bisogno di separare i cache hit dall’input fresco.
current_usage contiene:
input_tokens: token di input nel contesto correnteoutput_tokens: token di output generaticache_creation_input_tokens: token scritti nella cachecache_read_input_tokens: token letti dalla cache
used_percentage viene calcolato solo dai token di input: input_tokens + cache_creation_input_tokens + cache_read_input_tokens. Non include output_tokens.
Se calcoli manualmente la percentuale di contesto da current_usage, usa la stessa formula solo per l’input per corrispondere a used_percentage.
L’oggetto current_usage è null prima della prima chiamata API in una sessione, e di nuovo immediatamente dopo /compact fino a quando la prossima chiamata API non lo ripopola.
Esempi
Questi esempi mostrano modelli comuni della barra di stato. Per usare qualsiasi esempio:- Salva lo script in un file come
~/.claude/statusline.sh(o.py/.js) - Rendilo eseguibile:
chmod +x ~/.claude/statusline.sh - Aggiungi il percorso alle tue impostazioni
jq per analizzare JSON. Python e Node.js hanno l’analisi JSON integrata.
Utilizzo della finestra di contesto
Visualizza il modello corrente e l’utilizzo della finestra di contesto con una barra di progresso visiva. Ogni script legge JSON da stdin, estrae il campoused_percentage e costruisce una barra di 10 caratteri dove i blocchi pieni (▓) rappresentano l’utilizzo:

Stato git con colori
Mostra il ramo git con indicatori codificati a colori per i file in staging e modificati. Questo script usa codici di escape ANSI per i colori del terminale:\033[32m è verde, \033[33m è giallo e \033[0m ripristina il valore predefinito.

Tracciamento di costi e durata
Traccia i costi API della tua sessione e il tempo trascorso. Il campocost.total_cost_usd accumula il costo stimato di tutte le chiamate API nella sessione corrente. Il campo cost.total_duration_ms misura il tempo totale trascorso dall’inizio della sessione, mentre cost.total_api_duration_ms traccia solo il tempo trascorso in attesa delle risposte API.
Ogni script formatta il costo come valuta e converte i millisecondi in minuti e secondi:

Visualizza più righe
Il tuo script può produrre più righe per creare una visualizzazione più ricca. Ogni istruzioneecho produce una riga separata nell’area di stato.

print o echo crea una riga separata:
Link cliccabili
Questo esempio crea un link cliccabile al tuo repository GitHub. Legge l’URL del remote git, converte il formato SSH in HTTPS consed e avvolge il nome del repository nei codici di escape OSC 8. Tieni premuto Cmd (macOS) o Ctrl (Windows/Linux) e fai clic per aprire il link nel tuo browser.

printf '%b' che interpreta gli escape di backslash in modo più affidabile rispetto a echo -e su diverse shell:
Utilizzo del limite di velocità
Visualizza l’utilizzo del limite di velocità dell’abbonamento Claude.ai nella barra di stato. L’oggettorate_limits contiene five_hour (finestra mobile di 5 ore) e seven_day (finestra settimanale). Ogni finestra fornisce used_percentage (0-100) e resets_at (secondi di epoca Unix quando la finestra si ripristina).
Questo campo è presente solo per gli abbonati Claude.ai (Pro/Max) dopo la prima risposta API. Ogni script gestisce il campo assente con eleganza:
Memorizza nella cache le operazioni costose
Il tuo script della barra di stato viene eseguito frequentemente durante le sessioni attive. Comandi comegit status o git diff possono essere lenti, specialmente in repository di grandi dimensioni. Questo esempio memorizza nella cache le informazioni git in un file temporaneo e le aggiorna solo ogni 5 secondi.
Il nome del file di cache deve essere stabile tra le invocazioni della barra di stato all’interno di una sessione, ma univoco tra le sessioni in modo che le sessioni simultanee in repository diversi non leggano lo stato git memorizzato nella cache l’uno dell’altro. Gli identificatori basati su processi come $$, os.getpid() o process.pid cambiano ad ogni invocazione e annullano la cache. Usa invece session_id dall’input JSON: è stabile per la durata di una sessione ed è univoco per sessione.
Ogni script verifica se il file di cache è mancante o più vecchio di 5 secondi prima di eseguire i comandi git:
Configurazione Windows
Su Windows, Claude Code esegue i comandi della barra di stato tramite Git Bash quando Git Bash è installato, o tramite PowerShell quando Git Bash è assente. Per eseguire uno script PowerShell come barra di stato, invocalo tramitepowershell; questo funziona da entrambi i shell:
Barre di stato dei subagent
L’impostazionesubagentStatusLine renderizza un corpo di riga personalizzato per ogni subagent mostrato nel pannello dell’agente sotto il prompt. Usalo per sostituire la riga predefinita name · description · token count con la tua formattazione.
columns (la larghezza di riga utilizzabile) e un array tasks, dove ogni task ha id, name, type, status, description, label, startTime, tokenCount, tokenSamples e cwd.
Scrivi una riga JSON su stdout per ogni riga che vuoi sovrascrivere, nella forma {"id": "<task id>", "content": "<row body>"}. La stringa content viene renderizzata così com’è, inclusi i colori ANSI e i hyperlink OSC 8. Ometti l’id di un task per mantenere il rendering predefinito per quella riga; emetti una stringa content vuota per nasconderla.
Gli stessi gate di fiducia e disableAllHooks che si applicano a statusLine si applicano qui. I plugin possono fornire un subagentStatusLine predefinito nel loro settings.json.
Suggerimenti
- Testa con input simulato:
echo '{"model":{"display_name":"Opus"},"workspace":{"current_dir":"/home/user/project"},"context_window":{"used_percentage":25},"session_id":"test-session-abc"}' | ./statusline.sh - Mantieni l’output breve: la barra di stato ha una larghezza limitata, quindi l’output lungo potrebbe essere troncato o andare a capo in modo sgradevole
- Memorizza nella cache le operazioni lente: il tuo script viene eseguito frequentemente durante le sessioni attive, quindi comandi come
git statuspossono causare lag. Vedi l’esempio di caching per come gestire questo.
Risoluzione dei problemi
La barra di stato non appare- Verifica che il tuo script sia eseguibile:
chmod +x ~/.claude/statusline.sh - Controlla che il tuo script stampi su stdout, non su stderr
- Esegui il tuo script manualmente per verificare che produca output
- Se
disableAllHooksè impostato sutruenelle tue impostazioni, anche la barra di stato è disabilitata. Rimuovi questa impostazione o impostala sufalseper riabilitarla. - Esegui
claude --debugper registrare il codice di uscita e stderr dalla prima invocazione della barra di stato in una sessione - Chiedi a Claude di leggere il tuo file di impostazioni ed eseguire il comando
statusLinedirettamente per far emergere gli errori
-- o valori vuoti
- I campi potrebbero essere
nullprima che la prima risposta API si completi - Gestisci i valori null nel tuo script con fallback come
// 0in jq - Riavvia Claude Code se i valori rimangono vuoti dopo più messaggi
- Usa
used_percentageper lo stato di contesto più semplice e accurato - La percentuale di contesto potrebbe differire dall’output
/contexta causa di quando ciascuno viene calcolato
- Verifica che il tuo terminale supporti i hyperlink OSC 8 (iTerm2, Kitty, WezTerm)
- Terminal.app non supporta i link cliccabili
-
Se il testo del link appare ma non è cliccabile, Claude Code potrebbe non aver rilevato il supporto dei hyperlink nel tuo terminale. Questo accade comunemente con Windows Terminal e altri emulatori non nell’elenco di rilevamento automatico. Imposta la variabile di ambiente
FORCE_HYPERLINKper sovrascrivere il rilevamento prima di avviare Claude Code:In PowerShell, imposta la variabile nella sessione corrente prima: - Le sessioni SSH e tmux potrebbero eliminare le sequenze OSC a seconda della configurazione
-
Se le sequenze di escape appaiono come testo letterale come
\e]8;;, usaprintf '%b'invece diecho -eper una gestione più affidabile degli escape
- Le sequenze di escape complesse (colori ANSI, link OSC 8) possono occasionalmente causare output corrotto se si sovrappongono ad altri aggiornamenti dell’interfaccia utente
- Se vedi testo corrotto, prova a semplificare il tuo script in output di testo semplice
- Le barre di stato multi-riga con codici di escape sono più soggette a problemi di rendering rispetto al testo semplice su una sola riga
- Il comando della barra di stato viene eseguito solo se hai accettato la finestra di dialogo di fiducia dell’area di lavoro per la directory corrente. Poiché
statusLineesegue un comando di shell, richiede la stessa accettazione di fiducia di hook e altre impostazioni che eseguono shell. - Se la fiducia non è accettata, vedrai la notifica
statusline skipped · restart to fixinvece dell’output della tua barra di stato. Riavvia Claude Code e accetta il prompt di fiducia per abilitarla.
- Gli script che escono con codici diversi da zero o non producono output causano il vuoto della barra di stato
- Gli script lenti bloccano l’aggiornamento della barra di stato fino al completamento. Mantieni gli script veloci per evitare output obsoleto.
- Se un nuovo aggiornamento si attiva mentre uno script lento è in esecuzione, lo script in corso viene annullato
- Testa il tuo script indipendentemente con input simulato prima di configurarlo
- Le notifiche di sistema come errori del server MCP e aggiornamenti automatici vengono visualizzate sul lato destro della stessa riga della tua barra di stato. Le notifiche transitorie come l’avviso di contesto basso si cicla anche attraverso questa area.
- L’abilitazione della modalità verbose aggiunge un contatore di token a questa area
- Su terminali stretti, queste notifiche potrebbero troncare l’output della tua barra di stato