Skip to main content

Extract synthesized engineering knowledge from a GitHub repo into a learnings/ folder.

Project description

invocator

Summon the accumulated wisdom of a GitHub repository into a learnings/ grimoire. ✨

invocator is a CLI that points at any GitHub repository, walks its PRs, issues, commits, and code-review conversations, and synthesizes that history into a folder of categorized markdown files — rules, prevenções, patterns, decisions, glossary — so the tacit knowledge living in a project's timeline becomes navigable documentation.

The three spells

Spell What it does
invocator forge key Bind a pact with Anthropic — store and validate your API key
invocator scry cost --repo owner/name Gaze ahead: cost / wall time / item counts before the ritual
invocator extract wisdom --repo owner/name The full ritual — produces ./learnings/

Prerequisites

  • Python 3.11+
  • gh CLI installed and authenticated (gh auth login) — invocator never calls api.github.com directly
  • An Anthropic API key

Multi-account gh users: invocator runs as whichever GitHub identity gh auth status reports as active. If a repo lives in an org and REPO_NOT_FOUND surprises you, switch with gh auth switch before re-running.

Install

pipx install invocator        # recommended
# or
uv tool install invocator
# or, from source
git clone https://github.com/Gab-r-x/invocator.git && cd invocator && pip install -e .

Quickstart

invocator forge key
invocator scry cost --repo OleveCo/CourseGPTBackend
invocator extract wisdom --repo OleveCo/CourseGPTBackend

After the ritual completes, ./learnings/ will contain six markdown files synthesized from the repo's history.

Output structure

File Contents
rules.md Conventions and imperatives ("always X", "never Y") mined from review comments
prevencoes.md Bug patterns, regressions, and pitfalls the team has already paid for
patterns.md Refactors and architectural patterns that recur in the codebase
decisions.md ADR-style decisions extracted from PRs and issues
glossary.md Domain terms and named concepts that recur ≥3 times
INDEX.md Run metadata: repo, timestamp, model, cost, per-file bullet counts

How it works

  1. summongh api --paginate pulls PRs, issues, commits, and review comments into a JSONL cache with per-resource watermarks (re-runs are incremental).
  2. transmute — heuristics (conventional commits, review-cue regexes, labels, ADR detection, glossary mining) classify each item into one of five categories. SHA1 dedupe + top-K cap per category.
  3. inscribe — one Anthropic call per category, with explicit prompt caching, writes learnings/<category>.md. A SHA256 corpus hash means re-runs without deltas are free (no LLM call). INDEX.md is rendered deterministically.

Cost

Roughly $1–3 USD for medium-sized repos with claude-sonnet-4-6. Always preview with invocator scry cost --repo X first. Re-runs without changes are free thanks to the hash cache.

Troubleshooting

Symptom Fix
gh: command not found Install gh: https://cli.github.com/
GH_NOT_AUTHENTICATED Run gh auth login
NO_API_KEY Run invocator forge key
CORPUS_TOO_LARGE Cap inputs: --top-k 100
Want to re-fetch from scratch invocator extract wisdom --repo X --force-refetch

Contributing

This project follows a strict phased-todo workflow. Before contributing, read:

License

MIT — see LICENSE.

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

invocator-0.1.5.tar.gz (102.2 kB view details)

Uploaded Source

Built Distribution

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

invocator-0.1.5-py3-none-any.whl (36.4 kB view details)

Uploaded Python 3

File details

Details for the file invocator-0.1.5.tar.gz.

File metadata

  • Download URL: invocator-0.1.5.tar.gz
  • Upload date:
  • Size: 102.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.13

File hashes

Hashes for invocator-0.1.5.tar.gz
Algorithm Hash digest
SHA256 d6ec0e67de4fa7cebbfd43265e9b902735e2c17250c5d438ea8e61ef6ac2434d
MD5 f135fedf1d0db8cbf0f27fb6122fe25a
BLAKE2b-256 903fe2b8fb8a7a03e4f3cf2f38486bf478440bf2bfb89228b1d28203da3aeba1

See more details on using hashes here.

File details

Details for the file invocator-0.1.5-py3-none-any.whl.

File metadata

  • Download URL: invocator-0.1.5-py3-none-any.whl
  • Upload date:
  • Size: 36.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.13

File hashes

Hashes for invocator-0.1.5-py3-none-any.whl
Algorithm Hash digest
SHA256 d1a32520ffc46257712afa4a823ab0beb76bda4eb74a6e8dc71fcb0311930bd3
MD5 37a55f46d0dfacbb6fbcf1529ba1f0ff
BLAKE2b-256 e97a1333803c7f8c049c4cf0f2419c2d42cf43a465bbdcf56315749cdde93ec8

See more details on using hashes here.

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