La línea de estado es una barra personalizable en la parte inferior de Claude Code que ejecuta cualquier script de shell que configures. Recibe datos de sesión JSON en stdin y muestra lo que tu script imprime, dándote una vista persistente y de un vistazo del uso de contexto, costos, estado de git, o cualquier otra cosa que desees rastrear. Las líneas de estado son útiles cuando: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.
- Deseas monitorear el uso de la ventana de contexto mientras trabajas
- Necesitas rastrear los costos de la sesión
- Trabajas en múltiples sesiones y necesitas distinguirlas
- Deseas que la rama de git y el estado siempre sean visibles

Configurar una línea de estado
Usa el comando/statusline para que Claude Code genere un script para ti, o crea manualmente un script y agrégalo a tu configuración.
Usar el comando /statusline
El comando/statusline acepta instrucciones en lenguaje natural que describen lo que deseas mostrar. Claude Code genera un archivo de script en ~/.claude/ y actualiza tu configuración automáticamente:
Configurar manualmente una línea de estado
Agrega un campostatusLine a tu configuración de usuario (~/.claude/settings.json, donde ~ es tu directorio de inicio) o configuración del proyecto. Establece type en "command" y apunta command a una ruta de script o un comando de shell en línea. Para un tutorial completo sobre cómo crear un script, consulta Construir una línea de estado paso a paso.
command se ejecuta en un shell, por lo que también puedes usar comandos en línea en lugar de un archivo de script. Este ejemplo usa jq para analizar la entrada JSON y mostrar el nombre del modelo y el porcentaje de contexto:
padding opcional agrega espaciado horizontal adicional (en caracteres) al contenido de la línea de estado. Por defecto es 0. Este relleno se suma al espaciado integrado de la interfaz, por lo que controla la indentación relativa en lugar de la distancia absoluta desde el borde de la terminal.
El campo refreshInterval opcional vuelve a ejecutar tu comando cada N segundos además de las actualizaciones impulsadas por eventos. El mínimo es 1. Establece esto cuando tu línea de estado muestra datos basados en tiempo, como un reloj, o cuando los subagentes de fondo cambian el estado de git mientras la sesión principal está inactiva. Déjalo sin establecer para ejecutar solo en eventos.
El campo hideVimModeIndicator opcional suprime el texto integrado -- INSERT -- debajo del prompt. Establece esto en true cuando tu script renderiza vim.mode por sí mismo, para que el modo no se muestre dos veces.
Desactivar la línea de estado
Ejecuta/statusline y pídele que elimine o borre tu línea de estado (por ejemplo, /statusline delete, /statusline clear, /statusline remove it). También puedes eliminar manualmente el campo statusLine de tu settings.json.
Construir una línea de estado paso a paso
Este tutorial muestra lo que está sucediendo bajo el capó creando manualmente una línea de estado que muestra el modelo actual, el directorio de trabajo y el porcentaje de uso de la ventana de contexto.Ejecutar
/statusline con una descripción de lo que deseas configura todo esto automáticamente para ti.
Crear un script que lea JSON e imprima salida
Claude Code envía datos JSON a tu script a través de stdin. Este script usa
jq, un analizador JSON de línea de comandos que es posible que necesites instalar, para extraer el nombre del modelo, el directorio y el porcentaje de contexto, luego imprime una línea formateada.Guarda esto en ~/.claude/statusline.sh (donde ~ es tu directorio de inicio, como /Users/username en macOS o /home/username en Linux):Agregar a la configuración
Dile a Claude Code que ejecute tu script como la línea de estado. Agrega esta configuración a Tu línea de estado aparece en la parte inferior de la interfaz. La configuración se recarga automáticamente, pero los cambios no aparecerán hasta tu próxima interacción con Claude Code.
~/.claude/settings.json, que establece type en "command" (lo que significa “ejecutar este comando de shell”) y apunta command a tu script:Cómo funcionan las líneas de estado
Claude Code ejecuta tu script y canaliza datos de sesión JSON a través de stdin. Tu script lee el JSON, extrae lo que necesita e imprime texto a stdout. Claude Code muestra lo que tu script imprime. Cuándo se actualiza Tu script se ejecuta después de cada nuevo mensaje del asistente, después de que/compact finaliza, cuando cambia el modo de permiso, o cuando se activa/desactiva el modo vim. Las actualizaciones se debounce en 300ms, lo que significa que los cambios rápidos se agrupan y tu script se ejecuta una vez que las cosas se estabilizan. Si una nueva actualización se activa mientras tu script aún se está ejecutando, la ejecución en vuelo se cancela. Si editas tu script, los cambios no aparecerán hasta que tu próxima interacción con Claude Code active una actualización.
Estos disparadores pueden quedarse en silencio cuando la sesión principal está inactiva, por ejemplo mientras un coordinador espera en subagentes de fondo. Para mantener segmentos basados en tiempo o de fuentes externas actuales durante períodos inactivos, establece refreshInterval para también volver a ejecutar el comando en un temporizador fijo.
Lo que tu script puede generar
- Múltiples líneas: cada declaración
echooprintse muestra como una fila separada. Consulta el ejemplo de múltiples líneas. - Colores: usa códigos de escape ANSI como
\033[32mpara verde (la terminal debe admitirlos). Consulta el ejemplo de estado de git. - Enlaces: usa secuencias de escape OSC 8 para hacer que el texto sea clickeable (Cmd+clic en macOS, Ctrl+clic en Windows/Linux). Requiere una terminal que admita hipervínculos como iTerm2, Kitty o WezTerm. Consulta el ejemplo de enlaces clickeables.
La línea de estado se ejecuta localmente y no consume tokens de API. Se oculta temporalmente durante ciertas interacciones de la interfaz, incluidas sugerencias de autocompletado, el menú de ayuda y solicitudes de permiso.
Datos disponibles
Claude Code envía los siguientes campos JSON a tu script a través de stdin:| Campo | Descripción |
|---|---|
model.id, model.display_name | Identificador del modelo actual y nombre para mostrar |
cwd, workspace.current_dir | Directorio de trabajo actual. Ambos campos contienen el mismo valor; workspace.current_dir es preferido para consistencia con workspace.project_dir. |
workspace.project_dir | Directorio donde se lanzó Claude Code, que puede diferir de cwd si el directorio de trabajo cambia durante una sesión |
workspace.added_dirs | Directorios adicionales agregados a través de /add-dir o --add-dir. Array vacío si no se ha agregado ninguno |
workspace.git_worktree | Nombre de git worktree cuando el directorio actual está dentro de un worktree vinculado creado con git worktree add. Ausente en el árbol de trabajo principal. Poblado para cualquier git worktree, a diferencia de worktree.* que se aplica solo a sesiones --worktree |
cost.total_cost_usd | Costo total estimado de la sesión en USD, calculado del lado del cliente. Puede diferir de tu factura real |
cost.total_duration_ms | Tiempo total transcurrido desde que comenzó la sesión, en milisegundos |
cost.total_api_duration_ms | Tiempo total dedicado a esperar respuestas de API en milisegundos |
cost.total_lines_added, cost.total_lines_removed | Líneas de código cambiadas |
context_window.total_input_tokens, context_window.total_output_tokens | Conteos de tokens actualmente en la ventana de contexto, de la respuesta de API más reciente. La entrada incluye lecturas y escrituras de caché. Antes de v2.1.132 estos eran totales acumulativos de sesión |
context_window.context_window_size | Tamaño máximo de la ventana de contexto en tokens. 200000 por defecto, o 1000000 para modelos con contexto extendido. |
context_window.used_percentage | Porcentaje precalculado de ventana de contexto utilizada |
context_window.remaining_percentage | Porcentaje precalculado de ventana de contexto restante |
context_window.current_usage | Conteos de tokens de la última llamada a API, descritos en campos de ventana de contexto |
exceeds_200k_tokens | Si el conteo total de tokens (tokens de entrada, caché y salida combinados) de la respuesta de API más reciente excede 200k. Este es un umbral fijo independientemente del tamaño real de la ventana de contexto. |
effort.level | Nivel de esfuerzo de razonamiento actual (low, medium, high, xhigh, o max). Refleja el valor de sesión en vivo, incluidos cambios de /effort a mitad de sesión. Ausente cuando el modelo actual no admite el parámetro de esfuerzo |
thinking.enabled | Si el pensamiento extendido está habilitado para la sesión |
rate_limits.five_hour.used_percentage, rate_limits.seven_day.used_percentage | Porcentaje del límite de velocidad de 5 horas o 7 días consumido, de 0 a 100 |
rate_limits.five_hour.resets_at, rate_limits.seven_day.resets_at | Segundos de época Unix cuando se reinicia la ventana de límite de velocidad de 5 horas o 7 días |
session_id | Identificador único de sesión |
session_name | Nombre de sesión personalizado establecido con la bandera --name o /rename. Ausente si no se ha establecido un nombre personalizado |
transcript_path | Ruta al archivo de transcripción de conversación |
version | Versión de Claude Code |
output_style.name | Nombre del estilo de salida actual |
vim.mode | Modo vim actual (NORMAL, INSERT, VISUAL, o VISUAL LINE) cuando el modo vim está habilitado |
agent.name | Nombre del agente cuando se ejecuta con la bandera --agent o configuración de agente configurada |
worktree.name | Nombre del worktree activo. Presente solo durante sesiones --worktree |
worktree.path | Ruta absoluta al directorio del worktree |
worktree.branch | Nombre de rama de Git para el worktree (por ejemplo, "worktree-my-feature"). Ausente para worktrees basados en hooks |
worktree.original_cwd | El directorio en el que estaba Claude antes de entrar en el worktree |
worktree.original_branch | Rama de Git extraída antes de entrar en el worktree. Ausente para worktrees basados en hooks |
Esquema JSON completo
Esquema JSON completo
Tu comando de línea de estado recibe esta estructura JSON a través de stdin:Campos que pueden estar ausentes (no presentes en JSON):
session_name: aparece solo cuando se ha establecido un nombre personalizado con--nameo/renameworkspace.git_worktree: aparece solo cuando el directorio actual está dentro de un git worktree vinculadoeffort: aparece solo cuando el modelo actual admite el parámetro de esfuerzo de razonamientovim: aparece solo cuando el modo vim está habilitadoagent: aparece solo cuando se ejecuta con la bandera--agento configuración de agente configuradaworktree: aparece solo durante sesiones--worktree. Cuando está presente,branchyoriginal_branchtambién pueden estar ausentes para worktrees basados en hooksrate_limits: aparece solo para suscriptores de Claude.ai (Pro/Max) después de la primera respuesta de API en la sesión. Cada ventana (five_hour,seven_day) puede estar independientemente ausente. Usajq -r '.rate_limits.five_hour.used_percentage // empty'para manejar la ausencia con elegancia.
null:context_window.current_usage:nullantes de la primera llamada a API en una sesión, y nuevamente después de/compacthasta que la siguiente llamada a API lo repueblacontext_window.used_percentage,context_window.remaining_percentage: pueden sernullal principio de la sesión
Campos de ventana de contexto
El objetocontext_window describe la ventana de contexto en vivo de la respuesta de API más reciente. A partir de v2.1.132, total_input_tokens y total_output_tokens reflejan el uso actual del contexto, no totales acumulativos de sesión.
- Totales combinados (
total_input_tokens,total_output_tokens): tokens actualmente en la ventana de contexto.total_input_tokenses la suma deinput_tokens,cache_creation_input_tokens, ycache_read_input_tokens;total_output_tokensson los tokens de salida de la respuesta más reciente. Ambos son0antes de la primera respuesta de API. - Uso por componente (
current_usage): los mismos conteos de tokens desglosados por categoría. Usa esto cuando necesites separar los aciertos de caché de la entrada fresca.
current_usage contiene:
input_tokens: tokens de entrada en contexto actualoutput_tokens: tokens de salida generadoscache_creation_input_tokens: tokens escritos en cachécache_read_input_tokens: tokens leídos del caché
used_percentage se calcula solo a partir de tokens de entrada: input_tokens + cache_creation_input_tokens + cache_read_input_tokens. No incluye output_tokens.
Si calculas el porcentaje de contexto manualmente desde current_usage, usa la misma fórmula de solo entrada para coincidir con used_percentage.
El objeto current_usage es null antes de la primera llamada a API en una sesión, y nuevamente inmediatamente después de /compact hasta que la siguiente llamada a API lo repuebla.
Ejemplos
Estos ejemplos muestran patrones comunes de línea de estado. Para usar cualquier ejemplo:- Guarda el script en un archivo como
~/.claude/statusline.sh(o.py/.js) - Hazlo ejecutable:
chmod +x ~/.claude/statusline.sh - Agrega la ruta a tu configuración
jq para analizar JSON. Python y Node.js tienen análisis JSON integrado.
Uso de ventana de contexto
Muestra el modelo actual y el uso de la ventana de contexto con una barra de progreso visual. Cada script lee JSON desde stdin, extrae el campoused_percentage y construye una barra de 10 caracteres donde los bloques rellenos (▓) representan el uso:

Estado de git con colores
Muestra la rama de git con indicadores codificados por colores para archivos preparados y modificados. Este script usa códigos de escape ANSI para colores de terminal:\033[32m es verde, \033[33m es amarillo, y \033[0m restablece al predeterminado.

Seguimiento de costos y duración
Rastrea los costos de API de tu sesión y el tiempo transcurrido. El campocost.total_cost_usd acumula el costo estimado de todas las llamadas a API en la sesión actual. El campo cost.total_duration_ms mide el tiempo total transcurrido desde que comenzó la sesión, mientras que cost.total_api_duration_ms rastrea solo el tiempo dedicado a esperar respuestas de API.
Cada script formatea el costo como moneda y convierte milisegundos a minutos y segundos:

Mostrar múltiples líneas
Tu script puede generar múltiples líneas para crear una pantalla más rica. Cada declaraciónecho produce una fila separada en el área de estado.

print o echo crea una fila separada:
Enlaces clickeables
Este ejemplo crea un enlace clickeable a tu repositorio de GitHub. Lee la URL remota de git, convierte el formato SSH a HTTPS consed, y envuelve el nombre del repositorio en códigos de escape OSC 8. Mantén presionado Cmd (macOS) o Ctrl (Windows/Linux) y haz clic para abrir el enlace en tu navegador.

printf '%b' que interpreta escapes de barra invertida de manera más confiable que echo -e en diferentes shells:
Uso de límite de velocidad
Muestra el uso del límite de velocidad de suscripción de Claude.ai en la línea de estado. El objetorate_limits contiene five_hour (ventana móvil de 5 horas) y seven_day (ventanas semanales). Cada ventana proporciona used_percentage (0-100) y resets_at (segundos de época Unix cuando se reinicia la ventana).
Este campo solo está presente para suscriptores de Claude.ai (Pro/Max) después de la primera respuesta de API. Cada script maneja el campo ausente con elegancia:
Cachear operaciones costosas
Tu script de línea de estado se ejecuta frecuentemente durante sesiones activas. Comandos comogit status o git diff pueden ser lentos, especialmente en repositorios grandes. Este ejemplo cachea información de git en un archivo temporal y solo la actualiza cada 5 segundos.
El nombre del archivo de caché debe ser estable en las invocaciones de línea de estado dentro de una sesión, pero único en sesiones para que las sesiones concurrentes en diferentes repositorios no lean el estado de git cacheado de cada una. Los identificadores basados en procesos como $$, os.getpid(), o process.pid cambian en cada invocación y anulan el caché. Usa el session_id de la entrada JSON en su lugar: es estable durante la vida útil de una sesión y único por sesión.
Cada script verifica si el archivo de caché falta o es más antiguo que 5 segundos antes de ejecutar comandos de git:
Configuración de Windows
En Windows, Claude Code ejecuta comandos de línea de estado a través de Git Bash cuando Git Bash está instalado, o a través de PowerShell cuando Git Bash está ausente. Para ejecutar un script de PowerShell como tu línea de estado, invócalo mediantepowershell; esto funciona desde cualquier shell:
Líneas de estado de subagentes
La configuraciónsubagentStatusLine renderiza un cuerpo de fila personalizado para cada subagente mostrado en el panel de agentes debajo del prompt. Úsalo para reemplazar la fila predeterminada name · description · token count con tu propio formato.
columns (el ancho de fila utilizable) y un array tasks, donde cada tarea tiene id, name, type, status, description, label, startTime, tokenCount, tokenSamples, y cwd.
Escribe una línea JSON a stdout por cada fila que desees anular, en la forma {"id": "<task id>", "content": "<row body>"}. La cadena content se renderiza tal cual, incluidos colores ANSI e hipervínculos OSC 8. Omite el id de una tarea para mantener el renderizado predeterminado para esa fila; emite una cadena content vacía para ocultarla.
Las mismas puertas de confianza y disableAllHooks que se aplican a statusLine se aplican aquí. Los plugins pueden enviar una subagentStatusLine predeterminada en su settings.json.
Consejos
- Prueba con 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 - Mantén la salida corta: la barra de estado tiene un ancho limitado, por lo que la salida larga puede truncarse o ajustarse de manera incómoda
- Cachea operaciones lentas: tu script se ejecuta frecuentemente durante sesiones activas, por lo que comandos como
git statuspueden causar retrasos. Consulta el ejemplo de caché para saber cómo manejar esto.
Solución de problemas
La línea de estado no aparece- Verifica que tu script sea ejecutable:
chmod +x ~/.claude/statusline.sh - Comprueba que tu script genere salida a stdout, no stderr
- Ejecuta tu script manualmente para verificar que produce salida
- Si
disableAllHooksestá establecido entrueen tu configuración, la línea de estado también está deshabilitada. Elimina esta configuración o establécela enfalsepara volver a habilitarla. - Ejecuta
claude --debugpara registrar el código de salida y stderr de la primera invocación de línea de estado en una sesión - Pídele a Claude que lea tu archivo de configuración y ejecute el comando
statusLinedirectamente para exponer errores
-- o valores vacíos
- Los campos pueden ser
nullantes de que se complete la primera respuesta de API - Maneja valores nulos en tu script con valores predeterminados de respaldo como
// 0en jq - Reinicia Claude Code si los valores permanecen vacíos después de múltiples mensajes
- Usa
used_percentagepara el estado de contexto más simple y preciso - El porcentaje de contexto puede diferir de la salida
/contextdebido a cuándo se calcula cada uno
- Verifica que tu terminal admita hipervínculos OSC 8 (iTerm2, Kitty, WezTerm)
- Terminal.app no admite enlaces clickeables
-
Si el texto del enlace aparece pero no es clickeable, Claude Code puede no haber detectado soporte de hipervínculos en tu terminal. Esto afecta comúnmente a Windows Terminal y otros emuladores no en la lista de detección automática. Establece la variable de entorno
FORCE_HYPERLINKpara anular la detección antes de lanzar Claude Code:En PowerShell, establece la variable en la sesión actual primero: - Las sesiones SSH y tmux pueden eliminar secuencias OSC dependiendo de la configuración
-
Si las secuencias de escape aparecen como texto literal como
\e]8;;, usaprintf '%b'en lugar deecho -epara un manejo más confiable de escapes
- Las secuencias de escape complejas (colores ANSI, enlaces OSC 8) pueden ocasionalmente causar salida garbled si se superponen con otras actualizaciones de la interfaz
- Si ves texto corrupto, intenta simplificar tu script a salida de texto plano
- Las líneas de estado de múltiples líneas con códigos de escape son más propensas a problemas de renderizado que el texto plano de una sola línea
- El comando de línea de estado solo se ejecuta si has aceptado el diálogo de confianza del espacio de trabajo para el directorio actual. Debido a que
statusLineejecuta un comando de shell, requiere la misma aceptación de confianza que hooks y otras configuraciones que ejecutan shell. - Si la confianza no se acepta, verás la notificación
statusline skipped · restart to fixen lugar de tu salida de línea de estado. Reinicia Claude Code y acepta el mensaje de confianza para habilitarlo.
- Los scripts que salen con códigos distintos de cero o no producen salida hacen que la línea de estado se quede en blanco
- Los scripts lentos bloquean la línea de estado de actualizar hasta que se completen. Mantén los scripts rápidos para evitar salida obsoleta.
- Si una nueva actualización se activa mientras un script lento se está ejecutando, el script en vuelo se cancela
- Prueba tu script de forma independiente con entrada simulada antes de configurarlo
- Las notificaciones del sistema como errores de servidor MCP y actualizaciones automáticas se muestran en el lado derecho de la misma fila que tu línea de estado. Las notificaciones transitorias como la advertencia de contexto bajo también ciclan a través de esta área.
- Habilitar el modo verbose agrega un contador de tokens a esta área
- En terminales estrechas, estas notificaciones pueden truncar tu salida de línea de estado