gentle-pi
v0.3.8
Published
Turn Pi into el Gentleman: a senior-architect development harness with SDD/OpenSpec, subagents, strict TDD evidence, review guardrails, and skill discovery.
Maintainers
Readme
gentle-pi
Turn Pi from a powerful coding agent into a controlled development harness.
gentle-pi installs el Gentleman in Pi: a senior-architect operating layer for Spec-Driven Development, focused subagents, strict TDD evidence, reviewable work units, safety guards, and project/user skill discovery.
Pi already has strong tools. gentle-pi adds the discipline for using them well.
gentle-pi is the Pi-native package from the Gentle-AI ecosystem, built by Gentleman Programming: the broader open-source project for turning AI coding agents into disciplined engineering environments with SDD workflows, skills, memory integrations, model routing, and review guardrails across multiple agents.
Follow the project and the community around it:
- GitHub: Gentleman-Programming
- YouTube: Gentleman Programming
- Community Discord: Gentleman Programming
Startup intro collaboration: thanks to @aporcelli for pi-gentle-startup, which inspired the clean-screen startup animation, compact runtime panel, and pink visual treatment.
The problem
Most coding-agent sessions fail for operational reasons, not model reasons:
- the agent jumps into code before requirements are clear;
- architectural decisions disappear into chat history;
- one request quietly becomes a huge multi-area diff;
- tests run late, or not at all;
- reviewers get handed a wall of changes;
- subagents are available, but the parent session has no orchestration discipline;
- project skills exist, but the model forgets to load them.
gentle-pi fixes the workflow around the agent.
What it adds
| Capability | What it does |
| ------------------------------ | --------------------------------------------------------------------------------------------------------------------------------------------- |
| el Gentleman persona | Makes Pi behave like a senior architect and teacher, not a generic chatbot. Spanish responses use Rioplatense voseo by default. |
| Rose startup intro | Adds a pink rose fade-in, compact project/runtime panel, and visible startup collaboration credit for @aporcelli's pi-gentle-startup ideas. |
| Work routing discipline | Small tasks stay inline. Context-heavy exploration can be delegated. Large or risky changes go through SDD/OpenSpec. |
| SDD/OpenSpec assets | Installs phase agents and chains for init, explore, proposal, spec, design, tasks, apply, verify, and archive. |
| Lazy SDD preflight | Asks once per session for SDD mode, artifact store, PR chaining strategy, and review budget before the first SDD flow. |
| Subagent orchestration | Keeps one parent session responsible while child agents explore, implement, test, or review with focused context. |
| Strict TDD support | When project config declares a test command, apply/verify phases must record RED → GREEN → TRIANGULATE → REFACTOR evidence. |
| Reviewer protection | Surfaces review workload risk before a task turns into an oversized PR. |
| Per-agent model assignment | Pi-native modal for assigning stronger or cheaper models to specific SDD/custom agents. |
| Skill discovery registry | Maintains .atl/skill-registry.md from project and user skills so review/comment/PR workflows do not silently miss the right skill. |
| Delivery skills | Includes issue-first PRs, chained PRs, work-unit commits, cognitive docs, comment writing, and Judgment Day review. |
| Shell safety | Blocks destructive shell commands and asks for confirmation for sensitive operations. |
Install
pi install npm:gentle-piRecommended companion packages:
pi install npm:pi-subagents
pi install npm:pi-intercom
pi install npm:gentle-engram
pi install npm:pi-web-access
pi install npm:pi-lens
pi install npm:@juicesharp/rpiv-todo
pi install npm:@juicesharp/rpiv-ask-user-questionThen start Pi in a project:
pigentle-pi provides SDD agents as global Pi runtime assets, not per-project setup. The first SDD flow in a session still runs a one-time SDD preflight for preferences; for natural-language requests, el Gentleman decides when SDD is needed and runs the explicit preflight first.
Quick start
/gentle-ai:status Check package, SDD assets, OpenSpec, and global model config.
/gentle-ai:sdd-preflight Run or reuse the session SDD preflight explicitly.
/sdd-init Create or refresh openspec/config.yaml.
/gentle:models Assign global model/effort routing to SDD/custom agents.
/gentle:persona Switch between gentleman and neutral persona modes.Typical flow:
- Open Pi in your repo.
- Run
/gentle-ai:status. - Run
/sdd-initonce per project, or when test/project capabilities change. This also runs the session SDD preflight. - For a substantial change, ask Pi to use SDD. Natural-language requests are classified by the parent agent, not by brittle runtime regexes.
- Review the phase artifacts instead of trusting floating chat context.
How the harness decides what to do
gentle-pi routes through the smallest safe workflow:
| Request shape | Harness | | --------------------------------------------------------------------------- | ---------------------------- | | Small, clear, local edit | Inline direct work. | | Unknown codebase area or context-heavy investigation | Focused subagent delegation. | | Large, ambiguous, architectural, product-facing, or high-review-risk change | SDD/OpenSpec flow. |
The goal is not ceremony. The goal is to avoid accidental chaos. Once a task stops being small, delegation is expected rather than optional.
Delegation triggers
gentle-pi keeps the parent session thin and uses subagents at the narrowest useful point:
| Trigger | Expected behavior |
| --------------------------------------------------------------------------------------------------------------------------- | -------------------------------------------------------------------- |
| Reading 4+ files to understand a flow | Launch scout or context-builder and synthesize its handoff. |
| Touching 2+ non-trivial code files | Use one worker, or require fresh review before completion. |
| Commit, push, or PR after code changes | Run a fresh-context reviewer unless the diff is trivial docs/text. |
| Wrong cwd, worktree/git accident, merge recovery, confusing test/env issue | Stop and run a fresh audit reviewer before continuing. |
| Long monolithic session with accumulating complexity, roughly 20 tool calls, 5 exploratory reads, or 2 non-mechanical edits | Pause and delegate or explain why not. |
The intended balanced loop for a bounded bugfix is:
parent git/status + clarify → scout when context-heavy → one worker writes → fresh reviewer audits → parent validates and reportsFresh reviewers are intentionally not token-saving devices; they buy independent judgment. scout/context-builder save parent context by compressing broad exploration. worker preserves a single writer thread.
SDD/OpenSpec flow
init
↓
explore → proposal → spec ─┬→ design ─┐
└─────────┴→ tasks → apply → verify → sync → archiveThe main loop is intentionally file-backed when you choose openspec or both:
planning artifacts implementation evidence canonical update
────────────────── ─────────────────────── ────────────────
proposal/spec/design/tasks → apply-progress/verify-report → sync-report → archive-reportFor substantial work, the parent session coordinates the flow and each phase writes artifacts. That gives you:
- explicit requirements and non-goals;
- design decisions that survive compaction;
- task plans reviewers can reason about;
- implementation evidence;
- verification reports;
- sync reports that update canonical specs while keeping the change active;
- archive notes for future agents.
OpenSpec artifact model
gentle-pi treats OpenSpec-compatible behavior as part of the harness. You do not need to install the external OpenSpec CLI/package for SDD.
In file-backed modes, canonical accepted behavior lives in openspec/specs/, while active changes carry deltas under openspec/changes/:
openspec/
├── specs/ # accepted source of truth
│ └── {domain}/spec.md
└── changes/
├── {change}/ # active work
│ ├── proposal.md
│ ├── specs/{domain}/spec.md # full spec or delta spec
│ ├── design.md
│ ├── tasks.md
│ ├── apply-progress.md
│ ├── verify-report.md
│ └── sync-report.md
└── archive/YYYY-MM-DD-{change}/ # immutable audit trailDelta flow:
openspec/changes/{change}/specs/{domain}/spec.md
│
│ sdd-sync applies ADDED / MODIFIED / REMOVED
▼
openspec/specs/{domain}/spec.md
│
│ sdd-archive moves the completed change folder
▼
openspec/changes/archive/YYYY-MM-DD-{change}/When a canonical spec already exists, change specs use requirement operation sections:
## ADDED Requirements
## MODIFIED Requirements
## REMOVED RequirementsMODIFIED requirements must include the full requirement block, including still-valid scenarios, because sync replaces the canonical block by requirement name. sdd-sync syncs file-backed deltas into openspec/specs/{domain}/spec.md while keeping the change active; sdd-archive then moves the synced change to openspec/changes/archive/YYYY-MM-DD-{change}/.
Engram-only mode is different by design: Engram is working memory and does not maintain a canonical spec merge layer. Use openspec or both (hybrid file + memory persistence) when you need canonical spec evolution.
SDD preflight and project files
gentle-pi does not require SDD agents to be copied into every project. The package ensures global Pi SDD assets exist under the Pi agent home and treats project-local files only as overrides/debug copies. Slash SDD flows such as /sdd-*, /sdd-init, and the explicit /gentle-ai:sdd-preflight command run a lazy preflight and ask for session-scoped SDD preferences. For natural-language requests, the parent agent decides whether the work should use SDD and must run/reuse /gentle-ai:sdd-preflight before continuing.
~/.pi/agent/agents/sdd-*.md
~/.pi/agent/chains/sdd-*.chain.md
~/.pi/agent/gentle-ai/support/strict-tdd*.mdThe preflight choices are reused for later SDD flows in the same session:
- execution mode:
interactiveorauto; - artifact store:
openspec, orengram/bothwhen callable memory tools are available; - PR chaining strategy:
auto-forecast,ask-always,single-pr-default, orforce-chained; - review budget line threshold.
It does not overwrite existing global assets unless you explicitly run:
/gentle-ai:install-sdd --forceManual preflight commands:
/gentle-ai:sdd-preflight
/gentle:sdd-preflightSkill registry
gentle-pi keeps a local registry at:
.atl/skill-registry.mdThe registry scans project and user skill roots, not package-owned skills. It exists to catch workflow skills that are present on disk but not visible in Pi's injected skill list.
It scans common roots such as:
./skills
.opencode/skills
.claude/skills
.gemini/skills
.cursor/skills
.github/skills
.codex/skills
.qwen/skills
.kiro/skills
.openclaw/skills
.pi/skills
.agent/skills
.agents/skills
.atl/skills
~/.pi/agent/skills
~/.config/agents/skills
~/.agents/skills
~/.kimi/skills
~/.config/opencode/skills
~/.config/kilo/skills
~/.claude/skills
~/.gemini/skills
~/.gemini/antigravity/skills
~/.cursor/skills
~/.copilot/skills
~/.codex/skills
~/.codeium/windsurf/skills
~/.qwen/skills
~/.kiro/skills
~/.openclaw/skillsBehavior:
.atl/is added to.gitignorewhen needed;- the registry refreshes on session start;
- startup refresh is skipped when Pi starts with
--no-skills/-ns,--no-skill-registry, orGENTLE_PI_NO_SKILL_REGISTRY=1; /skill-registry:refreshforces regeneration;- a best-effort watcher refreshes when skill files change;
- the registry indexes skill names, full descriptions, scope, and exact
SKILL.mdpaths without copying skill body rules.
Skill discovery is a guardrail, not a workflow router: it helps Pi load the right skill without forcing extra ceremony.
Delegation contract:
- parent/orchestrator resolves project/user skills from the registry and passes matching paths under
## Skills to load before work; - SDD subagents still use their assigned executor/phase skill;
- during normal runtime, subagents should not independently discover additional project/user
SKILL.mdfiles or the registry; - fallback loading is degraded self-healing and must be reported via
skill_resolutionasfallback-registry,fallback-path, ornone.
Persona modes
/gentle:persona| Persona | Behavior |
| ----------- | ------------------------------------------------------------------------------------------------------------- |
| gentleman | Senior architect, teacher, direct technical feedback, Rioplatense Spanish/voseo when the user writes Spanish. |
| neutral | Same discipline, warmer professional language, no regional expression. |
Saved at:
.pi/gentle-ai/persona.jsonRun /reload or start a new Pi session after switching persona.
Model and effort assignment
/gentle:modelsThe modal discovers:
- project agents in
.pi/agents/and.agents/; - user agents in
~/.pi/agent/agents/and~/.agents/; - built-in agents from
pi-subagents.
Recommended model/effort shape:
| Agent kind | Recommended model | Recommended effort (thinking) |
| -------------------------- | ---------------------------------------------------- | ------------------------------- |
| Explore, proposal, archive | Fast and cheap is usually enough. | off to low |
| Spec, design, tasks | Strong reasoning model. | medium to high |
| Apply | Strong coding and tool-use model. | medium to high |
| Verify / review | Strong fresh-context model. | high |
| Tiny utilities | Inherit active/default model unless they bottleneck. | inherit |
Saved globally at:
~/.pi/gentle-ai/models.jsonExisting project-local .pi/gentle-ai/models.json files are still read as a legacy fallback when no global model config exists, but /gentle:models writes the shared global config.
Config shape (per agent):
{
"sdd-design": {
"model": "anthropic/claude-sonnet-4",
"thinking": "high"
},
"sdd-archive": {
"model": "openai/gpt-5-mini"
}
}Legacy string entries are still accepted and treated as model-only config.
Commands
| Command | What it does |
| -------------------------------- | ------------------------------------------------------------------- |
| /gentle-ai:status | Shows package, SDD asset, OpenSpec, and global model config status. |
| /gentle:models | Opens global model + effort assignment UI. |
| /gentle:persona | Switches persona mode. |
| /sdd-init | Initializes or refreshes openspec/config.yaml. |
| /gentle-ai:install-sdd | Repairs missing global SDD runtime assets without overwriting files. |
| /gentle-ai:install-sdd --force | Force-refreshes installed global SDD assets. |
| /skill-registry:refresh | Regenerates .atl/skill-registry.md. |
Startup flag:
pi --no-skill-registryUse it when you want skills available normally but do not want Gentle AI to refresh/watch .atl/skill-registry.md on startup. pi -ns / pi --no-skills also skip the registry startup work because Pi is already disabling skill loading.
Compatibility aliases:
/gentle-ai:models
/gentleman:models
/gentle-ai:persona
/gentleman:personaIncluded skills
gentle-ai— harness discipline for controlled Pi work.branch-pr— issue-first PR preparation.chained-pr— split oversized changes into reviewable PR chains.work-unit-commits— commits as reviewable work units.judgment-day— blind dual review, fixes, and re-judgment.cognitive-doc-design— documentation that reduces cognitive load.comment-writer— concise, warm, postable collaboration comments.issue-creation— issue workflow with checks before creation.
Memory
gentle-pi does not provide persistent memory by itself.
For memory, install the companion package:
pi install npm:gentle-engramWhen memory tools are actually active, el Gentleman can save decisions, bug fixes, discoveries, user prompts, and session summaries across Pi sessions.
Memory contract for SDD delegation:
- parent/orchestrator owns memory retrieval and passes selected context into subagent prompts;
- subagents should not independently search memory during normal runtime unless explicitly instructed to retrieve a specific artifact or observation;
- subagents should save significant discoveries, decisions, bug fixes, and completed SDD phase artifacts before returning when memory tools are available;
- in memory/hybrid mode, SDD artifacts use stable topic keys such as
sdd/<change>/proposal,sdd/<change>/spec,sdd/<change>/design,sdd/<change>/tasks,sdd/<change>/apply-progress, andsdd/<change>/verify-report.
Package contents
| Path | Purpose |
| ------------------------------ | ---------------------------------------------------------------------------------------------------------- |
| extensions/gentle-ai.ts | Injects identity, ensures global SDD assets, registers commands, applies model config, and protects shell execution. |
| extensions/startup-banner.ts | Shows the rose startup intro, compact runtime panel, and collaboration credit. |
| extensions/sdd-init.ts | Registers /sdd-init for OpenSpec initialization. |
| extensions/skill-registry.ts | Maintains .atl/skill-registry.md from project/user skills. |
| assets/orchestrator.md | Parent-session orchestration contract. |
| assets/agents/ | SDD agents installed as global Pi runtime assets. |
| assets/chains/ | SDD chains installed as global Pi runtime assets. |
| assets/support/ | Strict TDD support docs for apply/verify phases. |
| skills/ | Gentle AI delivery and collaboration skills. |
| prompts/ | Gentle-prefixed prompt templates. |
Development
Install from this repo:
pi install .Validate before publishing:
pnpm test
bun build extensions/skill-registry.ts --target=node --format=esm --outfile=/tmp/skill-registry.js
node --experimental-strip-types --check extensions/gentle-ai.ts
node --experimental-strip-types --check extensions/sdd-init.ts
node --experimental-strip-types --check extensions/startup-banner.ts
npm pack --dry-runPublish npm through GitHub Actions only:
gh workflow run publish.yml --repo Gentleman-Programming/gentle-pi --ref main -f dist-tag=latest
gh run watch <run-id> --repo Gentleman-Programming/gentle-pi --exit-status
npm view gentle-pi@<version> version --registry=https://registry.npmjs.org/
npm dist-tag ls gentle-pi --registry=https://registry.npmjs.org/Do not run npm publish locally for gentle-pi; the GitHub workflow provides provenance, environment protection, and registry credentials.
Principles
- Human control over agent momentum.
- Concepts before code.
- Artifacts over floating chat context.
- SDD when risk justifies it.
- Strict TDD when tests exist.
- One parent orchestrator, focused subagents.
- Reviewable changes over giant diffs.
