Pular para o conteúdo principal

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.

Claude Code funciona em qualquer terminal sem configuração. Esta página é para quando algo específico não está se comportando da forma que você espera. Encontre seu sintoma abaixo. Se tudo já se sente certo, você não precisa desta página. Esta página é sobre fazer seu terminal enviar os sinais corretos para Claude Code. Para alterar quais teclas Claude Code responde, consulte atalhos de teclado em vez disso.

Inserir prompts multilinhas

Pressionar Enter envia sua mensagem. Para adicionar uma quebra de linha sem enviar, pressione Ctrl+J, ou digite \ e depois pressione Enter. Ambos funcionam em todos os terminais sem configuração. Na maioria dos terminais você também pode pressionar Shift+Enter, mas o suporte varia por emulador de terminal:
TerminalShift+Enter para quebra de linha
Ghostty, Kitty, iTerm2, WezTerm, Warp, Apple Terminal, Windows TerminalFunciona sem configuração
VS Code, Cursor, Windsurf, Alacritty, ZedExecute /terminal-setup uma vez
gnome-terminal, JetBrains IDEs como PyCharm e Android StudioNão disponível; use Ctrl+J ou \ depois Enter
Para VS Code, Cursor, Windsurf, Alacritty e Zed, /terminal-setup escreve Shift+Enter e outros atalhos de teclado no arquivo de configuração do terminal. Em VS Code, Cursor e Windsurf, também define terminal.integrated.mouseWheelScrollSensitivity nas configurações do editor para rolagem mais suave no modo de tela cheia. As vinculações e configurações existentes são mantidas no lugar; se você vir uma mensagem como VSCode terminal Shift+Enter key binding already configured, nenhuma alteração foi feita. Execute /terminal-setup diretamente no terminal do host em vez de dentro do tmux ou screen, pois ele precisa escrever na configuração do terminal do host. Se você estiver executando dentro do tmux, Shift+Enter também requer a configuração do tmux abaixo mesmo quando o terminal externo a suporta. Para vincular quebra de linha a uma tecla diferente, ou para trocar o comportamento para que Enter insira uma quebra de linha e Shift+Enter envie, mapeie as ações chat:newline e chat:submit em seu arquivo de atalhos de teclado.

Ativar atalhos de tecla Option no macOS

Alguns atalhos do Claude Code usam a tecla Option, como Option+Enter para uma quebra de linha ou Option+P para trocar modelos. No macOS, a maioria dos terminais não envia Option como um modificador por padrão, então esses atalhos não funcionam até que você o ative. A configuração do terminal para isso geralmente é rotulada como “Use Option as Meta Key”; Meta é o nome histórico do Unix para a tecla agora rotulada como Option ou Alt.
Abra Configurações → Perfis → Teclado e marque “Use Option as Meta Key”.Se você aceitou o prompt de primeira execução do Claude Code que oferecia “Option+Enter para quebras de linha e sino visual”, isso já foi feito. Esse prompt executa /terminal-setup para você, que ativa Option como Meta e muda o sino de áudio para um flash de tela visual em seu perfil do Apple Terminal.
Para Ghostty, Kitty e outros terminais, procure por uma configuração Option-as-Alt ou Option-as-Meta no arquivo de configuração do terminal.

Obtenha um sino de terminal ou notificação

Quando Claude termina uma tarefa ou pausa para um prompt de permissão, ele dispara um evento de notificação. Exibir isso como um sino de terminal ou notificação de desktop permite que você mude para outro trabalho enquanto uma tarefa longa é executada. Por padrão, Claude Code envia uma notificação de desktop apenas em Ghostty, Kitty e iTerm2. Em outros terminais, defina preferredNotifChannel como "terminal_bell" para tocar o sino do terminal, ou configure um hook de Notificação para um som personalizado ou comando. A notificação de desktop chega à sua máquina local via SSH, portanto uma sessão remota ainda pode alertá-lo. Ghostty e Kitty a encaminham para seu centro de notificações do SO sem configuração adicional. iTerm2 requer que você ative o encaminhamento:
1

Abra as configurações de notificação do iTerm2

Vá para Configurações → Perfis → Terminal.
2

Ative alertas

Marque “Notification Center Alerts”, depois clique em “Filter Alerts” e ative “Send escape sequence-generated alerts”.
Se as notificações ainda não aparecerem, confirme que seu aplicativo de terminal tem permissão de notificação nas configurações do seu SO, e se você estiver executando dentro do tmux, ative passthrough.

Play a sound with a Notification hook

Em qualquer terminal você pode configurar um hook de Notificação para reproduzir um som ou executar um comando personalizado quando Claude precisar de sua atenção. Hooks são executados junto com a notificação de desktop em vez de substituí-la, portanto terminais que não recebem uma notificação de desktop, como Warp ou o terminal integrado do VS Code, podem usar um hook ou definir preferredNotifChannel como "terminal_bell" em vez disso. O exemplo abaixo reproduz um som do sistema no macOS. O guia vinculado tem comandos de notificação de desktop para macOS, Linux e Windows.
~/.claude/settings.json
{
  "hooks": {
    "Notification": [
      {
        "hooks": [{ "type": "command", "command": "afplay /System/Library/Sounds/Glass.aiff" }]
      }
    ]
  }
}

Configure tmux

Quando Claude Code é executado dentro do tmux, duas coisas quebram por padrão: Shift+Enter envia em vez de inserir uma quebra de linha, e notificações de desktop e a barra de progresso nunca chegam ao terminal externo. Adicione estas linhas a ~/.tmux.conf, depois execute tmux source-file ~/.tmux.conf para aplicá-las ao servidor em execução:
~/.tmux.conf
set -g allow-passthrough on
set -s extended-keys on
set -as terminal-features 'xterm*:extkeys'
A linha allow-passthrough permite que notificações e atualizações de progresso cheguem ao terminal externo em vez de serem engolidas pelo tmux. As linhas extended-keys permitem que tmux distinga Shift+Enter de Enter simples para que o atalho de quebra de linha funcione.

Corresponder ao tema de cores

Use o comando /theme, ou o seletor de tema em /config, para escolher um tema do Claude Code que corresponda ao seu terminal. Selecionar a opção auto detecta o fundo claro ou escuro do seu terminal, para que o tema siga as mudanças de aparência do SO sempre que seu terminal fizer. Claude Code não controla o esquema de cores do próprio terminal, que é definido pela aplicação de terminal. Para personalizar o que aparece na parte inferior da interface, configure uma linha de status personalizada que mostra o modelo atual, diretório de trabalho, branch do git ou outro contexto.

Criar um tema personalizado

Temas personalizados requerem Claude Code v2.1.118 ou posterior.
Além dos presets integrados, /theme lista todos os temas personalizados que você definiu e quaisquer temas contribuídos por plugins instalados. Selecione Novo tema personalizado… no final da lista para criar um interativamente: você nomeia o tema e depois escolhe tokens de cor individuais para substituir. Pressione Ctrl+E enquanto um tema personalizado está destacado para editá-lo. Cada tema personalizado é um arquivo JSON em ~/.claude/themes/. O nome do arquivo sem a extensão .json é o slug do tema, e selecionar o tema armazena custom:<slug> como sua preferência de tema. O arquivo tem três campos opcionais:
CampoTipoDescrição
namestringRótulo de exibição mostrado em /theme. Padrão é o slug do nome do arquivo
basestringPreset integrado do qual o tema começa: dark, light, dark-daltonized, light-daltonized, dark-ansi, ou light-ansi. Padrão é dark
overridesobjectMapa de nomes de tokens de cor para valores de cor. Tokens não listados aqui caem através do preset base
Valores de cor aceitam #rrggbb, #rgb, rgb(r,g,b), ansi256(n), ou ansi:<name> onde <name> é um dos 16 nomes de cores ANSI padrão como red ou cyanBright. Tokens desconhecidos e valores de cor inválidos são ignorados, portanto um erro de digitação não pode quebrar a renderização. O exemplo a seguir define um tema que mantém o preset escuro, mas recolore o acento do prompt, o texto de erro e o texto de sucesso:
~/.claude/themes/dracula.json
{
  "name": "Dracula",
  "base": "dark",
  "overrides": {
    "claude": "#bd93f9",
    "error": "#ff5555",
    "success": "#50fa7b"
  }
}
Claude Code monitora ~/.claude/themes/ e recarrega quando um arquivo muda, portanto edições feitas no seu editor se aplicam a uma sessão em execução sem necessidade de reinicialização. A referência abaixo cobre os tokens que você pode definir em overrides. O editor interativo em /theme mostra os mesmos tokens com uma visualização ao vivo, além de alguns acentos de propósito único, como cores de tela de integração, que são omitidas aqui.
O exemplo a seguir combina tokens de vários dos grupos abaixo: o acento da marca, a borda do modo de plano, os fundos de diff e o fundo da mensagem em tela cheia.
~/.claude/themes/midnight.json
{
  "name": "Midnight",
  "base": "dark",
  "overrides": {
    "claude": "#a78bfa",
    "planMode": "#38bdf8",
    "diffAdded": "#14532d",
    "diffRemoved": "#7f1d1d",
    "userMessageBackground": "#1e1b4b"
  }
}

Cores de texto e acento

Controle o acento da marca primária e as tonalidades de texto em primeiro plano usadas em toda a interface.
TokenControla
claudeAcento da marca primária, usado para o spinner e rótulo do assistente
textTexto em primeiro plano padrão
inverseTextTexto desenhado sobre um fundo colorido, como badges de status
inactiveTexto secundário como dicas, timestamps e itens desabilitados
subtleBordas fracas e texto secundário de-enfatizado
suggestionSugestões de preenchimento automático e destaque de seleção em seletores
permissionBordas de diálogo, incluindo prompts de permissão e seletores
rememberIndicadores de memória e CLAUDE.md

Cores de status

Sinalize estados de sucesso, falha e aviso em mensagens e indicadores.
TokenControla
successMensagens de sucesso e verificações aprovadas
errorMensagens de erro e falhas
warningAvisos, mensagens de cautela e a borda do modo auto
mergedStatus de pull request mesclado

Caixa de entrada e indicadores de modo

Defina a cor da borda da caixa de entrada e o acento mostrado enquanto um modo de permissão ou indicador está ativo.
TokenControla
promptBorderBorda da caixa de entrada no modo de permissão padrão
planModeAcento e borda do modo de plano
autoAcceptAcento e borda do modo aceitar-edições
bashBorderBorda da caixa de entrada ao inserir um comando shell !
ideIndicador de conexão IDE
fastModeIndicador de modo rápido

Renderização de diff

Colora código adicionado e removido em edições e revisões de arquivo.
TokenControla
diffAddedFundo de linhas adicionadas
diffRemovedFundo de linhas removidas
diffAddedDimmedFundo de contexto inalterado perto de linhas adicionadas
diffRemovedDimmedFundo de contexto inalterado perto de linhas removidas
diffAddedWordDestaque em nível de palavra dentro de uma linha adicionada
diffRemovedWordDestaque em nível de palavra dentro de uma linha removida

Modo tela cheia

Aplique apenas no modo de renderização em tela cheia, onde as mensagens têm um preenchimento de fundo.
TokenControla
userMessageBackgroundFundo atrás de suas mensagens na transcrição
userMessageBackgroundHoverFundo atrás de uma mensagem enquanto pairada ou expandida
messageActionsBackgroundFundo atrás da mensagem selecionada quando a barra de ações está aberta
bashMessageBackgroundColorFundo atrás de entradas de comando shell ! na transcrição
memoryBackgroundColorFundo atrás de entradas de memória # na transcrição
selectionBgFundo do texto selecionado com o mouse

Medidor de uso e rótulos de alto-falante

Ajuste a barra mostrada na visualização /usage e os rótulos que distinguem suas mensagens das de Claude.
TokenControla
rate_limit_fillPorção preenchida do medidor de uso
rate_limit_emptyPorção não preenchida do medidor de uso
briefLabelYouCor do rótulo You em suas mensagens
briefLabelClaudeCor do rótulo Claude em mensagens do assistente

Variantes de shimmer e cores de subagentes

Vários tokens têm uma variante de shimmer emparelhada que fornece a cor mais clara usada no gradiente animado do spinner. Substitua o shimmer junto com seu token base se a animação parecer incompatível.
  • claude e claudeShimmer
  • warning e warningShimmer
  • permission e permissionShimmer
  • promptBorder e promptBorderShimmer
  • inactive e inactiveShimmer
  • fastMode e fastModeShimmer
Cada subagente e tarefa paralela é mostrado em uma das oito cores nomeadas para que você possa diferenciá-los na transcrição. Os nomes dos tokens seguem o padrão <color>_FOR_SUBAGENTS_ONLY, onde <color> é red, blue, green, yellow, purple, orange, pink, ou cyan. Substitua estes para alterar a aparência de cada cor nomeada. Por exemplo, um subagente com color: blue em sua definição é desenhado usando o valor blue_FOR_SUBAGENTS_ONLY.As palavras-chave ultrathink e ultraplan na entrada do prompt são renderizadas com um gradiente arco-íris de sete cores. Os nomes dos tokens seguem o padrão rainbow_<color> e rainbow_<color>_shimmer, onde <color> é red, orange, yellow, green, blue, indigo, ou violet.

Switch to fullscreen rendering

Se a exibição piscar ou a posição de rolagem pular enquanto Claude está trabalhando, mude para o modo de renderização em tela cheia. Ele desenha em uma tela separada que o terminal reserva para aplicativos em tela cheia em vez de anexar ao seu scrollback normal, o que mantém o uso de memória plano e adiciona suporte a mouse para rolagem e seleção. Neste modo você rola com o mouse ou PageUp dentro do Claude Code em vez de com o scrollback nativo do seu terminal; consulte a página de tela cheia para saber como pesquisar e copiar. Execute /tui fullscreen para mudar na sessão atual com sua conversa intacta. Para torná-lo o padrão, defina a variável de ambiente CLAUDE_CODE_NO_FLICKER antes de iniciar Claude Code:
CLAUDE_CODE_NO_FLICKER=1 claude

Paste large content

Quando você cola mais de 10.000 caracteres no prompt, Claude Code reduz a entrada para um placeholder [Pasted text] para que a caixa de entrada permaneça utilizável. O conteúdo completo ainda é enviado para Claude quando você envia. O terminal integrado do VS Code pode descartar caracteres de colagens muito grandes antes de chegarem ao Claude Code, então prefira fluxos de trabalho baseados em arquivo lá. Para entradas muito grandes, como arquivos inteiros ou logs longos, escreva o conteúdo em um arquivo e peça ao Claude para lê-lo em vez de colar. Isso mantém a transcrição da conversa legível e permite que Claude referencie o arquivo por caminho em turnos posteriores.

Editar prompts com atalhos de teclado Vim

Claude Code inclui um modo de edição estilo Vim para a entrada do prompt. Ative-o através de /config → Editor mode, ou definindo editorMode como "vim" em ~/.claude/settings.json. Defina Editor mode de volta para normal para desativá-lo. O modo Vim suporta um subconjunto de motions de modo NORMAL e VISUAL e operadores, como navegação hjkl, seleção v/V, e d/c/y com objetos de texto. Consulte a referência do modo editor Vim para a tabela de teclas completa. Motions de Vim não são remapeáveis através do arquivo de atalhos de teclado. Pressionar Enter ainda envia seu prompt no modo INSERT, diferentemente do Vim padrão. Use o ou O no modo NORMAL, ou Ctrl+J, para inserir uma quebra de linha em vez disso.
  • Interactive mode: referência completa de atalhos de teclado e a tabela de teclas Vim
  • Keybindings: remapeie qualquer atalho do Claude Code, incluindo Enter e Shift+Enter
  • Fullscreen rendering: detalhes sobre rolagem, pesquisa e cópia no modo tela cheia
  • Hooks guide: mais exemplos de hook de Notificação para Linux e Windows
  • Troubleshooting: correções para problemas fora da configuração do terminal