Skip to main content

Claude Code extension that watches agent tool calls and suggests structured alternatives

Project description

Kibitzer

The person watching your chess game who can't help offering opinions.

Kibitzer is a Claude Code extension that watches how agents use tools and suggests better alternatives. It enforces path protection per mode, intercepts bash commands that have structured alternatives, and coaches agents toward more effective tool usage — all without an LLM in the decision loop.

PyPI Python License Docs

Install

pip install kibitzer
cd your-project/
kibitzer init --hooks --mcp

This registers PreToolUse/PostToolUse hooks in .claude/settings.json and optionally starts an MCP server with two tools: ChangeToolMode and GetFeedback.

What it does

Path protection

Each mode defines which paths the agent can write to. The path guard checks every Edit, Write, and NotebookEdit call.

Mode        Writable            Use case
─────────── ─────────────────── ───────────────────────────
free        everything          prototyping, no guardrails
create      everything          greenfield, scaffold-first
implement   src/, lib/          normal dev — tests protected
test_dev    tests/, test/       writing tests — source protected
document    docs/, README.md    documentation only
debug       nothing             read-only investigation
review      nothing             read-only code review

When a write is denied, the agent sees why and how to fix it:

Path 'tests/test_auth.py' is not writable in the current mode (writable: ['src/', 'lib/']).
Use the ChangeToolMode tool to switch modes.

Interception

Interceptor plugins watch Bash calls for commands that have structured alternatives:

Bash command Suggested alternative Plugin
git add -A && git commit -m '...' jetsam save jetsam
pytest tests/ blq run test blq
grep -rn 'def handler' src/ FindDefinitions(...) fledgling

Three interception modes form a ratchet — start in observe (log silently), graduate to suggest (show alternative), then redirect (deny bash, require structured tool). Each graduation is a one-line config change.

Coaching

The coach fires every N tool calls and detects patterns from ~250 experimental runs:

  • Repeated edit failures — "Edit failed 3 times on src/handler.py. Try Read() first to see exact content."
  • Edit streak without tests — "You've made 7 edits without running tests."
  • Semantic tool underuse — "FindDefinitions shows all functions in one call instead of grepping file by file."
  • Analysis loop — "You've spent 18 turns reading without changes. Start with the most confident fix."
  • Mode oscillation — "Frequent mode switches. Consider using free mode."

Patterns are mode-aware: the analysis loop doesn't fire in debug mode (not editing is correct there), edit-without-test doesn't fire in document mode (docs don't need tests).

Auto-transitions

The mode controller watches for failure patterns:

  • 3+ consecutive failures → auto-switch to debug
  • 20+ turns in debug → auto-switch back to implement

An oscillation guard prevents rapid switching: if the agent just left a mode (< 5 turns), it won't auto-switch back. After 6+ total switches, auto-transitions stop.

MCP tools

The agent can call two tools explicitly:

ChangeToolMode(mode, reason?) — Switch modes. Returns the new mode's writable paths and strategy.

GetFeedback(status?, suggestions?, intercepts?) — Check current status, get coaching suggestions, and see which bash commands have been intercepted.

Configuration

Override defaults in .kibitzer/config.toml:

# Monorepo: widen writable paths
[modes.implement]
writable = ["packages/core/src/", "packages/api/src/"]

# Graduate jetsam to suggest mode
[plugins.jetsam]
mode = "suggest"

# More aggressive coaching
[coach]
frequency = 3

Coordinates with

Kibitzer suggests but never wraps these tools — each is independent:

  • blq — structured build/test capture
  • jetsam — git workflow acceleration
  • Fledgling — AST-aware code intelligence

None are required. Kibitzer degrades gracefully — path guard and coach work with nothing else installed.

Documentation

Full docs at kibitzer.readthedocs.io:

  • Modes — path protection, switching, auto-transitions
  • Coach — all patterns, experimental evidence, model dependency
  • Interceptors — the observe/suggest/redirect ratchet
  • Configuration — full config.toml reference
  • Architecture — how the pieces fit together

License

MIT

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

kibitzer-0.1.3.tar.gz (71.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

kibitzer-0.1.3-py3-none-any.whl (26.9 kB view details)

Uploaded Python 3

File details

Details for the file kibitzer-0.1.3.tar.gz.

File metadata

  • Download URL: kibitzer-0.1.3.tar.gz
  • Upload date:
  • Size: 71.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for kibitzer-0.1.3.tar.gz
Algorithm Hash digest
SHA256 0ca9f17236454aa29beb8d6ba03afc3985a0adcc3838751a62ffaaf729a4f929
MD5 36acaf8ebd00080983fab0a2f00e3cf5
BLAKE2b-256 ffbdbeb7b4e783de3acd11631b26e50f9064d866041eb562b9234f6d60e0d0ed

See more details on using hashes here.

Provenance

The following attestation bundles were made for kibitzer-0.1.3.tar.gz:

Publisher: publish.yml on teaguesterling/kibitzer

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file kibitzer-0.1.3-py3-none-any.whl.

File metadata

  • Download URL: kibitzer-0.1.3-py3-none-any.whl
  • Upload date:
  • Size: 26.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for kibitzer-0.1.3-py3-none-any.whl
Algorithm Hash digest
SHA256 6be22710b8d01d567ffd5b0ad7106dcb940792a8f1ba9d5d154afec6007577e3
MD5 9d92c62b0b6ad44a5a4a707b8ee14807
BLAKE2b-256 f3d46a56aa90552fdd8d342a53d9a6e89fd1c29dea72374dde260b10f74fa049

See more details on using hashes here.

Provenance

The following attestation bundles were made for kibitzer-0.1.3-py3-none-any.whl:

Publisher: publish.yml on teaguesterling/kibitzer

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page