From dotclaude
Estimate per-turn token cost of this project's `.claude/` configuration and `CLAUDE.md`. Reports always-loaded vs path-scoped vs invoked-only, ranks the top contributors, and flags entries over budget. Add `--api` for exact counts via Anthropic's count_tokens endpoint instead of the chars/4 heuristic.
How this skill is triggered — by the user, by Claude, or both
Slash command
/dotclaude:context-budget [--api][--api]The summary Claude sees in its skill listing — used to decide when to auto-load this skill
Estimate the token cost of this project's `.claude/` configuration and `CLAUDE.md` so the user can see exactly which files load every turn versus only when triggered.
Estimate the token cost of this project's .claude/ configuration and CLAUDE.md so the user can see exactly which files load every turn versus only when triggered.
From the project root:
ls CLAUDE.md 2>/dev/null
find .claude/rules -name '*.md' -type f 2>/dev/null
find .claude/skills -name 'SKILL.md' -type f 2>/dev/null
find .claude/agents -name '*.md' -type f 2>/dev/null
[ -f .claude/CLAUDE.md ] && echo "WARN: .claude/CLAUDE.md exists. CLAUDE.md belongs at the project root."
Skip any file under .claude/agents/README.md, .claude/rules/README.md, etc. Those are folder descriptions, not loaded by Claude Code at runtime.
For every .md file in .claude/rules/, read the YAML frontmatter (the block between the first two --- lines).
| Frontmatter contains | Classification | Per-turn cost |
|---|---|---|
alwaysApply: true | Always-loaded | Every turn |
paths: [...] | Path-scoped | Loaded only when working near matched files |
| Neither | Defaults to always-loaded; flag for review | Every turn |
Other categories:
./CLAUDE.md -> always-loaded (by definition)..claude/skills/<name>/SKILL.md -> invoked-only (zero per-turn cost; only loads when the user runs /skill-name or, if disable-model-invocation is unset, when Claude auto-triggers it)..claude/agents/<name>.md -> invoked-only and runs in isolated context (per-invocation cost in its own session, not per-turn cost in the main thread).Default mode (no API call): chars-based heuristic. Anthropic documents that English text averages roughly 4 characters per token. Compute:
chars=$(wc -c < "$FILE" | tr -d ' ')
tokens=$((chars / 4))
Note this in the report so the user knows the count is approximate (within roughly 10 to 15 percent of the exact count for typical config text).
--api mode: if $ARGUMENTS contains --api:
if [ -z "$ANTHROPIC_API_KEY" ]; then
echo "ERROR: --api requested but ANTHROPIC_API_KEY is not set. Falling back to heuristic."
else
CONTENT=$(jq -Rs . < "$FILE")
tokens=$(curl -s https://api.anthropic.com/v1/messages/count_tokens \
-H "x-api-key: $ANTHROPIC_API_KEY" \
-H "anthropic-version: 2023-06-01" \
-H "content-type: application/json" \
-d "{\"model\":\"claude-sonnet-4-6\",\"messages\":[{\"role\":\"user\",\"content\":$CONTENT}]}" \
| jq -r '.input_tokens')
fi
The endpoint returns Anthropic's exact tokenizer count. That is the factual number Claude Code itself would see when loading the file.
Sum tokens within each category, identify the top 3 contributors among always-loaded files, then print:
Context budget for <project root>
Method: heuristic (chars/4) [or: Anthropic count_tokens API]
Always-loaded (every turn): ~N tokens
CLAUDE.md ~N tokens
.claude/rules/code-quality.md (alwaysApply) ~N tokens
.claude/rules/testing.md (alwaysApply) ~N tokens
Path-scoped (loaded near matched files): ~N tokens (max, if every glob matches)
.claude/rules/security.md (paths: src/api/**, ...) ~N tokens
.claude/rules/frontend.md (paths: **/*.tsx, ...) ~N tokens
Invoked-only (zero per-turn cost):
Cumulative size if every skill and agent loaded once: ~N tokens
.claude/skills/<name>/SKILL.md ~N tokens
.claude/agents/<name>.md ~N tokens
Top 3 always-loaded contributors:
1. <file> ~N tokens
2. <file> ~N tokens
3. <file> ~N tokens
Verdict: PASS / NEAR LIMIT / OVER BUDGET
End the report with the highest-leverage trim recommendation if any class is over budget.
| Class | Target | Hard cap | Action when over |
|---|---|---|---|
CLAUDE.md | <25 non-blank lines | <50 non-blank lines | Keep the dotclaude block tight; move detail into path-scoped rules. |
Each alwaysApply rule | <30 lines, ~250 tok | n/a | Push content to a path-scoped rule or into an agent. |
| Total always-loaded | <1000 tokens | <1500 tokens | Identify the single biggest contributor and trim it. |
--api (requires $ANTHROPIC_API_KEY) for the exact count from Anthropic's tokenizer.disable-model-invocation: true, meaning they only fire on /name.npx claudepluginhub 8408323/dotclaude --plugin dotclaudeGuides creation, editing, and verification of skills for AI coding agents using test-driven development with subagent scenarios. Use when authoring or debugging skills.