--- name: config-audit:manifest description: Show ranked token-source manifest — every CLAUDE.md, plugin, skill, MCP server, and hook ordered DESC by estimated tokens argument-hint: "[path] [--json]" allowed-tools: Read, Bash model: sonnet --- # Config-Audit: Manifest Produce a ranked, single-table view of every token source loaded for a given repo path. Where `whats-active` shows separate tables per category, `manifest` collapses everything into one ordered list — making it easy to see what's costing the most regardless of category. ## UX Rules (MANDATORY — from `.claude/rules/ux-rules.md`) 1. **Never show raw JSON or stderr output.** Always use `--output-file` + `2>/dev/null`. 2. **Narrate before acting.** Tell the user what you're about to do. 3. **Read, don't dump.** Read the JSON file and render a formatted table. 4. **End with context-sensitive next steps.** ## Implementation ### Step 1: Parse `$ARGUMENTS` First non-flag argument is the path (default `.`). Recognized flags: - `--json` — emit raw JSON instead of the rendered table. - `--raw` — pass-through to the scanner; accepted for CLI surface consistency with the other config-audit commands. The manifest CLI is data-table only (no findings prose), so `--raw` is a no-op here, but the flag is still threaded through so users get uniform behaviour across `--raw`. ### Step 2: Run the CLI silently Tell the user: **"Building token-source manifest for ``..."** ```bash TMPFILE="/tmp/ca-manifest-$$.json" RAW_FLAG="" if echo "$ARGUMENTS" | grep -q -- "--raw"; then RAW_FLAG="--raw"; fi node ${CLAUDE_PLUGIN_ROOT}/scanners/manifest.mjs --output-file "$TMPFILE" $RAW_FLAG 2>/dev/null; echo $? ``` **Exit code handling:** - `0` → continue - `3` → tell user: "Couldn't read configuration. Check that the path exists and is a directory." Stop. ### Step 3: If `--json` was requested, cat the file and stop ```bash cat "$TMPFILE" ``` Do NOT render the table in JSON mode. ### Step 4: Read JSON and render Use the Read tool on `$TMPFILE`. Extract `meta.repoPath`, `total`, and `sources[]`. Render the top 20 sources (or fewer if the manifest is shorter): ```markdown **Token-source manifest for ``** — ~{total} tokens at startup | Rank | Kind | Name | Source | Tokens | |------|------|------|--------|--------| | 1 | {kind} | `` | {source} | ~{estimated_tokens} | | ... | ... | ... | ... | ... | _Estimates assume ~4 chars/token (Claude ballpark). Real token count varies ±15%._ ``` If `sources.length > 20`, follow the table with: _"Showing top 20 of {N} sources. Run with `--json` to see the full list."_ ### Step 5: Suggest next steps ```markdown **Next steps:** - `/config-audit tokens` — Opus-4.7 token-hotspot patterns (cache-breaking, redundant perms, deep imports, MCP budget) - `/config-audit whats-active` — same data grouped by category, with disable suggestions - `/config-audit feature-gap` — what *could* improve here, grouped by impact ``` Tone: - High total (>50k): empathetic — "That's a heavy startup cost; tokens bullet anything you'd otherwise spend on the actual conversation." - Moderate (10–50k): neutral — "Reasonable. Skim the top 5 to see if anything is unexpectedly large." - Low (<10k): encouraging — "Tight setup. The model has plenty of room for the actual work."