MCPcopy
hub / github.com/mvanhorn/cli-printing-press

github.com/mvanhorn/cli-printing-press @v4.27.1 sqlite

repository ↗ · DeepWiki ↗ · release v4.27.1 ↗
10,871 symbols 38,467 edges 816 files 3,352 documented · 31%
README

CLI Printing Press

CI Golden Release Go License

Nothing is more valuable than time and money. In a world of AI agents, that's speed and token spend. A well-designed CLI is muscle memory for an agent: no hunting through docs, no wrong turns, no wasted tokens. We built the Printing Press to print the best CLIs in the world for agents.

It reads the official API docs, studies every popular community CLI and MCP server, sniffs the web for the APIs nobody published (think Google Flights or Dominos), and applies the power-user playbook Peter Steinberger proved with discrawl and gogcli - local SQLite, compound commands, agent-native flags. It fuses all of that and prints a token-efficient Go CLI plus a Claude Code skill plus an MCP server for any API or any website.

Three CLIs printed by the press, installable today:

  • ESPN (sniffed, no official API). "Tonight's NBA playoff games with live score, series state, each team's leading scorer's stat line, and any injury or lineup news from the last 24 hours." Returns everything in one call.
  • flight-goat (Kayak nonstop search plus sniffed Google Flights). "Non-stop flights over 8 hours from Seattle for 4 people, Dec 24 to Jan 1, cheapest first." Two sources stitched into one query.
  • linear-pp-cli (50ms against a local SQLite mirror). "Every blocked issue whose blocker has been stuck for a week." Compound queries the API can't answer.

Browse the full catalog of printed CLIs at printingpress.dev or in the Printing Press Library, organized by category, most with full MCP servers.

Codex users: see docs/CODEX.md to install the Printing Press skills with --agent codex, verify the install, and understand how that differs from /printing-press <api> codex.

Cursor users: see docs/CURSOR.md for how to install a printed CLI, attach the matching skill, handle auth, and choose CLI vs MCP when your repo does not already document a workflow.

Install

You need both the binary and the Printing Press skills. The skills (/printing-press <app>) are the primary interface; they drive the binary behind the scenes.

The binary alone works (research, generation, verification, scoring) but skips the curated agent loop. The skills alone have nothing to call. Install both.

Prerequisites: Go 1.26.4 or newer, Claude Code or another skills-supported agent, and Node/npm for npx. The skills are tested with Claude Code; install for Codex with --agent codex when you want to try the same slash-command workflow there. Use Claude Code for the best-tested experience.

1. Install

curl -fsSL https://raw.githubusercontent.com/mvanhorn/cli-printing-press/main/scripts/install.sh | bash

The installer runs go install for the generator binary, then refreshes all Printing Press skills through skills@latest add --skill '*'. Restart or reload your agent session after it completes so the refreshed skills are loaded.

Use --cli-only or --skills-only when you only want one side:

curl -fsSL https://raw.githubusercontent.com/mvanhorn/cli-printing-press/main/scripts/install.sh | bash -s -- --cli-only
curl -fsSL https://raw.githubusercontent.com/mvanhorn/cli-printing-press/main/scripts/install.sh | bash -s -- --skills-only

Claude Code is the default install target. To install or refresh the skills for Codex instead, pass --agent codex:

curl -fsSL https://raw.githubusercontent.com/mvanhorn/cli-printing-press/main/scripts/install.sh | bash -s -- --skills-only --agent codex
npx -y skills@latest list -g -a codex --json

See docs/CODEX.md for the Codex-specific notes.

Verify with cli-printing-press --version. If install fails, confirm Go 1.26.4 or newer is installed, Node/npm is installed for npx, and $GOPATH/bin is on your PATH.

Older releases installed a generator binary named printing-press. That legacy entrypoint still works for compatibility, but the canonical generator command is now cli-printing-press so the public library installer can own printing-press list, printing-press search, and printing-press install.

Manual install

Install or update the binary:

go install github.com/mvanhorn/cli-printing-press/v4/cmd/cli-printing-press@latest

Use Vercel's open-agent-skills CLI to install the Printing Press skills from this repo into a supported agent. Claude Code is the default and tested path:

npx -y skills@latest add mvanhorn/cli-printing-press/skills --skill '*' -g -a claude-code -y

For Codex:

npx -y skills@latest add mvanhorn/cli-printing-press/skills --skill '*' -g -a codex -y
npx -y skills@latest list -g -a codex --json

To refresh the skills later without naming individual skills, rerun the installer in skills-only mode:

curl -fsSL https://raw.githubusercontent.com/mvanhorn/cli-printing-press/main/scripts/install.sh | bash -s -- --skills-only

Restart or reload the target agent after refreshing skills so the new skill text is loaded.

Once installed, you can start Claude Code from any folder. Codex users should start a fresh Codex session after installing or refreshing skills.

Developer path: load skills from a clone

Use this if you're editing the Printing Press itself and want local skill changes to take effect on the next session start.

git clone https://github.com/mvanhorn/cli-printing-press.git
cd cli-printing-press
claude --plugin-dir .          # load this repo's skills directly
claude --plugin-dir . -w       # ...in a new git worktree (parallel runs)

For a persistent local setup that survives restarts and also loads in background sessions, see Local Plugin Development.

2. Start a printing session

claude

Then inside Claude Code:

/printing-press <app-name>

For example:

/printing-press Notion                       # Print a CLI for an API by name
/printing-press https://postman.com/explore  # ...or point at a website (no spec needed)
/printing-press-reprint notion               # Reprint an existing CLI under the latest machine

/printing-press drives the cli-printing-press binary you installed — research, generation, scoring, and shipcheck all run through it. Two parts, one workflow.

One command. Lean loop. Produces a Go CLI plus an MCP server that absorbs every feature from every competing tool, then transcends with compound use cases only possible with local data. REST, GraphQL, or browser-sniffed traffic. No OpenAPI spec required.

Each run produces two binaries (<api>-pp-cli plus <api>-pp-mcp), research documents, verification proofs, and a Quality Score.

Where output goes

By default, active and published output are separated:

  • Active managed runs work in ~/printing-press/.runstate/<scope>/runs/<run-id>/working/<api>-pp-cli
  • Published CLIs go to ~/printing-press/library/<api>
  • Archived manuscripts go to ~/printing-press/manuscripts/<api>/<run-id>/
  • Manuscripts are split into research/, proofs/, discovery/, and pipeline/

<scope> is derived from the current git checkout path, so parallel worktrees do not stomp on each other. If you pass --output, that overrides the generated CLI location for that command.

Codex mode (60% fewer Opus tokens)

/printing-press HubSpot codex    # Offload code generation to Codex CLI
/printing-press HubSpot          # Standard Opus mode (default)

When you add codex, Phase 3's code generation tasks are delegated to Codex CLI. Claude stays the brain (research, planning, scoring, review). Codex does the hands (writing Go code from scoped prompts). Same quality, 60% fewer Opus tokens. If Codex fails 3 times in a row, the press falls back to doing it locally, no manual intervention needed.

Improve an existing CLI (Polish)

Targeted fix-up. Diagnostics (dogfood, verify, scorecard, output review), fixes verify failures, removes dead code, cleans descriptions and READMEs, offers to publish. Auto-runs as Phase 5.5 of every generation; can also run standalone:

/printing-press-polish notion

Publish a CLI to the library

When you're happy with a CLI, publish it to the library:

/printing-press-publish linear   # Validates, packages, creates PR

Amend a published CLI from a dogfood session

After dogfooding a published CLI in a Claude Code session, turn the friction you hit (missing flags, hand-rolled API payloads, silent-null returns) into a PR for the public library. Mines the active session transcript, scopes the patch with you, plans + executes the fix autonomously, scrubs PII, and opens a PR — two checkpoints (scope, PR draft):

/printing-press-amend                # auto-detect target CLI from session
/printing-press-amend superhuman     # explicit target

Why these CLIs win

Most generators wrap endpoints and stop. Printing Press generates CLIs that understand the domain.

Local-first data layer. High-gravity resources get domain-specific SQLite tables (not JSON blobs), FTS5 full-text search indexes, and incremental sync with cursor tracking. sync pulls data down. search finds it in milliseconds. sql lets power users query directly. All offline, all local.

Machine-owned freshness. Store-backed CLIs can opt into a bounded pre-read refresh via cache.enabled so --data-source auto keeps the local store current without a manual sync. --data-source local and --data-source live give you full control.

Compound commands no wrapper can do. Once data lives in SQLite, commands like stale, health, bottleneck, and reconcile become possible - they join across resources and analyze history. A stateless API wrapper literally cannot do this.

Agent-native by default. Human-friendly tables when you're in a terminal. Auto-JSON when piped, no --json flag needed. --compact drops to high-gravity fields only (60-80% fewer tokens). Typed exit codes (0/2/3/4/5/7) let agents self-correct without parsing error text. --dry-run for safe exploration. Every flag exists because an AI agent will call it thousands of times a day.

No spec? No problem. Don't have an OpenAPI spec? Point the press at a website. It launches a browser, captures traffic, reverse-engineers the API, and generates the spec for you. ESPN, Postman Explore, internal tools - if you can click through it, the press can build a CLI for it.

Dual interface from one spec. Every API gets a Cobra CLI (<api>-pp-cli) and an MCP server (<api>-pp-mcp). Same client, same store, same auth. Shell agents use the CLI. IDE agents use MCP. Zero code duplication.

Verified, not vibes. Four mechanical checks - scorecard, dogfood, proof-of-behavior, live API smoke test - catch hallucinated paths, dead flags, auth mismatches, and broken data pipelines before you ship.

Credits its sources. Every generated README includes a Sources and Inspiration section that credits the ecosystem tools studied during research. We built on giants' shoulders and we say so.

The non-obvious insight

Every API has a secret identity. The data it exposes is useful for something its creators never designed for. The printing press finds that secret and builds a CLI around it.

The Non-Obvious Insight (NOI) is a one-sentence reframe:

"[API] isn't just [obvious thing]. It's [non-obvious thing].
 Every [data point] is a signal about [hidden truth]."
API What they think it is What it actually is
Discord A chat app A searchable knowledge base. Every message thread is institutional memory.
Linear An issue tracker A team behavior observatory. Every state change is a signal about how your team actually works vs. how they think they work.
Stripe A payment processor A business health monitor. Every failed charge and churn event is a signal about product-market fit.
GitHub A code host An engineering culture fingerprint. Every review turnaround and merge pattern is a signal about how your team ships.
Notion A doc editor A knowledge decay detector. Every stale page and orphaned database is a signal about what your team has forgotten.
HubSpot A CRM Your company's relationship memory. Every deal stage transition, email open, and meeting log is a signal about pipeline health and rep performance.
Slack Messaging An organizational nervous system. Every response time and channel silence is a signal about team health.
ESPN Sports data A betting intelligence terminal. Every injury report, lineup change, and odds movement is a signal about game outcomes.

The NOI is the creative DNA of every CLI the press generates. Phase 0 cannot c

Extension points exported contracts — how you extend this code

Transport (Interface)
(no doc) [5 implementers]
testdata/golden/expected/generate-device-ble-control/ble-desk-lamp/internal/device/transport.go
Adapter (Interface)
(no doc) [2 implementers]
internal/devicesniff/ble/adapter.go
DogfoodOption (FuncType)
DogfoodOption configures optional behavior for RunDogfood.
internal/pipeline/dogfood.go
Transport (Interface)
(no doc) [5 implementers]
testdata/golden/expected/generate-device-ble/ble-temperature-sensor/internal/device/transport.go
Transport (Interface)
(no doc) [5 implementers]
testdata/golden/expected/generate-device-ble-session/ble-session-appliance/internal/device/transport.go
Transport (Interface)
(no doc) [5 implementers]
testdata/golden/expected/generate-device-ble-opaque/ble-opaque-binary/internal/device/transport.go
Link (Interface)
Link is a connected device. Write/Read/Subscribe address GATT characteristics by UUID, so one connection serves every co [2 …
testdata/golden/expected/generate-device-ble/ble-temperature-sensor/internal/device/ble.go

Core symbols most depended-on inside this repo

Generate
called by 761
internal/generator/generator.go
New
called by 748
internal/generator/generator.go
Error
called by 488
internal/cli/exitcodes.go
CLI
called by 395
internal/naming/naming.go
Close
called by 334
testdata/golden/expected/generate-device-ble/ble-temperature-sensor/internal/device/ble.go
String
called by 331
testdata/golden/expected/generate-golden-api/printing-press-golden/internal/cliutil/freshness.go
Parse
called by 276
internal/openapi/parser.go
Error
called by 167
internal/pressauth/root.go

Shape

Function 9,037
Method 943
Struct 806
TypeAlias 51
Interface 16
Class 14
FuncType 4

Languages

Go99%
Python1%
TypeScript1%

Modules by API surface

internal/generator/generator.go372 symbols
internal/openapi/parser.go313 symbols
internal/generator/generator_test.go305 symbols
internal/spec/spec.go248 symbols
internal/openapi/parser_test.go234 symbols
internal/pipeline/scorecard.go157 symbols
internal/pipeline/dogfood.go155 symbols
internal/profiler/profiler.go135 symbols
internal/pipeline/live_dogfood_test.go124 symbols
internal/spec/spec_test.go119 symbols
internal/browsersniff/analysis.go109 symbols
internal/pipeline/live_dogfood.go103 symbols

Dependencies from manifests, versioned

github.com/andybalholm/brotliv1.2.1 · 1×
github.com/chromedp/cdprotov0.0.0-2026032100182 · 1×
github.com/chromedp/sysutilv1.1.0 · 1×
github.com/dave/dstv0.27.4 · 1×
github.com/dlclark/regexp2v1.12.0 · 1×
github.com/enetx/gv1.0.224 · 1×
github.com/enetx/httpv1.0.28 · 1×
github.com/enetx/http2v1.0.26 · 1×
github.com/enetx/http3v1.0.7 · 1×

For agents

$ claude mcp add cli-printing-press \
  -- python -m otcore.mcp_server <graph>

⬇ download graph artifact