Whetstone
A single Rust binary that installs and orchestrates three upstream tools for Claude Code (and friends): Headroom (context proxy), RTK (Bash-output hook), and ICM (project memory). Idempotent setup, version-pinned manifest, reversible v2 → v3 migration, release automation.
whetstone setup ──┬── Headroom (context compression proxy, upstream)
├── RTK (Bash-output rewrite hook, upstream)
└── ICM (embedded SQLite project memory, upstream)
Compression is upstream's job. The glue — installing, versioning, configuring, migrating, and tearing down cleanly — is whetstone's.
Install
|
Or from source: cargo install whetstone && whetstone setup
See docs/install.md for prerequisites, setup details, and project configuration.
Upgrading from v2 → v3
v3 is a structural rewrite. whetstone setup will refuse to install over a v2
project and hand off to whetstone migrate. The migration is one command,
archive-backed, and reversible.
Full procedure, archive contents, and rollback semantics: docs/migration.md.
Breaking changes (v3.0.0)
- AutoMem provider removed.
MemoryProvideris now{ Icm, Skip }. ThemcpServers.memoryblock is torn out of~/.claude/settings.json(archived). If you ran an external FalkorDB + Qdrant service, tear it down yourself — it's no longer in whetstone's blast radius. - Bundled skills, rules, and hook scripts removed. The
assets/hooks/*.sh,assets/skills/,assets/rules/, and theMEMSTACK.mdshim are gone. ICM owns its own assets; whetstone delegates toicm init --mode standard. - Hooks are tool-managed. Whetstone no longer hand-merges
~/.claude/settings.json.rtk init --auto-patchandicm initwrite their own hook entries.whetstone doctorreports drift. - Migration is mandatory. Existing v2 installs must run
whetstone migratebefore any v3 command will configure them. config.local.jsonreplaced by.claude/whetstone.json(schema version, integration version, provider, tool versions, timestamps).- Hardcoded
--modelinjection removed.whetstone claudeno longer forces a model; Claude Code's own settings choose it.
Full release notes in CHANGELOG.md.
Architecture
User → AI Coding Tool
├── Bash calls → [RTK Hook] → compressed output
├── Context → [Headroom Proxy :8787]→ LLM API
└── Memory → [ICM, embedded SQLite]→ persistent context
What each piece does
Whetstone (this repo) — single Rust binary. Installs the three tools below,
ensures uv is present (offers to install it), version-pins everything in
.claude/whetstone.json, exposes setup, update, migrate, doctor, and
release. No runtime dependencies of its own.
Headroom (upstream — headroom-ai) —
HTTP proxy in front of the LLM provider. Multi-stage pipeline: cache alignment,
content routing, statistical JSON compression, AST-aware code compression,
score-based message dropping. Compression numbers belong to Headroom; run
curl localhost:8787/stats to measure your own.
RTK (upstream — rtk-ai/rtk) — Bash-output
compression via PreToolUse hook. Compresses output before it enters the context
window. Caveat: it only fires on Bash tool calls; Claude Code's native
Read/Grep/Glob bypass it. Compression isn't free either — RTK's own tracker has
logged a ~18% net cost-increase case. Run rtk gain and rtk discover to keep
yourself honest, and consider RTK's audit mode if a particular rewrite feels
suspect.
ICM (upstream — rtk-ai/icm) — embedded
SQLite memory store; skills, hooks, and CLI installed by
icm init --mode standard. Whetstone v2's bundled MemStack/skills/rules layer
is gone — ICM owns its own assets now.
Documentation
| Doc | Contents |
|---|---|
| Installation | Prerequisites, quick start, new/existing project setup |
| CLI Reference | All v3 commands, flags, RTK quick reference + caveats |
| Migration Guide | v2 → v3 with migrate, --dry-run, --rollback |
| Editor Setup | Claude Code, Cursor, Copilot, Windsurf, Cline, Aider, Codex, Gemini CLI, OpenCode + compatibility matrix |
| Headroom Service | systemd, launchd, and background setup |
| Configuration | Global/per-project files, environment variables |
| Troubleshooting | Common issues, uninstall, manual removal |
Development
Source layout in CLAUDE.md.