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

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.1.tar.gz (97.8 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.1-py3-none-any.whl (34.3 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: invocator-0.1.1.tar.gz
  • Upload date:
  • Size: 97.8 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.1.tar.gz
Algorithm Hash digest
SHA256 4a5df03693fb2cf7d6e065986490933213ce86293820378814204a06fceeb87d
MD5 dba7454b4dd796bf9466c10924872bc7
BLAKE2b-256 ea3e19cd426e3ec5c82f52db00e21cb8e506222a1d241d69634a04f46bbe5d91

See more details on using hashes here.

File details

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

File metadata

  • Download URL: invocator-0.1.1-py3-none-any.whl
  • Upload date:
  • Size: 34.3 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.1-py3-none-any.whl
Algorithm Hash digest
SHA256 5ffc60534e1ebe27863bdf2363711bd958ac84588a25ca4ce5cde685f1b477b6
MD5 7179ee7875d13847237252b94b279c32
BLAKE2b-256 fed6c2cf051c87584a7d0f47bdedeeb8e0f4995674afea0b5e3ee6ab5e8307af

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