Skip to main content

Learn your pushback style from past Claude Code feedback and code reviews, and replicate it with a language model.

Project description

cc-pushback

cc-pushback banner

PyPI Python Docs License: PolyForm-Noncommercial-1.0.0

cc-pushback mines your Claude Code transcripts for the moments you pushed back — corrections, interrupts, rejected plans, code-review comments, "no, do it this way" — and collects them, with the surrounding conversational context, into a local database. That corpus is the raw material for learning your pushback style; this first release builds it.

Install

No install needed — run everything through uvx:

uvx cc-pushback --help

uvx fetches cc-pushback into a throwaway environment and runs it. To add it to a project instead:

uv add cc-pushback

Quickstart

Scan your transcripts for the moments you pushed back and accumulate them into a local feedback database:

uvx cc-pushback scan
scanned 412 files, 1473 new rows

scan is incremental and idempotent. Each transcript is parsed only when it is new or has changed since the last scan, and every candidate is keyed by a content digest, so re-running over unchanged inputs adds nothing. Recording a file and inserting its candidates commit in one transaction — interrupt a scan and the database is never left half-written. A transcript that fails to parse (one Claude Code is still writing, say) is skipped and retried next time, never aborting the run.

The database lives at ~/.cc-pushback/feedback.db by default (override with --db). Inspect what has been collected:

uvx cc-pushback stats          # counts by source kind, and the scanned-file count
uvx cc-pushback list           # recent feedback, newest first
uvx cc-pushback list --source plan_review --limit 50

What gets collected

scan runs four detectors over each transcript:

  • Transcript messages (transcript_message) — the pushback you typed mid-session, after trivial acknowledgements and structural noise are filtered out.
  • Plan reviews (plan_review) — rejected ExitPlanMode plans (with the feedback you gave) and plan-mode re-entries right after an edit cycle, i.e. "let's rethink this."
  • Interrupts and rejections (interrupt_rejection) — permission denials and [Request interrupted by user] corrections, with the denied tool and your follow-up captured.
  • Review comments (review_comment) — structured code-review messages exploded into one row per inline comment.

Each row carries the conversational window around the feedback — the assistant action it responded to, plus a few turns either side — captured at collection time, because transcripts are ephemeral.

Restrict to specific kinds with --source (repeatable), or force a full re-mine of every transcript (after a detector change, say) with --full:

uvx cc-pushback list --source transcript_message --source plan_review
uvx cc-pushback scan --full

Mining transcripts from another machine

Transcripts live under ~/.claude/projects. To mine a remote machine's history, mirror its projects directory locally with rsync, then scan that directory:

rsync -az yasyf@yasyf:.claude/projects/ ~/.cc-pushback/mirrors/yasyf/
uvx cc-pushback scan --transcripts ~/.cc-pushback/mirrors/yasyf/

--transcripts is repeatable, so you can fold several mirrors into one scan. Because discovery is mtime-keyed, repeating the rsync and re-scanning only ingests what changed.

What problems does this solve?

  • Your corrections evaporate. Every "don't do it that way" you've typed into Claude Code is sitting unused in transcript files. cc-pushback turns that history into a structured dataset.
  • CLAUDE.md only captures what you remember to write down. Most of your taste is tacit — you only notice a rule when it's violated. Collecting real pushbacks recovers the rules you never articulated.
  • The signal is buried in noise. Trivial acknowledgements, structural reminders, and tool chatter drown out the moments that matter; cc-pushback keeps the pushback and discards the rest.

Docs

Read the docs for the full guide and API reference.

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

cc_pushback-0.2.0.tar.gz (56.4 kB view details)

Uploaded Source

Built Distribution

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

cc_pushback-0.2.0-py3-none-any.whl (64.1 kB view details)

Uploaded Python 3

File details

Details for the file cc_pushback-0.2.0.tar.gz.

File metadata

  • Download URL: cc_pushback-0.2.0.tar.gz
  • Upload date:
  • Size: 56.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for cc_pushback-0.2.0.tar.gz
Algorithm Hash digest
SHA256 d835358175759f6737a7ad57068961ca6d7d0770b3a82f7443f4d823b4f898c3
MD5 e3a40b266594928cb501ba63eed0d1e3
BLAKE2b-256 00e7840193cdb47db2fb8f619b190ec3d8a4e62be5465b4785f165087ec1974d

See more details on using hashes here.

Provenance

The following attestation bundles were made for cc_pushback-0.2.0.tar.gz:

Publisher: release-pypi.yml on yasyf/cc-pushback

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

File details

Details for the file cc_pushback-0.2.0-py3-none-any.whl.

File metadata

  • Download URL: cc_pushback-0.2.0-py3-none-any.whl
  • Upload date:
  • Size: 64.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for cc_pushback-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 2a579d8ac5ee8fe49f64efc891f8447b43f72652d3c2bdb74b1da15941b8821c
MD5 0c3725e7af834e6b8fc809581a2df743
BLAKE2b-256 9d788d00bdbc4a44b295071d3897c5b9e0a925ab45bf4cbb1dde22b37b8e31ad

See more details on using hashes here.

Provenance

The following attestation bundles were made for cc_pushback-0.2.0-py3-none-any.whl:

Publisher: release-pypi.yml on yasyf/cc-pushback

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