A linha de status é uma barra personalizável na parte inferior do Claude Code que executa qualquer script de shell que você configurar. Ela recebe dados de sessão JSON em stdin e exibe tudo o que seu script imprime, oferecendo uma visualização persistente e rápida do uso de contexto, custos, status do git ou qualquer outra coisa que você queira rastrear. As linhas de status são úteis quando você: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.
- Quer monitorar o uso da janela de contexto enquanto trabalha
- Precisa rastrear custos de sessão
- Trabalha em várias sessões e precisa distingui-las
- Quer que a ramificação git e o status estejam sempre visíveis

Configurar uma linha de status
Use o comando/statusline para fazer com que o Claude Code gere um script para você, ou crie manualmente um script e adicione-o às suas configurações.
Use o comando /statusline
O comando/statusline aceita instruções em linguagem natural descrevendo o que você quer exibir. O Claude Code gera um arquivo de script em ~/.claude/ e atualiza suas configurações automaticamente:
Configure manualmente uma linha de status
Adicione um campostatusLine às suas configurações de usuário (~/.claude/settings.json, onde ~ é seu diretório inicial) ou configurações de projeto. Defina type como "command" e aponte command para um caminho de script ou um comando de shell inline. Para um passo a passo completo de criação de um script, consulte Construir uma linha de status passo a passo.
command é executado em um shell, então você também pode usar comandos inline em vez de um arquivo de script. Este exemplo usa jq para analisar a entrada JSON e exibir o nome do modelo e a porcentagem de contexto:
padding opcional adiciona espaçamento horizontal extra (em caracteres) ao conteúdo da linha de status. O padrão é 0. Este preenchimento é além do espaçamento integrado da interface, então controla o recuo relativo em vez da distância absoluta da borda do terminal.
O campo refreshInterval opcional executa novamente seu comando a cada N segundos além das atualizações orientadas por eventos. O mínimo é 1. Defina isto quando sua linha de status exibir dados baseados em tempo, como um relógio, ou quando subagentes em segundo plano alterarem o estado do git enquanto a sessão principal está ociosa. Deixe sem definir para executar apenas em eventos.
O campo hideVimModeIndicator opcional suprime o texto integrado -- INSERT -- abaixo do prompt. Defina isto como true quando seu script renderizar vim.mode em si, para que o modo não seja exibido duas vezes.
Desabilitar a linha de status
Execute/statusline e peça para remover ou limpar sua linha de status (por exemplo, /statusline delete, /statusline clear, /statusline remove it). Você também pode excluir manualmente o campo statusLine do seu settings.json.
Construir uma linha de status passo a passo
Este passo a passo mostra o que está acontecendo nos bastidores criando manualmente uma linha de status que exibe o modelo atual, diretório de trabalho e porcentagem de uso da janela de contexto.Executar
/statusline com uma descrição do que você quer configura tudo isso automaticamente para você.
Crie um script que leia JSON e imprima a saída
O Claude Code envia dados JSON para seu script via stdin. Este script usa
jq, um analisador JSON de linha de comando que você pode precisar instalar, para extrair o nome do modelo, diretório e porcentagem de contexto, depois imprime uma linha formatada.Salve isto em ~/.claude/statusline.sh (onde ~ é seu diretório inicial, como /Users/username no macOS ou /home/username no Linux):Adicione às configurações
Diga ao Claude Code para executar seu script como a linha de status. Adicione esta configuração a Sua linha de status aparece na parte inferior da interface. As configurações são recarregadas automaticamente, mas as alterações não aparecerão até sua próxima interação com o Claude Code.
~/.claude/settings.json, que define type como "command" (significando “execute este comando de shell”) e aponta command para seu script:Como as linhas de status funcionam
O Claude Code executa seu script e envia dados de sessão JSON para ele via stdin. Seu script lê o JSON, extrai o que precisa e imprime texto para stdout. O Claude Code exibe tudo o que seu script imprime. Quando é atualizado Seu script é executado após cada nova mensagem do assistente, após/compact terminar, quando o modo de permissão muda ou quando o modo vim alterna. As atualizações são debounced em 300ms, significando que mudanças rápidas são agrupadas e seu script é executado uma vez que as coisas se estabilizam. Se uma nova atualização for acionada enquanto seu script ainda está em execução, a execução em andamento é cancelada. Se você editar seu script, as alterações não aparecerão até que sua próxima interação com o Claude Code acione uma atualização.
Estes gatilhos podem ficar silenciosos quando a sessão principal está ociosa, por exemplo enquanto um coordenador aguarda subagentes em segundo plano. Para manter segmentos baseados em tempo ou de origem externa atualizados durante períodos ociosos, defina refreshInterval para também executar novamente o comando em um temporizador fixo.
O que seu script pode exibir
- Múltiplas linhas: cada instrução
echoouprinté exibida como uma linha separada. Consulte o exemplo de múltiplas linhas. - Cores: use códigos de escape ANSI como
\033[32mpara verde (o terminal deve suportá-los). Consulte o exemplo de status do git. - Links: use sequências de escape OSC 8 para tornar o texto clicável (Cmd+clique no macOS, Ctrl+clique no Windows/Linux). Requer um terminal que suporte hiperlinks como iTerm2, Kitty ou WezTerm. Consulte o exemplo de links clicáveis.
A linha de status é executada localmente e não consome tokens de API. Ela se oculta temporariamente durante certas interações da interface, incluindo sugestões de preenchimento automático, o menu de ajuda e prompts de permissão.
Dados disponíveis
O Claude Code envia os seguintes campos JSON para seu script via stdin:| Campo | Descrição |
|---|---|
model.id, model.display_name | Identificador do modelo atual e nome de exibição |
cwd, workspace.current_dir | Diretório de trabalho atual. Ambos os campos contêm o mesmo valor; workspace.current_dir é preferido para consistência com workspace.project_dir. |
workspace.project_dir | Diretório onde o Claude Code foi iniciado, que pode diferir de cwd se o diretório de trabalho mudar durante uma sessão |
workspace.added_dirs | Diretórios adicionais adicionados via /add-dir ou --add-dir. Array vazio se nenhum foi adicionado |
workspace.git_worktree | Nome da git worktree quando o diretório atual está dentro de uma worktree vinculada criada com git worktree add. Ausente na worktree principal. Preenchido para qualquer git worktree, diferentemente de worktree.* que se aplica apenas a sessões --worktree |
cost.total_cost_usd | Custo total estimado da sessão em USD, calculado no lado do cliente. Pode diferir de sua fatura real |
cost.total_duration_ms | Tempo total decorrido desde o início da sessão, em milissegundos |
cost.total_api_duration_ms | Tempo total gasto aguardando respostas de API em milissegundos |
cost.total_lines_added, cost.total_lines_removed | Linhas de código alteradas |
context_window.total_input_tokens, context_window.total_output_tokens | Contagens de tokens atualmente na janela de contexto, da resposta de API mais recente. A entrada inclui leituras e escritas de cache. Antes da v2.1.132, estas eram totais cumulativos de sessão |
context_window.context_window_size | Tamanho máximo da janela de contexto em tokens. 200000 por padrão, ou 1000000 para modelos com contexto estendido. |
context_window.used_percentage | Porcentagem pré-calculada da janela de contexto usada |
context_window.remaining_percentage | Porcentagem pré-calculada da janela de contexto restante |
context_window.current_usage | Contagens de tokens da última chamada de API, descritas em campos de janela de contexto |
exceeds_200k_tokens | Se a contagem total de tokens (tokens de entrada, cache e saída combinados) da resposta de API mais recente excede 200k. Este é um limite fixo independentemente do tamanho real da janela de contexto. |
effort.level | Nível de esforço de raciocínio atual (low, medium, high, xhigh ou max). Reflete o valor da sessão em tempo real, incluindo mudanças de /effort durante a sessão. Ausente quando o modelo atual não suporta o parâmetro de esforço |
thinking.enabled | Se o pensamento estendido está habilitado para a sessão |
rate_limits.five_hour.used_percentage, rate_limits.seven_day.used_percentage | Porcentagem do limite de taxa de 5 horas ou 7 dias consumida, de 0 a 100 |
rate_limits.five_hour.resets_at, rate_limits.seven_day.resets_at | Segundos de época Unix quando a janela de limite de taxa de 5 horas ou 7 dias é redefinida |
session_id | Identificador único de sessão |
session_name | Nome de sessão personalizado definido com a flag --name ou /rename. Ausente se nenhum nome personalizado foi definido |
transcript_path | Caminho para o arquivo de transcrição de conversa |
version | Versão do Claude Code |
output_style.name | Nome do estilo de saída atual |
vim.mode | Modo vim atual (NORMAL, INSERT, VISUAL ou VISUAL LINE) quando modo vim está habilitado |
agent.name | Nome do agente ao executar com a flag --agent ou configurações de agente configuradas |
worktree.name | Nome da worktree ativa. Presente apenas durante sessões --worktree |
worktree.path | Caminho absoluto para o diretório da worktree |
worktree.branch | Nome da ramificação git para a worktree (por exemplo, "worktree-my-feature"). Ausente para worktrees baseadas em hook |
worktree.original_cwd | O diretório em que o Claude estava antes de entrar na worktree |
worktree.original_branch | Ramificação git verificada antes de entrar na worktree. Ausente para worktrees baseadas em hook |
Esquema JSON completo
Esquema JSON completo
Seu comando de linha de status recebe esta estrutura JSON via stdin:Campos que podem estar ausentes (não presentes em JSON):
session_name: aparece apenas quando um nome personalizado foi definido com--nameou/renameworkspace.git_worktree: aparece apenas quando o diretório atual está dentro de uma git worktree vinculadaeffort: aparece apenas quando o modelo atual suporta o parâmetro de esforço de raciocíniovim: aparece apenas quando o modo vim está habilitadoagent: aparece apenas ao executar com a flag--agentou configurações de agente configuradasworktree: aparece apenas durante sessões--worktree. Quando presente,brancheoriginal_branchtambém podem estar ausentes para worktrees baseadas em hookrate_limits: aparece apenas para assinantes Claude.ai (Pro/Max) após a primeira resposta de API na sessão. Cada janela (five_hour,seven_day) pode estar independentemente ausente. Usejq -r '.rate_limits.five_hour.used_percentage // empty'para lidar com ausência graciosamente.
null:context_window.current_usage:nullantes da primeira chamada de API em uma sessão, e novamente após/compactaté que a próxima chamada de API a repopulecontext_window.used_percentage,context_window.remaining_percentage: podem sernullno início da sessão
Campos de janela de contexto
O objetocontext_window descreve a janela de contexto em tempo real da resposta de API mais recente. A partir da v2.1.132, total_input_tokens e total_output_tokens refletem o uso de contexto atual, não totais cumulativos de sessão.
- Totais combinados (
total_input_tokens,total_output_tokens): tokens atualmente na janela de contexto.total_input_tokensé a soma deinput_tokens,cache_creation_input_tokensecache_read_input_tokens;total_output_tokenssão os tokens de saída da resposta mais recente. Ambos são0antes da primeira resposta de API. - Uso por componente (
current_usage): as mesmas contagens de tokens divididas por categoria. Use isto quando você precisar de acertos de cache separados da entrada fresca.
current_usage contém:
input_tokens: tokens de entrada no contexto atualoutput_tokens: tokens de saída geradoscache_creation_input_tokens: tokens escritos no cachecache_read_input_tokens: tokens lidos do cache
used_percentage é calculado apenas a partir de tokens de entrada: input_tokens + cache_creation_input_tokens + cache_read_input_tokens. Ele não inclui output_tokens.
Se você calcular a porcentagem de contexto manualmente a partir de current_usage, use a mesma fórmula apenas de entrada para corresponder a used_percentage.
O objeto current_usage é null antes da primeira chamada de API em uma sessão, e novamente imediatamente após /compact até que a próxima chamada de API a repopule.
Exemplos
Estes exemplos mostram padrões comuns de linha de status. Para usar qualquer exemplo:- Salve o script em um arquivo como
~/.claude/statusline.sh(ou.py/.js) - Torne-o executável:
chmod +x ~/.claude/statusline.sh - Adicione o caminho às suas configurações
jq para analisar JSON. Python e Node.js têm análise JSON integrada.
Uso da janela de contexto
Exiba o modelo atual e o uso da janela de contexto com uma barra de progresso visual. Cada script lê JSON de stdin, extrai o campoused_percentage e constrói uma barra de 10 caracteres onde blocos preenchidos (▓) representam o uso:

Status do git com cores
Mostre a ramificação git com indicadores codificados por cores para arquivos preparados e modificados. Este script usa códigos de escape ANSI para cores de terminal:\033[32m é verde, \033[33m é amarelo e \033[0m redefine para padrão.

Rastreamento de custo e duração
Rastreie os custos de API e o tempo decorrido da sua sessão. O campocost.total_cost_usd acumula o custo estimado de todas as chamadas de API na sessão atual. O campo cost.total_duration_ms mede o tempo total decorrido desde o início da sessão, enquanto cost.total_api_duration_ms rastreia apenas o tempo gasto aguardando respostas de API.
Cada script formata o custo como moeda e converte milissegundos em minutos e segundos:

Exibir múltiplas linhas
Seu script pode exibir múltiplas linhas para criar uma exibição mais rica. Cada instruçãoecho produz uma linha separada na área de status.

print ou echo cria uma linha separada:
Links clicáveis
Este exemplo cria um link clicável para seu repositório GitHub. Ele lê a URL remota do git, converte o formato SSH para HTTPS comsed e envolve o nome do repositório em códigos de escape OSC 8. Mantenha Cmd (macOS) ou Ctrl (Windows/Linux) pressionado e clique para abrir o link em seu navegador.

printf '%b' que interpreta escapes de barra invertida de forma mais confiável que echo -e em diferentes shells:
Uso de limite de taxa
Exiba o uso do limite de taxa de assinatura Claude.ai na linha de status. O objetorate_limits contém five_hour (janela móvel de 5 horas) e seven_day (janelas semanais). Cada janela fornece used_percentage (0-100) e resets_at (segundos de época Unix quando a janela é redefinida).
Este campo está presente apenas para assinantes Claude.ai (Pro/Max) após a primeira resposta de API. Cada script trata o campo ausente graciosamente:
Cache de operações caras
Seu script de linha de status é executado frequentemente durante sessões ativas. Comandos comogit status ou git diff podem ser lentos, especialmente em repositórios grandes. Este exemplo armazena em cache informações do git em um arquivo temporário e apenas as atualiza a cada 5 segundos.
O nome do arquivo de cache precisa ser estável em invocações de linha de status dentro de uma sessão, mas único em sessões para que sessões simultâneas em repositórios diferentes não leiam o estado git em cache uma da outra. Identificadores baseados em processo como $$, os.getpid() ou process.pid mudam a cada invocação e derrotam o cache. Use o session_id da entrada JSON em vez disso: é estável para a vida útil de uma sessão e único por sessão.
Cada script verifica se o arquivo de cache está ausente ou mais antigo que 5 segundos antes de executar comandos git:
Configuração do Windows
No Windows, o Claude Code executa comandos de linha de status através do Git Bash quando o Git Bash está instalado, ou através do PowerShell quando o Git Bash está ausente. Para executar um script PowerShell como sua linha de status, invoque-o viapowershell; isso funciona a partir de qualquer shell:
Linhas de status de subagente
A configuraçãosubagentStatusLine renderiza um corpo de linha personalizado para cada subagente mostrado no painel de agente abaixo do prompt. Use-a para substituir a linha padrão name · description · token count pela sua própria formatação.
columns (a largura de linha utilizável) e um array tasks, onde cada tarefa tem id, name, type, status, description, label, startTime, tokenCount, tokenSamples e cwd.
Escreva uma linha JSON para stdout por linha que você queira substituir, na forma {"id": "<task id>", "content": "<row body>"}. A string content é renderizada como está, incluindo cores ANSI e hiperlinks OSC 8. Omita o id de uma tarefa para manter a renderização padrão para essa linha; emita uma string content vazia para ocultá-la.
Os mesmos portões de confiança e disableAllHooks que se aplicam a statusLine se aplicam aqui. Plugins podem enviar um subagentStatusLine padrão em seu settings.json.
Dicas
- Teste com entrada simulada:
echo '{"model":{"display_name":"Opus"},"workspace":{"current_dir":"/home/user/project"},"context_window":{"used_percentage":25},"session_id":"test-session-abc"}' | ./statusline.sh - Mantenha a saída curta: a barra de status tem largura limitada, então saída longa pode ser truncada ou quebrada de forma estranha
- Cache de operações lentas: seu script é executado frequentemente durante sessões ativas, então comandos como
git statuspodem causar atraso. Consulte o exemplo de cache para saber como lidar com isso.
Solução de problemas
Linha de status não aparecendo- Verifique se seu script é executável:
chmod +x ~/.claude/statusline.sh - Verifique se seu script produz saída para stdout, não stderr
- Execute seu script manualmente para verificar se produz saída
- Se
disableAllHooksestiver definido comotrueem suas configurações, a linha de status também será desabilitada. Remova esta configuração ou defina-a comofalsepara reabilitar. - Execute
claude --debugpara registrar o código de saída e stderr da primeira invocação de linha de status em uma sessão - Peça ao Claude para ler seu arquivo de configurações e executar o comando
statusLinediretamente para descobrir erros
-- ou valores vazios
- Os campos podem ser
nullantes da primeira resposta de API ser concluída - Trate valores nulos em seu script com fallbacks como
// 0em jq - Reinicie o Claude Code se os valores permanecerem vazios após várias mensagens
- Use
used_percentagepara o estado de contexto mais simples e preciso - A porcentagem de contexto pode diferir da saída
/contextdevido a quando cada uma é calculada
- Verifique se seu terminal suporta hiperlinks OSC 8 (iTerm2, Kitty, WezTerm)
- Terminal.app não suporta links clicáveis
-
Se o texto do link aparecer mas não for clicável, o Claude Code pode não ter detectado suporte a hiperlink em seu terminal. Isto afeta comumente Windows Terminal e outros emuladores não na lista de detecção automática. Defina a variável de ambiente
FORCE_HYPERLINKpara substituir a detecção antes de iniciar o Claude Code:No PowerShell, defina a variável na sessão atual primeiro: - Sessões SSH e tmux podem remover sequências OSC dependendo da configuração
-
Se sequências de escape aparecerem como texto literal como
\e]8;;, useprintf '%b'em vez deecho -epara manipulação de escape mais confiável
- Sequências de escape complexas (cores ANSI, links OSC 8) podem ocasionalmente causar saída corrompida se se sobrepuserem com outras atualizações da interface
- Se você vir texto corrompido, tente simplificar seu script para saída de texto simples
- Linhas de status de múltiplas linhas com códigos de escape são mais propensas a problemas de renderização do que texto simples de linha única
- O comando de linha de status só é executado se você aceitou o diálogo de confiança do espaço de trabalho para o diretório atual. Como
statusLineexecuta um comando de shell, ele requer a mesma aceitação de confiança que hooks e outras configurações que executam shell. - Se a confiança não for aceita, você verá a notificação
statusline skipped · restart to fixem vez da saída da sua linha de status. Reinicie o Claude Code e aceite o prompt de confiança para habilitá-lo.
- Scripts que saem com códigos diferentes de zero ou não produzem saída fazem a linha de status ficar em branco
- Scripts lentos bloqueiam a linha de status de atualizar até que sejam concluídos. Mantenha scripts rápidos para evitar saída obsoleta.
- Se uma nova atualização for acionada enquanto um script lento está em execução, o script em andamento é cancelado
- Teste seu script independentemente com entrada simulada antes de configurá-lo
- Notificações do sistema como erros de servidor MCP e atualizações automáticas são exibidas no lado direito da mesma linha que sua linha de status. Notificações transitórias como o aviso de contexto baixo também circulam por esta área.
- Habilitar modo verbose adiciona um contador de tokens a esta área
- Em terminais estreitos, essas notificações podem truncar sua saída de linha de status