my-pi

June 10, 2026 · View on GitHub

Semgrep built with vite+ tested with vitest

My curated Pi distribution: a ready-to-run coding-agent CLI with MCP, LSP, skills, recall, redaction, telemetry, team mode, prompt presets, and other handy extensions prewired.

my-pi package preview

Built on the @earendil-works/pi-coding-agent SDK. Use the full distribution directly, or install individual @spences10/pi-* packages into your own Pi setup.

Quick start

pnpx my-pi@latest
# or: npx my-pi@latest / bunx my-pi@latest

Two ways to use my-pi

1. Run the full distribution

Use my-pi if you want the complete, opinionated setup:

pnpx my-pi@latest

This is its own CLI wrapper around Pi. Do not install the root package with pi install npm:my-pi.

2. Install individual Pi packages

Most extensions in this repo are also published as normal Pi packages:

pi install npm:@spences10/pi-lsp
pi install npm:@spences10/pi-mcp
pi install npm:@spences10/pi-redact

Use this path if you already have your own Pi setup and only want selected features. Package READMEs are the source of truth for install instructions, commands, configuration, and runtime behavior.

What you get

  • Pi-native CLI + SDK wrapper — interactive TUI, print mode, JSON mode, RPC mode, and programmatic runtime creation.
  • Project-aware MCP tools — stdio and HTTP/streamable-HTTP servers from mcp.json, scoped so sensitive or noisy tools only load for the projects and orgs where they belong.
  • Project-aware skills — discover, enable, disable, import, and sync Pi-native skills, with different skill sets per project.
  • LSP tools — diagnostics, hover, definitions, references, and document symbols via language servers.
  • Context sidecar — local SQLite storage for oversized tool output, keeping long results searchable without flooding chat context.
  • Guardrails — Svelte and coding-preference checks that block configured anti-patterns before agents write them.
  • Prompt presets — base presets plus additive prompt layers with per-project persistence.
  • Secret safety — redaction plus reminders to use secret-safe environment loading.
  • Recall, telemetry, and observability — local support for prior-session lookup, evals, latency analysis, live event streams, and operational debugging.
  • Git UI — interactive source-control staging and commit support.
  • Team mode — local RPC teammate orchestration with tasks and mailboxes.
  • Themes and TUI helpers — visual polish and shared modal primitives.

Requirements

  • Node.js >=24.15.0
  • pnpm 11 for local development
  • Pi authentication via pi auth, provider environment variables, or supported OAuth flows

my-pi uses native node:sqlite through context, telemetry, and observability packages. The CLI suppresses Node's expected node:sqlite ExperimentalWarning; standalone package/API consumers own their process warning policy until Node marks it stable.

Common usage

# full TUI
pnpx my-pi@latest

# one-shot print mode
pnpx my-pi@latest "summarize this repo"
pnpx my-pi@latest -P "explicit print mode"

# NDJSON events for scripts/agents
pnpx my-pi@latest --json "list all TODO comments"

# RPC mode for team/agent orchestration
pnpx my-pi@latest --mode rpc

# local live observability dashboard
pnpx my-pi@latest
# then run /observability in the TUI to open the browser dashboard
pnpx my-pi@latest observability

Pi handles model authentication natively. For provider-specific model examples, see the Pi docs and the relevant extension/package README.

Reusable Pi packages

Install the full distribution with pnpx my-pi@latest, or install selected extensions into vanilla Pi:

# Bash/Zsh/Fish
pi install npm:@spences10/pi-{context,lsp,team-mode}

Full package list here:

PackagePurpose
@spences10/pi-coding-preferencesConfigurable coding-workflow guardrails
@spences10/pi-confirm-destructiveDestructive action confirmations
@spences10/pi-contextScoped SQLite FTS overflow cache for oversized tool output
@spences10/pi-git-uiInteractive source-control staging UI
@spences10/pi-lspLSP-backed diagnostics and symbol tools
@spences10/pi-mcpMCP server integration and /mcp
@spences10/pi-nopeeknopeek reminder for secret-safe environment loading
@spences10/pi-observabilityLive local event stream and browser dashboard
@spences10/pi-omnisearchmcp-omnisearch reminder for verified web research
@spences10/pi-recallpirecall reminder and background sync
@spences10/pi-redactOutput redaction and /redact-stats
@spences10/pi-skillsSkill management, import, and sync
@spences10/pi-sqlite-toolsmcp-sqlite-tools reminder for safer SQLite database work
@spences10/pi-svelte-guardrailsSvelte pattern guardrails
@spences10/pi-team-modeLocal team mode with RPC teammates, tasks, and mailboxes
@spences10/pi-telemetryLocal SQLite telemetry and /telemetry
@spences10/pi-themesBundled theme pack for Pi

Shared helper packages such as @spences10/pi-child-env, @spences10/pi-project-trust, @spences10/pi-settings, and @spences10/pi-tui-modal are published as dependencies and are not packages to install via pi install.

Project structure

apps/
  web/                     Landing page for discovering my-pi and its packages
src/
  index.ts                 CLI entry point
  api.ts                   Programmatic API
  extensions/              Root-only built-ins and distro wiring
packages/
  pi-*/                    Reusable Pi packages and shared support packages
.pi/
  presets.json             Optional project prompt presets
  presets/*.md             Optional project prompt preset files
mcp.json                   Project MCP server config