statusline-generator
$
npx mdskill add daymade/claude-code-skills/statusline-generatorA single-source-of-truth statusline for Claude Code. One script, two layouts, end-to-end self-verification.
SKILL.md
.github/skills/statusline-generatorView on GitHub ↗
---
name: statusline-generator
description: >
Installs, configures, customizes, or troubleshoots the Claude Code statusline
(cwd, model, token counts). Use when the user wants to set up or change the
statusline, switch minimal vs full layouts, show absolute token counts
(e.g. ctx 108K / 1M) instead of a percentage, add cost via ccusage or git
status, dump the stdin JSON Claude Code passes the script, or fix a statusline
that is blank, silent, stuck, shows "permission denied", or stopped updating
after a script edit (often a missing chmod +x). Trigger phrases: "configure
statusline", "statusline blank", "status line not showing", "statusline
broken", "show token count in statusline", 状态栏, 状态栏不显示, 状态栏空白,
显示工作目录, 显示 token 数.
---
# 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
bash scripts/health_check.sh
```
It validates four layers:
1. `~/.claude/statusline.sh` exists and is executable. **Missing `chmod +x` is
the single most common silent-failure cause** — Claude Code runs the script,
`exec` fails, statusline goes blank.
2. `~/.claude/settings.json` has a valid `statusLine` block pointing at the script.
3. Mock stdin tests covering complete data, zero tokens, missing fields,
and `$HOME` path shortening.
4. Real stdin replay from `/tmp/.claude-statusline-last-stdin.json` if 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
bash scripts/install_statusline.sh
```
This script:
- Backs up any existing `~/.claude/statusline.sh` and `settings.json`.
- Copies `generate_statusline.sh` to `~/.claude/statusline.sh` and `chmod +x`s it.
- Updates `settings.json` `statusLine` block via `jq` (preserves other settings).
- **Mandatorily runs `health_check.sh` and 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`:
```bash
# 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:
```bash
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 +x`s; `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`](references/context-window-schema.md).
## Customization
For colors, custom segments (hostname, time, etc.), and disabling cost tracking,
see [`references/customization.md`](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`](references/troubleshooting-decision-tree.md).
It walks through:
1. Statusline blank or never updates (chmod cause)
2. ctx segment missing or wrong (field traps)
3. Want token counts not percentages (layout switch)
4. Colors render as raw escape codes (terminal compatibility)
5. Git segment missing (full layout)
6. Cost segment missing (ccusage / cache)
7. Edits have no effect (path mismatch)
8. 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. |
More from daymade/claude-code-skills
- asr-transcribe-to-textTranscribes audio and video files to text using Qwen3-ASR. Supports two modes — local MLX inference on macOS Apple Silicon (no API key, 15-27x realtime) and remote API via vLLM/OpenAI-compatible endpoints. Auto-detects platform and recommends the best path. Triggers when the user wants to transcribe recordings, convert audio/video to text, do speech-to-text, or mentions ASR, Qwen ASR, 转录, 语音转文字, 录音转文字. Also triggers for meeting recordings, lectures, interviews, podcasts, screen recordings, or any audio/video file the user wants converted to text.
- auto-repo-setup|
- benchmark-due-diligence>
- bigdata-skill>-
- capture-screenProgrammatic screenshot capture on macOS. Find window IDs with Swift CGWindowListCopyWindowInfo, control application windows via AppleScript (zoom, scroll, select), and capture with screencapture. Use when automating screenshots, capturing application windows for documentation, or building multi-shot visual workflows.
- claude-code-history-files-finderFinds and recovers content from Claude Code session history files. This skill should be used when searching for deleted files, tracking changes across sessions, analyzing conversation history, or recovering code from previous Claude interactions. Triggers include mentions of "session history", "recover deleted", "find in history", "previous conversation", or ".claude/projects".
- claude-md-progressive-disclosurer|
- claude-skills-troubleshootingDiagnose and resolve Claude Code plugin and skill issues. This skill should be used when plugins are installed but not showing in available skills list, skills are not activating as expected, or when troubleshooting enabledPlugins configuration in settings.json. Triggers include "plugin not working", "skill not showing", "installed but disabled", or "enabledPlugins" issues.
- cli-demo-generatorGenerates professional animated CLI demos as GIFs using VHS terminal recordings. Handles tape file creation, self-bootstrapping demos with hidden setup, output noise filtering, post-processing speed-up, and frame-level verification. Use when users want to create terminal demos, record CLI workflows as GIFs, generate animated documentation, build demo tapes for README files, or need to showcase any command-line tool visually. Also triggers on "record terminal", "VHS tape", "demo GIF", "animate my CLI", or any request to visually demonstrate shell commands.
- cloudflare-troubleshootingInvestigate and resolve Cloudflare configuration issues using API-driven evidence gathering. Use when troubleshooting ERR_TOO_MANY_REDIRECTS, SSL errors, DNS issues, or any Cloudflare-related problems. Focus on systematic investigation using Cloudflare API to examine actual configuration rather than making assumptions.