- 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.
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, 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. 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 |
cost.total_cost_usd | Costo total de la sesión en USD |
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 acumulativos en toda la 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. |
session_id | Identificador único de sesión |
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 o INSERT) 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):
vim: 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 hooks
null:context_window.current_usage:nullantes de la primera llamada a API en una sesióncontext_window.used_percentage,context_window.remaining_percentage: pueden sernullal principio de la sesión
Campos de ventana de contexto
El objetocontext_window proporciona dos formas de rastrear el uso de contexto:
- Totales acumulativos (
total_input_tokens,total_output_tokens): suma de todos los tokens en toda la sesión, útil para rastrear el consumo total - Uso actual (
current_usage): conteos de tokens de la llamada a API más reciente, úsalo para un porcentaje de contexto preciso ya que refleja el estado real del contexto
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.
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 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:
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.
Usa un nombre de archivo de caché estable y fijo como /tmp/statusline-git-cache. Cada invocación de línea de estado se ejecuta como un nuevo proceso, por lo que identificadores basados en procesos como $$, os.getpid(), o process.pid producen un valor diferente cada vez y el caché nunca se reutiliza.
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. Puedes invocar PowerShell desde ese shell:Consejos
- Prueba con entrada simulada:
echo '{"model":{"display_name":"Opus"},"context_window":{"used_percentage":25}}' | ./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 un estado de contexto preciso en lugar de totales acumulativos - Los
total_input_tokensytotal_output_tokensson acumulativos en toda la sesión y pueden exceder el tamaño de la ventana de contexto - 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
- 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
- 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, actualizaciones automáticas y advertencias de tokens se muestran en el lado derecho de la misma fila que tu línea de estado
- 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