- Хотите отслеживать использование контекстного окна во время работы
- Нужно отслеживать затраты сеанса
- Работаете в нескольких сеансах и нужно их различать
- Хотите, чтобы ветка git и статус всегда были видны

Настройка строки состояния
Используйте команду/statusline для автоматического создания скрипта Claude Code, или вручную создайте скрипт и добавьте его в ваши настройки.
Использование команды /statusline
Команда/statusline принимает инструкции на естественном языке, описывающие то, что вы хотите отображать. Claude Code генерирует файл скрипта в ~/.claude/ и автоматически обновляет ваши настройки:
Ручная настройка строки состояния
Добавьте полеstatusLine в ваши пользовательские настройки (~/.claude/settings.json, где ~ — это ваш домашний каталог) или настройки проекта. Установите type на "command" и укажите command на путь скрипта или встроенную команду оболочки. Для полного пошагового руководства по созданию скрипта см. Построение строки состояния пошагово.
command запускается в оболочке, поэтому вы также можете использовать встроенные команды вместо файла скрипта. Этот пример использует jq для разбора входных данных JSON и отображения имени модели и процента контекста:
padding добавляет дополнительное горизонтальное расстояние (в символах) к содержимому строки состояния. По умолчанию 0. Это заполнение добавляется к встроенному расстоянию интерфейса, поэтому оно управляет относительным отступом, а не абсолютным расстоянием от края терминала.
Отключение строки состояния
Запустите/statusline и попросите её удалить или очистить вашу строку состояния (например, /statusline delete, /statusline clear, /statusline remove it). Вы также можете вручную удалить поле statusLine из вашего settings.json.
Построение строки состояния пошагово
Это пошаговое руководство показывает, что происходит под капотом, путём ручного создания строки состояния, которая отображает текущую модель, рабочий каталог и процент использования контекстного окна.Запуск
/statusline с описанием того, что вы хотите, настраивает всё это автоматически.
Создайте скрипт, который читает JSON и выводит результат
Claude Code отправляет данные JSON в ваш скрипт через stdin. Этот скрипт использует
jq, парсер JSON командной строки, который вам может потребоваться установить, для извлечения имени модели, каталога и процента контекста, а затем выводит отформатированную строку.Сохраните это в ~/.claude/statusline.sh (где ~ — это ваш домашний каталог, например /Users/username на macOS или /home/username на Linux):Добавьте в настройки
Скажите Claude Code запустить ваш скрипт как строку состояния. Добавьте эту конфигурацию в Ваша строка состояния появляется в нижней части интерфейса. Настройки перезагружаются автоматически, но изменения не появятся до вашего следующего взаимодействия с Claude Code.
~/.claude/settings.json, которая устанавливает type на "command" (означает «запустить эту команду оболочки») и указывает command на ваш скрипт:Как работают строки состояния
Claude Code запускает ваш скрипт и передаёт данные сеанса JSON в него через stdin. Ваш скрипт читает JSON, извлекает то, что ему нужно, и выводит текст в stdout. Claude Code отображает всё, что выводит ваш скрипт. Когда это обновляется Ваш скрипт запускается после каждого нового сообщения ассистента, когда изменяется режим разрешений или когда переключается режим vim. Обновления дебаунсятся на 300 мс, что означает, что быстрые изменения объединяются вместе и ваш скрипт запускается один раз, когда всё стабилизируется. Если новое обновление срабатывает, пока ваш скрипт всё ещё работает, выполнение в полёте отменяется. Если вы отредактируете свой скрипт, изменения не появятся до вашего следующего взаимодействия с Claude Code, которое срабатывает обновление. Что может выводить ваш скрипт- Несколько строк: каждый оператор
echoилиprintотображается как отдельная строка. См. пример многострочности. - Цвета: используйте коды экранирования ANSI, такие как
\033[32mдля зелёного (терминал должен их поддерживать). См. пример статуса git. - Ссылки: используйте последовательности экранирования OSC 8 для создания кликабельного текста (Cmd+клик на macOS, Ctrl+клик на Windows/Linux). Требуется терминал, поддерживающий гиперссылки, такой как iTerm2, Kitty или WezTerm. См. пример кликабельных ссылок.
Строка состояния работает локально и не потребляет токены API. Она временно скрывается во время определённых взаимодействий с пользовательским интерфейсом, включая предложения автодополнения, меню справки и запросы разрешений.
Доступные данные
Claude Code отправляет следующие поля JSON в ваш скрипт через stdin:| Поле | Описание |
|---|---|
model.id, model.display_name | Текущий идентификатор модели и отображаемое имя |
cwd, workspace.current_dir | Текущий рабочий каталог. Оба поля содержат одно и то же значение; workspace.current_dir предпочтительнее для согласованности с workspace.project_dir. |
workspace.project_dir | Каталог, в котором был запущен Claude Code, который может отличаться от cwd, если рабочий каталог изменяется во время сеанса |
cost.total_cost_usd | Общая стоимость сеанса в USD |
cost.total_duration_ms | Общее реальное время с момента начала сеанса в миллисекундах |
cost.total_api_duration_ms | Общее время, потраченное на ожидание ответов API в миллисекундах |
cost.total_lines_added, cost.total_lines_removed | Строки кода, которые были изменены |
context_window.total_input_tokens, context_window.total_output_tokens | Совокупные подсчёты токенов во всём сеансе |
context_window.context_window_size | Максимальный размер контекстного окна в токенах. По умолчанию 200000 или 1000000 для моделей с расширенным контекстом. |
context_window.used_percentage | Предварительно рассчитанный процент использованного контекстного окна |
context_window.remaining_percentage | Предварительно рассчитанный процент оставшегося контекстного окна |
context_window.current_usage | Подсчёты токенов из последнего вызова API, описанные в полях контекстного окна |
exceeds_200k_tokens | Превышает ли общее количество токенов (входные, кэшированные и выходные токены в сумме) из последнего ответа API 200k. Это фиксированный порог независимо от фактического размера контекстного окна. |
session_id | Уникальный идентификатор сеанса |
transcript_path | Путь к файлу стенограммы разговора |
version | Версия Claude Code |
output_style.name | Имя текущего стиля вывода |
vim.mode | Текущий режим vim (NORMAL или INSERT), когда режим vim включен |
agent.name | Имя агента при запуске с флагом --agent или настроенными параметрами агента |
worktree.name | Имя активного worktree. Присутствует только во время сеансов --worktree |
worktree.path | Абсолютный путь к каталогу worktree |
worktree.branch | Имя ветки Git для worktree (например, "worktree-my-feature"). Отсутствует для worktrees на основе hooks |
worktree.original_cwd | Каталог, в котором находился Claude перед входом в worktree |
worktree.original_branch | Ветка Git, проверенная перед входом в worktree. Отсутствует для worktrees на основе hooks |
Полная схема JSON
Полная схема JSON
Ваша команда строки состояния получает эту структуру JSON через stdin:Поля, которые могут отсутствовать (не присутствуют в JSON):
vim: появляется только когда режим vim включенagent: появляется только при запуске с флагом--agentили настроенными параметрами агентаworktree: появляется только во время сеансов--worktree. Когда присутствует,branchиoriginal_branchтакже могут отсутствовать для worktrees на основе hooks
null:context_window.current_usage:nullперед первым вызовом API в сеансеcontext_window.used_percentage,context_window.remaining_percentage: могут бытьnullв начале сеанса
Поля контекстного окна
Объектcontext_window предоставляет два способа отслеживания использования контекста:
- Совокупные итоги (
total_input_tokens,total_output_tokens): сумма всех токенов во всём сеансе, полезна для отслеживания общего потребления - Текущее использование (
current_usage): подсчёты токенов из последнего вызова API, используйте это для точного процента контекста, так как это отражает фактическое состояние контекста
current_usage содержит:
input_tokens: входные токены в текущем контекстеoutput_tokens: выходные токены, которые были сгенерированыcache_creation_input_tokens: токены, записанные в кэшcache_read_input_tokens: токены, прочитанные из кэша
used_percentage рассчитывается только из входных токенов: input_tokens + cache_creation_input_tokens + cache_read_input_tokens. Оно не включает output_tokens.
Если вы рассчитываете процент контекста вручную из current_usage, используйте ту же формулу только для входных данных, чтобы соответствовать used_percentage.
Объект current_usage равен null перед первым вызовом API в сеансе.
Примеры
Эти примеры показывают распространённые паттерны строк состояния. Чтобы использовать любой пример:- Сохраните скрипт в файл, например
~/.claude/statusline.sh(или.py/.js) - Сделайте его исполняемым:
chmod +x ~/.claude/statusline.sh - Добавьте путь в ваши настройки
jq для разбора JSON. Python и Node.js имеют встроенный разбор JSON.
Использование контекстного окна
Отобразите текущую модель и использование контекстного окна с визуальной полосой прогресса. Каждый скрипт читает JSON из stdin, извлекает полеused_percentage и строит 10-символьную полосу, где заполненные блоки (▓) представляют использование:

Статус git с цветами
Показывает ветку git с цветовыми индикаторами для подготовленных и изменённых файлов. Этот скрипт использует коды экранирования ANSI для цветов терминала:\033[32m — зелёный, \033[33m — жёлтый и \033[0m — сброс на значение по умолчанию.

Отслеживание затрат и продолжительности
Отслеживайте затраты API вашего сеанса и прошедшее время. Полеcost.total_cost_usd накапливает стоимость всех вызовов API в текущем сеансе. Поле cost.total_duration_ms измеряет общее прошедшее время с момента начала сеанса, а cost.total_api_duration_ms отслеживает только время, потраченное на ожидание ответов API.
Каждый скрипт форматирует стоимость как валюту и преобразует миллисекунды в минуты и секунды:

Отображение нескольких строк
Ваш скрипт может выводить несколько строк для создания более богатого отображения. Каждый операторecho создаёт отдельную строку в области состояния.

print или echo создаёт отдельную строку:
Кликабельные ссылки
Этот пример создаёт кликабельную ссылку на ваш репозиторий GitHub. Он читает URL удалённого репозитория, преобразует формат SSH в HTTPS с помощьюsed и оборачивает имя репозитория в коды экранирования OSC 8. Удерживайте Cmd (macOS) или Ctrl (Windows/Linux) и нажмите, чтобы открыть ссылку в браузере.

printf '%b', которая более надёжно интерпретирует экранирующие последовательности, чем echo -e в разных оболочках:
Кэширование дорогостоящих операций
Ваш скрипт строки состояния запускается часто во время активных сеансов. Команды, такие какgit status или git diff, могут быть медленными, особенно в больших репозиториях. Этот пример кэширует информацию git во временный файл и обновляет её только каждые 5 секунд.
Используйте стабильное, фиксированное имя файла кэша, например /tmp/statusline-git-cache. Каждый вызов строки состояния запускается как новый процесс, поэтому идентификаторы на основе процесса, такие как $$, os.getpid() или process.pid, дают разное значение каждый раз и кэш никогда не переиспользуется.
Каждый скрипт проверяет, отсутствует ли файл кэша или он старше 5 секунд, перед запуском команд git:
Конфигурация Windows
На Windows Claude Code запускает команды строки состояния через Git Bash. Вы можете вызвать PowerShell из этой оболочки:Советы
- Тестирование с макетными входными данными:
echo '{"model":{"display_name":"Opus"},"context_window":{"used_percentage":25}}' | ./statusline.sh - Сохраняйте вывод коротким: строка состояния имеет ограниченную ширину, поэтому длинный вывод может быть обрезан или неправильно обёрнут
- Кэшируйте медленные операции: ваш скрипт запускается часто во время активных сеансов, поэтому команды, такие как
git status, могут вызвать задержку. См. пример кэширования для того, как это обработать.
Устранение неполадок
Строка состояния не отображается- Убедитесь, что ваш скрипт исполняемый:
chmod +x ~/.claude/statusline.sh - Проверьте, что ваш скрипт выводит в stdout, а не stderr
- Запустите ваш скрипт вручную, чтобы убедиться, что он выводит результат
- Если
disableAllHooksустановлен наtrueв ваших настройках, строка состояния также отключена. Удалите эту настройку или установите её наfalse, чтобы повторно включить. - Запустите
claude --debug, чтобы записать код выхода и stderr из первого вызова строки состояния в сеансе - Попросите Claude прочитать ваш файл настроек и выполнить команду
statusLineнапрямую, чтобы выявить ошибки
-- или пустые значения
- Поля могут быть
nullперед завершением первого ответа API - Обрабатывайте нулевые значения в вашем скрипте с резервными значениями, такими как
// 0в jq - Перезагрузите Claude Code, если значения остаются пустыми после нескольких сообщений
- Используйте
used_percentageдля точного состояния контекста вместо совокупных итогов total_input_tokensиtotal_output_tokensнакапливаются во всём сеансе и могут превышать размер контекстного окна- Процент контекста может отличаться от вывода
/contextиз-за времени расчёта каждого
- Убедитесь, что ваш терминал поддерживает гиперссылки OSC 8 (iTerm2, Kitty, WezTerm)
- Terminal.app не поддерживает кликабельные ссылки
- Сеансы SSH и tmux могут удалять последовательности OSC в зависимости от конфигурации
- Если последовательности экранирования отображаются как буквальный текст, например
\e]8;;, используйтеprintf '%b'вместоecho -eдля более надёжной обработки экранирования
- Сложные последовательности экранирования (цвета ANSI, ссылки OSC 8) могут иногда вызывать искажённый вывод, если они перекрываются с другими обновлениями пользовательского интерфейса
- Если вы видите повреждённый текст, попробуйте упростить ваш скрипт до простого текстового вывода
- Многострочные строки состояния с кодами экранирования более подвержены проблемам отображения, чем однострочный простой текст
- Скрипты, которые выходят с ненулевыми кодами или не выводят результат, вызывают пустую строку состояния
- Медленные скрипты блокируют обновление строки состояния до их завершения. Держите скрипты быстрыми, чтобы избежать устаревшего вывода.
- Если новое обновление срабатывает, пока медленный скрипт работает, выполнение скрипта отменяется
- Протестируйте ваш скрипт независимо с макетными входными данными перед его настройкой
- Системные уведомления, такие как ошибки MCP сервера, автоматические обновления и предупреждения о токенах, отображаются на правой стороне той же строки, что и ваша строка состояния
- Включение подробного режима добавляет счётчик токенов в эту область
- На узких терминалах эти уведомления могут обрезать вывод вашей строки состояния