Problem
RTK's Claude Code hook intercepts only the Bash tool, but Claude Code has built-in native tools (Read, Grep, Glob, Edit, Write) that handle the majority of file and search operations without ever touching Bash.
Claude Code's system prompt explicitly instructs:
"Do NOT use the Bash to run commands when a relevant dedicated tool is provided."
- Read files →
Read tool (not cat/head/tail)
- Search content →
Grep tool (not grep/rg)
- Find files →
Glob tool (not find/ls)
- Edit files →
Edit tool (not sed/awk)
This means ~60% of the commands RTK is designed to compress (cat, grep, find, ls) never reach the Bash tool and are invisible to the RTK hook.
Evidence
On a real system with RTK 0.28.2 properly installed (hook v2, settings.json configured, RTK.md referenced):
rtk discover reports 6,302 Bash commands in 7 days and claims 248K tokens saveable
- But
rtk gain shows only 4 commands ever processed by RTK
- The hook was installed and working correctly — the gap is because
rtk discover scans Claude's JSONL logs and cannot distinguish between Bash tool calls and native tool calls, so it overestimates saveable tokens
Architecture mismatch
Claude Code Tool Routing:
┌─────────────┐
│ Read tool │──→ direct file read (no Bash, no hook, no RTK)
│ Grep tool │──→ direct ripgrep (no Bash, no hook, no RTK)
│ Glob tool │──→ direct glob (no Bash, no hook, no RTK)
│ Edit tool │──→ direct edit (no Bash, no hook, no RTK)
│ Bash tool │──→ hook fires ──→ RTK rewrites ✅
└─────────────┘
Impact
- RTK's headline claim of "80% savings across ~118K tokens per session" is significantly overstated for Claude Code users
rtk discover gives misleading savings estimates because it counts native tool usage as "missed Bash commands"
- Users install RTK expecting large savings but see minimal impact, leading to confusion
What RTK still helps with (Bash-only commands)
git operations (status, diff, log, add, commit, push)
gh CLI (pr, issue, run)
npm run build/test, cargo test/build
docker commands
curl, ssh
These are real savings, but a fraction of the advertised total.
Suggestions
rtk discover accuracy: Filter out or flag commands that likely used native tools (Read/Grep/Glob) rather than Bash, so savings estimates are realistic
- Hook non-Bash tools: Investigate intercepting
Read, Grep, Glob tool calls via the PreToolUse hook to compress their outputs (different matcher + updatedInput schema)
- Documentation: Clarify that Claude Code's native tools bypass RTK, and set realistic expectations for savings (git/gh/build/test commands only)
rtk gain context: Show estimated "reachable" vs "unreachable" commands so users understand why savings are lower than rtk discover suggests
Environment
- RTK 0.28.2 (Homebrew, macOS)
- Claude Code with Opus model
- Hook v2 (thin delegator), correctly installed and verified working
Problem
RTK's Claude Code hook intercepts only the Bash tool, but Claude Code has built-in native tools (
Read,Grep,Glob,Edit,Write) that handle the majority of file and search operations without ever touching Bash.Claude Code's system prompt explicitly instructs:
This means ~60% of the commands RTK is designed to compress (
cat,grep,find,ls) never reach the Bash tool and are invisible to the RTK hook.Evidence
On a real system with RTK 0.28.2 properly installed (hook v2, settings.json configured, RTK.md referenced):
rtk discoverreports 6,302 Bash commands in 7 days and claims 248K tokens saveablertk gainshows only 4 commands ever processed by RTKrtk discoverscans Claude's JSONL logs and cannot distinguish between Bash tool calls and native tool calls, so it overestimates saveable tokensArchitecture mismatch
Impact
rtk discovergives misleading savings estimates because it counts native tool usage as "missed Bash commands"What RTK still helps with (Bash-only commands)
gitoperations (status, diff, log, add, commit, push)ghCLI (pr, issue, run)npm run build/test,cargo test/builddockercommandscurl,sshThese are real savings, but a fraction of the advertised total.
Suggestions
rtk discoveraccuracy: Filter out or flag commands that likely used native tools (Read/Grep/Glob) rather than Bash, so savings estimates are realisticRead,Grep,Globtool calls via thePreToolUsehook to compress their outputs (differentmatcher+updatedInputschema)rtk gaincontext: Show estimated "reachable" vs "unreachable" commands so users understand why savings are lower thanrtk discoversuggestsEnvironment