SKILL.md
Statusline Generator
A single-source-of-truth statusline for Claude Code. One script, two layouts,
end-to-end self-verification.
Quick health check (start here when something is wrong)
Run this first whenever the statusline misbehaves. It catches the silent failures
that account for most "configured but not working" reports:
bash scripts/health_check.sh
It validates four layers:
~/.claude/statusline.shexists and is executable. **Missingchmod +xis
the single most common silent-failure cause** — Claude Code runs the script,
exec fails, statusline goes blank.
~/.claude/settings.jsonhas a validstatusLineblock pointing at the script.
- Mock stdin tests covering complete data, zero tokens, missing fields,
and $HOME path shortening.
- Real stdin replay from
/tmp/.claude-statusline-last-stdin.jsonif you
previously ran with CLAUDE_STATUSLINE_DEBUG=1.
Each failure prints a one-line fix command — you don't have to read documentation
to recover.
Quick install
bash scripts/install_statusline.sh
This script:
- Backs up any existing
~/.claude/statusline.shandsettings.json.
- Copies
generate_statusline.shto~/.claude/statusline.shandchmod +xs it.
- Updates
settings.jsonstatusLineblock viajq(preserves other settings).
- **Mandatorily runs
health_check.shand shows the result** — installation
is not "complete" until verification passes.
Restart Claude Code (or send any new message) to see the statusline update.
What you get
Default — minimal one-line layout
~/code/myproject Opus 4.7 (1M context) ctx: 108K / 1M
Just the essentials: short path, model name, absolute token counts. No colors,
no git, no cost, no percentage. Designed for users who want signal without noise.
Full — multi-line with cost and git
Set CLAUDE_STATUSLINE_LAYOUT=full in your shell profile to enable:
alex (Sonnet 4.6) [$0.42/$25.93] ctx: 108K/1M (11%)
~/code/myproject
[git:main*+]
- Line 1: user, model, ccusage session/daily costs, color-coded ctx (green ≤50%,
yellow 51–80%, red >80%).
- Line 2: short path.
- Line 3: git branch with
*for modified,+for untracked.
Layouts: how to switch
The script reads layout from environment, not flags (Claude Code passes JSON on stdin,
so flags would conflict). Set in ~/.zshrc or ~/.bashrc:
# Minimal (default — same as not setting it)
export CLAUDE_STATUSLINE_LAYOUT=minimal
# Full
export CLAUDE_STATUSLINE_LAYOUT=full
Restart your shell (or source the rc file) so Claude Code inherits the change,
then send a message — statusline refreshes within 300ms.
Debug stdin capture
To see exactly what JSON Claude Code sends your script:
export CLAUDE_STATUSLINE_DEBUG=1
Each invocation writes its stdin to /tmp/.claude-statusline-last-stdin.json
(overwriting on every refresh). Inspect with jq .. Useful for:
- Diagnosing why a field doesn't render the way you expect.
- Re-running the script against real input:
cat /tmp/.claude-statusline-last-stdin.json | ~/.claude/statusline.sh.
- Filing bug reports — paste the dump as ground truth.
Authoring rules (why this skill is shaped this way)
Two production failure modes drove the current design. Both are sealed in code,
not just docs:
Rule 1 — Always chmod +x , always verify by running
The single biggest silent-failure cause of any statusline is a script without
the executable bit: Claude Code's exec fails silently and the bar goes blank
with no error. install_statusline.sh always chmod +xs; health_check.sh
flags the bit if missing. **If you hand-write or hand-edit a statusline script,
mock-test it before declaring done:** echo '{}' | bash your-script.sh.
Rule 2 — "Configuration complete" is meaningless without evidence
"Wrote the file and updated settings.json" is not the same as "the script runs
and produces the expected output." install_statusline.sh therefore always
runs health_check.sh at the end and exits non-zero if any check fails.
Treat any "complete!" report from any agent that lacks evidence as suspect.
For field-level traps (used_percentage null at session start, total_input_tokens
semantics across Claude Code versions, hardcoded context_window_size), see
references/context-window-schema.md.
Customization
For colors, custom segments (hostname, time, etc.), and disabling cost tracking,
see references/customization.md.
Dependencies
The script auto-detects available tools and degrades gracefully:
Tool
Required for
Fallback
jq
JSON parsing (preferred)
falls back to python3
python3
JSON parsing fallback
bare cwd only
awk
token K/M formatting
required by both layouts
git
git status (full layout)
silent skip if missing or not in repo
ccusage
cost (full layout)
silent skip if missing
Install on macOS: brew install jq. On Debian/Ubuntu: apt install jq.
Troubleshooting
For symptom-by-symptom diagnostics, see
references/troubleshooting-decision-tree.md.
It walks through:
- Statusline blank or never updates (chmod cause)
- ctx segment missing or wrong (field traps)
- Want token counts not percentages (layout switch)
- Colors render as raw escape codes (terminal compatibility)
- Git segment missing (full layout)
- Cost segment missing (ccusage / cache)
- Edits have no effect (path mismatch)
- Slow refresh (jq vs python3)
Resources
File
Purpose
scripts/generate_statusline.sh
The statusline script. Single source of truth. Two layouts via CLAUDE_STATUSLINE_LAYOUT.
scripts/install_statusline.sh
Idempotent installer. Backs up, copies, chmods, wires settings.json, runs health check.
scripts/health_check.sh
Four-layer verification: file perms, settings.json wiring, mock stdin tests, real stdin replay.
references/troubleshooting-decision-tree.md
Symptom-driven diagnostic flowchart. Load when statusline misbehaves.
references/customization.md
Color changes, custom segments, threshold tuning, single-line full layout. Load when user wants to modify how the statusline looks.
references/context-window-schema.md
Claude Code statusline JSON schema. Documents every field plus current_usage vs total_input_tokens semantics across versions.
references/color_codes.md
ANSI color codes reference. Load for color customization.
references/ccusage_integration.md
ccusage integration deep-dive: caching, JSON shape, troubleshooting. Load for cost-related issues.