docs: pi clean seam refactor — PRD and ADR-010 (#4219)
* docs: add PRD and ADR for pi clean seam refactor Introduces two new planning documents for extracting GSD-authored code out of the vendored pi packages into dedicated @gsd/agent-core and @gsd/agent-modes workspace packages, establishing a module-system-enforced boundary that makes future pi-mono upstream updates significantly easier. Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com> * docs: rename ADR-009 to ADR-010, update cross-references Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com> --------- Co-authored-by: Claude Sonnet 4.6 <noreply@anthropic.com>
This commit is contained in:
parent
16fa6f45c0
commit
856c3f5cf5
2 changed files with 382 additions and 0 deletions
271
docs/dev/ADR-010-pi-clean-seam-architecture.md
Normal file
271
docs/dev/ADR-010-pi-clean-seam-architecture.md
Normal file
|
|
@ -0,0 +1,271 @@
|
|||
# ADR-010: Pi Clean Seam Architecture
|
||||
|
||||
**Status:** Proposed
|
||||
**Date:** 2026-04-14
|
||||
**Deciders:** Tom Boucher
|
||||
**PRD:** [PRD-pi-clean-seam-refactor.md](./PRD-pi-clean-seam-refactor.md)
|
||||
|
||||
---
|
||||
|
||||
## Context
|
||||
|
||||
GSD vendors four packages from [pi-mono](https://github.com/badlogic/pi-mono) (an open-source coding agent framework) by copying their source directly into `/packages/`:
|
||||
|
||||
| Package | Role | Current version |
|
||||
|---|---|---|
|
||||
| `@gsd/pi-agent-core` | Core agent loop and types | 0.57.1 |
|
||||
| `@gsd/pi-ai` | Multi-provider LLM API | 0.57.1 |
|
||||
| `@gsd/pi-tui` | Terminal UI framework | 0.57.1 |
|
||||
| `@gsd/pi-coding-agent` | Coding agent, tools, extension system | 2.74.0 |
|
||||
|
||||
Vendoring was chosen over npm dependencies to allow GSD to modify the upstream packages freely. However, over time, GSD has written substantial original logic directly inside `pi-coding-agent` — approximately 79 files including:
|
||||
|
||||
- `agent-session.ts` (98KB) — the primary GSD session orchestrator
|
||||
- `compaction/` — context window management
|
||||
- `modes/interactive/`, `modes/rpc/`, `modes/print/` — all three run modes
|
||||
- `cli/` — CLI argument parsing and utilities
|
||||
- `sdk.ts` — the `createAgentSession()` factory
|
||||
|
||||
This GSD-authored code is mixed in with upstream pi code inside the same package. The pi packages are currently 10 versions behind upstream (0.57.1 vs 0.67.2), with a breaking API change from v0.65.0 (`session_switch`/`session_fork` removal) unresolved. The primary obstacle to applying updates is that there is no reliable way to distinguish GSD files from pi files without reading them individually.
|
||||
|
||||
### Why not move to npm dependencies now?
|
||||
|
||||
Pi-mono does publish to npm as `@mariozechner/pi-*`. Moving to npm dependencies would eliminate vendoring entirely, but it is blocked by:
|
||||
|
||||
1. `@gsd/native` bindings are imported directly inside the vendored pi-tui and pi-coding-agent source — the upstream npm packages do not have these imports
|
||||
2. ~50 direct source modification commits to the vendored packages since March 2026 would need to be evaluated individually
|
||||
3. The upstream extension API (~25 events) is a subset of GSD's extension system (~50+ events) — the delta would need to be re-architected before the move
|
||||
|
||||
Moving to npm is a valid Phase 2. This ADR covers Phase 1: establishing a clean seam without changing the vendoring approach.
|
||||
|
||||
---
|
||||
|
||||
## Decision
|
||||
|
||||
Introduce two new workspace packages that own all GSD-authored code currently living inside `pi-coding-agent`. The vendored pi packages become close-to-upstream source copies. GSD code depends on pi; pi code does not depend on GSD.
|
||||
|
||||
### New package structure
|
||||
|
||||
```
|
||||
packages/
|
||||
pi-agent-core/ # vendored upstream — no GSD modifications
|
||||
pi-ai/ # vendored upstream — no GSD modifications
|
||||
pi-tui/ # vendored upstream — no GSD modifications
|
||||
pi-coding-agent/ # vendored upstream + extension system (pi-typed, stays here)
|
||||
gsd-agent-core/ # NEW — GSD session orchestration layer
|
||||
gsd-agent-modes/ # NEW — GSD run modes and CLI layer
|
||||
```
|
||||
|
||||
### Dependency graph
|
||||
|
||||
```
|
||||
gsd-pi (binary)
|
||||
└── @gsd/agent-modes
|
||||
├── @gsd/agent-core
|
||||
│ ├── @gsd/pi-coding-agent
|
||||
│ ├── @gsd/pi-agent-core
|
||||
│ └── @gsd/pi-ai
|
||||
└── @gsd/pi-coding-agent
|
||||
├── @gsd/pi-agent-core
|
||||
├── @gsd/pi-ai
|
||||
└── @gsd/pi-tui
|
||||
```
|
||||
|
||||
Arrows point in one direction only. No cycles. The vendored pi packages have no knowledge of `@gsd/agent-core` or `@gsd/agent-modes`.
|
||||
|
||||
---
|
||||
|
||||
## Package Specifications
|
||||
|
||||
### `@gsd/agent-core` (`packages/gsd-agent-core/`)
|
||||
|
||||
**Purpose:** GSD's session orchestration layer. Owns the `AgentSession` class, compaction, bash execution, system prompt construction, and the `createAgentSession()` factory that wires everything together.
|
||||
|
||||
**Public API surface (exported from `index.ts`):**
|
||||
|
||||
```typescript
|
||||
// Primary factory — the entry point for everything above this layer
|
||||
export { createAgentSession, CreateAgentSessionOptions, CreateAgentSessionResult } from './sdk.js'
|
||||
|
||||
// Session class and types
|
||||
export { AgentSession, AgentSessionEvent } from './agent-session.js'
|
||||
|
||||
// Supporting types consumed by modes and extensions
|
||||
export { CompactionOrchestrator } from './compaction/index.js'
|
||||
export { BashExecutor } from './bash-executor.js'
|
||||
export { SystemPromptBuilder } from './system-prompt.js'
|
||||
export { LifecycleHooks } from './lifecycle-hooks.js'
|
||||
export { ArtifactManager } from './artifact-manager.js'
|
||||
export { BlobStore } from './blob-store.js'
|
||||
```
|
||||
|
||||
**Files migrating in from `pi-coding-agent/src/core/`:**
|
||||
|
||||
| File | Notes |
|
||||
|---|---|
|
||||
| `agent-session.ts` | Core session class — 98KB, primary migration target |
|
||||
| `sdk.ts` | `createAgentSession()` factory |
|
||||
| `compaction/compaction.ts` | Context window orchestration |
|
||||
| `compaction/branch-summarization.ts` | Summarization on fork |
|
||||
| `compaction/utils.ts` | Shared compaction utilities |
|
||||
| `system-prompt.ts` | GSD system prompt construction |
|
||||
| `bash-executor.ts` | Bash runtime with GSD integration |
|
||||
| `fallback-resolver.ts` | Model fallback strategy |
|
||||
| `lifecycle-hooks.ts` | Phase hook system |
|
||||
| `image-overflow-recovery.ts` | Context overflow recovery |
|
||||
| `contextual-tips.ts` | Help text system |
|
||||
| `keybindings.ts` | Keyboard binding manager |
|
||||
| `artifact-manager.ts` | Blob artifact storage |
|
||||
| `blob-store.ts` | External binary data management |
|
||||
| `export-html/` | Session HTML export |
|
||||
|
||||
**Key dependency note:** `agent-session.ts` imports pi types directly (`Agent`, `AgentEvent`, `AgentMessage`, `AgentState`, `AgentTool`, `ThinkingLevel` from `@gsd/pi-agent-core`; `Model`, `Message` from `@gsd/pi-ai`). This is intentional — GSD's session layer is pi-typed, not abstracting over pi. This makes the seam a clear seam, not an abstraction.
|
||||
|
||||
---
|
||||
|
||||
### `@gsd/agent-modes` (`packages/gsd-agent-modes/`)
|
||||
|
||||
**Purpose:** GSD's run-mode and CLI layer. Assembles the agent session (from `@gsd/agent-core`) with a specific interface: interactive TUI, headless RPC server, or print output. Contains the `main()` entry point logic invoked by the `gsd` binary.
|
||||
|
||||
**Public API surface (exported from `index.ts`):**
|
||||
|
||||
```typescript
|
||||
export { runInteractiveMode } from './modes/interactive/index.js'
|
||||
export { runRpcMode, RpcMode } from './modes/rpc/index.js'
|
||||
export { runPrintMode } from './modes/print/index.js'
|
||||
export { RpcClient } from './modes/rpc/rpc-client.js'
|
||||
export { parseArgs, GsdArgs } from './cli/args.js'
|
||||
export { main } from './main.js'
|
||||
```
|
||||
|
||||
**Files migrating in from `pi-coding-agent/src/`:**
|
||||
|
||||
| Directory/File | Notes |
|
||||
|---|---|
|
||||
| `modes/interactive/` | Full TUI interactive mode (~30 component files) |
|
||||
| `modes/rpc/` | RPC server, client, JSON protocol, remote terminal |
|
||||
| `modes/print/` | Print/headless mode |
|
||||
| `modes/shared/` | Shared mode utilities and UI context setup |
|
||||
| `cli/args.ts` | CLI argument parsing |
|
||||
| `cli/config-selector.ts` | Config directory selection |
|
||||
| `cli/session-picker.ts` | Session picker UI |
|
||||
| `cli/list-models.ts` | Model listing |
|
||||
| `cli/file-processor.ts` | File input processing |
|
||||
| `main.ts` | Entry point logic |
|
||||
|
||||
---
|
||||
|
||||
### `pi-coding-agent` (what remains)
|
||||
|
||||
After the migration, `pi-coding-agent` contains:
|
||||
|
||||
- **Upstream tools** (`src/core/tools/`) — bash, read, edit, write, find, grep, ls, hashline tools
|
||||
- **Upstream agent infrastructure** — auth storage, model registry, upstream session manager
|
||||
- **Extension system** (`src/core/extensions/`) — loader, runner, types, wrapper
|
||||
|
||||
The extension system remains here because it is legitimately pi-typed. Extensions subscribe to pi events (`session_start`, `tool_execution_start`, `model_select`, etc.) and receive pi types in their handlers. Moving the extension system out of `pi-coding-agent` would require re-expressing those types in GSD terms, which is the abstraction-layer work explicitly out of scope for this phase.
|
||||
|
||||
**Required update to extension loader:**
|
||||
|
||||
`src/core/extensions/loader.ts` maintains a `STATIC_BUNDLED_MODULES` map of packages that extensions can import at runtime. After the migration, `@gsd/agent-core` and `@gsd/agent-modes` must be added to this map so that extensions importing those packages continue to resolve correctly in compiled Bun binaries:
|
||||
|
||||
```typescript
|
||||
// Before (current)
|
||||
const STATIC_BUNDLED_MODULES = {
|
||||
"@gsd/pi-agent-core": _bundledPiAgentCore,
|
||||
"@gsd/pi-ai": _bundledPiAi,
|
||||
"@gsd/pi-tui": _bundledPiTui,
|
||||
"@gsd/pi-coding-agent": _bundledPiCodingAgent,
|
||||
// ...
|
||||
}
|
||||
|
||||
// After
|
||||
const STATIC_BUNDLED_MODULES = {
|
||||
"@gsd/pi-agent-core": _bundledPiAgentCore,
|
||||
"@gsd/pi-ai": _bundledPiAi,
|
||||
"@gsd/pi-tui": _bundledPiTui,
|
||||
"@gsd/pi-coding-agent": _bundledPiCodingAgent,
|
||||
"@gsd/agent-core": _bundledGsdAgentCore, // NEW
|
||||
"@gsd/agent-modes": _bundledGsdAgentModes, // NEW
|
||||
// ...
|
||||
}
|
||||
```
|
||||
|
||||
---
|
||||
|
||||
## How Pi Updates Work After This Change
|
||||
|
||||
1. Download the new pi-mono release for the four vendored packages
|
||||
2. Copy the upstream source into `packages/pi-agent-core/`, `pi-ai/`, `pi-tui/`, `pi-coding-agent/`
|
||||
- Do not touch `packages/gsd-agent-core/` or `packages/gsd-agent-modes/`
|
||||
3. Run `tsc --noEmit` (or the build) across the workspace
|
||||
4. Fix type errors in `@gsd/agent-core` and `@gsd/agent-modes` only
|
||||
5. If upstream changed the extension event API, fix extension system integration in `pi-coding-agent/src/core/extensions/`
|
||||
|
||||
Steps 2-5 are scoped to known files. No archaeology required.
|
||||
|
||||
---
|
||||
|
||||
## Known Issues to Fix During Migration
|
||||
|
||||
| Issue | Location | Fix |
|
||||
|---|---|---|
|
||||
| Internal-path import of `AgentSessionEvent` | `src/web/bridge-service.ts` | Import from `@gsd/agent-core` public export |
|
||||
| `clearQueue()` not in typed public API | `AgentSession` | Add to public interface in `@gsd/agent-core/index.ts` |
|
||||
| `buildSessionContext()` on `SessionManager` | Used by GSD code, not publicly exported | Evaluate: re-export from `@gsd/agent-core` or remove dependency |
|
||||
| Deprecated `session_switch`, `session_fork`, `session_directory` usage | 2+ files in `pi-coding-agent` | Migrate to `session_start` with `reason` field (required for v0.65.0 compat) — can be done as part of or after clean seam work |
|
||||
|
||||
---
|
||||
|
||||
## Consequences
|
||||
|
||||
### Positive
|
||||
|
||||
- Pi updates are scoped: type errors from a pi update surface only in the two new GSD packages, not scattered across mixed source
|
||||
- The module system enforces the boundary: a pi file importing `@gsd/agent-core` is a compiler error, not a convention violation
|
||||
- Phase 2 (moving pi packages to npm) becomes a package.json change rather than a file archaeology project
|
||||
- Headless/RPC consumers can depend on `@gsd/agent-core` without pulling in the TUI layer
|
||||
|
||||
### Negative
|
||||
|
||||
- One-time migration cost: ~79 file moves, import path updates across the codebase, two new `package.json` files, build script update
|
||||
- The virtual module map in `extensions/loader.ts` grows by two entries and requires matching bundle imports at compile time
|
||||
- Maintainers need to understand the new three-layer structure (`pi-coding-agent` → `agent-core` → `agent-modes`) when debugging
|
||||
|
||||
### Neutral
|
||||
|
||||
- End-user install experience (`npm install -g gsd-pi@latest`) is unchanged
|
||||
- Extension authors see no change — the extension API surface remains in `@gsd/pi-coding-agent`
|
||||
- GSD packages continue to use pi types directly — no new abstraction layer
|
||||
|
||||
---
|
||||
|
||||
## Alternatives Considered
|
||||
|
||||
### Single `@gsd/agent` package
|
||||
|
||||
Move everything into one package instead of two. Simpler dependency graph but creates a large package where session logic and TUI logic share a build unit. Rejected because headless/RPC use cases would pull in the TUI unnecessarily, and the two concerns have meaningfully different consumers.
|
||||
|
||||
### Directory convention within `pi-coding-agent` (no new packages)
|
||||
|
||||
Add a `src/gsd/` subdirectory inside `pi-coding-agent` to clearly mark GSD files without creating new packages. Fastest to implement but the seam is a convention, not enforced by the module system. A future accidental cross-import would not be caught by the compiler. Rejected because the enforcement value of proper packages is worth the modest extra setup.
|
||||
|
||||
### Move to npm dependencies now (Phase 2 first)
|
||||
|
||||
Take `@mariozechner/pi-*` from npm and skip vendoring entirely. Blocked by `@gsd/native` imports baked into the vendored source, ~50 direct source modification commits, and the upstream extension API gap. Deferred to Phase 2.
|
||||
|
||||
---
|
||||
|
||||
## Implementation Notes
|
||||
|
||||
The migration should proceed in this order to maintain a working build at each step:
|
||||
|
||||
1. **Audit** — identify all imports of `pi-coding-agent` internal paths (non-index) and document them
|
||||
2. **Create packages** — scaffold `gsd-agent-core` and `gsd-agent-modes` with `package.json` and empty `index.ts`
|
||||
3. **Move files in batches** — start with leaf files (no downstream dependents within pi-coding-agent), work toward `agent-session.ts` last
|
||||
4. **Fix imports incrementally** — TypeScript will identify broken imports after each batch
|
||||
5. **Update extension loader** — add new packages to virtual module map
|
||||
6. **Update build script** — insert new packages in dependency order
|
||||
7. **Verify** — full build, existing tests pass, `gsd --version` works
|
||||
|
||||
The pi update to v0.67.2 (and the deprecated API migration) can be done as a follow-on once the clean seam is in place, since that work will be dramatically simpler with the new structure.
|
||||
111
docs/dev/PRD-pi-clean-seam-refactor.md
Normal file
111
docs/dev/PRD-pi-clean-seam-refactor.md
Normal file
|
|
@ -0,0 +1,111 @@
|
|||
# PRD: Pi Clean Seam Refactor
|
||||
|
||||
**Author:** Tom Boucher
|
||||
**Date:** 2026-04-14
|
||||
**ADR:** [ADR-010-pi-clean-seam-architecture.md](./ADR-010-pi-clean-seam-architecture.md)
|
||||
**Priority:** High — blocks safe pi-mono upstream updates
|
||||
|
||||
---
|
||||
|
||||
## Problem Statement
|
||||
|
||||
GSD is built on top of pi-mono, an open-source agent framework maintained by Mario Zechner at [github.com/badlogic/pi-mono](https://github.com/badlogic/pi-mono). GSD takes pi-mono as vendored source copies — four packages (`pi-agent-core`, `pi-ai`, `pi-tui`, `pi-coding-agent`) are copied directly into `/packages/` and modified in-place.
|
||||
|
||||
This worked as a starting point but has created a structural problem: **GSD-authored code lives inside the pi packages**. The 98KB `agent-session.ts`, the compaction system, three run modes (interactive, RPC, print), the CLI utilities, and the `createAgentSession()` factory are all authored by GSD but stored inside `pi-coding-agent`. Approximately 79 GSD-authored TypeScript files are mixed in with pi's upstream source.
|
||||
|
||||
The consequence is that every pi-mono update requires manually diffing GSD's modifications against the incoming upstream changes file-by-file. There is no reliable way to tell which files are GSD's and which are pi's without reading them. Updates that should take hours become multi-day archaeology projects. Pi-mono is currently 10 versions behind upstream (0.57.1 vs 0.67.2 as of April 2026), with a blocking API change (`session_switch`/`session_fork` removal in v0.65.0) unresolved.
|
||||
|
||||
Beyond update pain, there is a project risk: if pi-mono stops being maintained or changes direction, GSD's business logic is entangled with a dependency it no longer controls.
|
||||
|
||||
## Vision
|
||||
|
||||
GSD's code is clearly separated from pi's code at the module system level. The vendored pi packages contain only upstream code (plus the extension system, which is intentionally pi-typed). GSD's agent logic lives in GSD-owned packages that **depend on** pi but do not live inside it. When a new pi release comes out, a maintainer updates the vendored pi packages, runs the TypeScript compiler, and fixes the errors that surface in the GSD packages — without ever needing to diff individual files to find what's ours vs. theirs.
|
||||
|
||||
## Success Criteria
|
||||
|
||||
| Criterion | Measurement |
|
||||
|-----------|-------------|
|
||||
| Zero GSD business logic in vendored pi packages | `pi-coding-agent/src/` contains no files that import from `@gsd/` packages (except the extension system's bundled module map) |
|
||||
| Module boundary is compiler-enforced | TypeScript `paths` config or package `exports` prevents pi packages from importing GSD packages |
|
||||
| Applying a pi-mono update is scoped | Updating pi packages produces type errors only in `@gsd/agent-core` and `@gsd/agent-modes` — no changes required in pi package source files |
|
||||
| Install experience is unchanged | `npm install -g gsd-pi@latest` produces an identical binary from the user's perspective |
|
||||
| Existing extensions continue to work | All built-in GSD extensions load and execute without modification |
|
||||
| Build time does not regress significantly | Full build completes within 120% of current baseline |
|
||||
|
||||
## Non-Goals
|
||||
|
||||
- **Not** moving pi packages from vendored source to npm dependencies (that is a potential Phase 2)
|
||||
- **Not** creating an abstraction layer that hides pi types from GSD code — GSD packages may freely use pi's `AgentMessage`, `Model`, `TUI`, etc.
|
||||
- **Not** upstreaming GSD's modifications to pi-mono (desirable long-term but out of scope)
|
||||
- **Not** changing the published npm package name, install command, or any user-facing CLI behavior
|
||||
- **Not** removing or replacing the extension system — it stays in `pi-coding-agent` and remains typed against pi's types
|
||||
|
||||
## Stakeholders
|
||||
|
||||
- **Maintainers applying pi updates** — primary beneficiary; this work directly reduces their update burden
|
||||
- **Extension authors** — must not be broken; the extension API surface stays in `@gsd/pi-coding-agent`
|
||||
- **End users** — not impacted; the refactor is entirely internal
|
||||
|
||||
## Requirements
|
||||
|
||||
### R1 — New package: `@gsd/agent-core`
|
||||
|
||||
A new workspace package at `packages/gsd-agent-core/` that owns all GSD session orchestration logic. It depends on `@gsd/pi-coding-agent`, `@gsd/pi-agent-core`, and `@gsd/pi-ai`. Nothing in the vendored pi packages depends on it.
|
||||
|
||||
Must contain:
|
||||
- `agent-session.ts` and all `AgentSession` types
|
||||
- `compaction/` (orchestrator, branch summarization, utilities)
|
||||
- `system-prompt.ts`
|
||||
- `bash-executor.ts`
|
||||
- `fallback-resolver.ts`
|
||||
- `lifecycle-hooks.ts`
|
||||
- `image-overflow-recovery.ts`
|
||||
- `contextual-tips.ts`
|
||||
- `keybindings.ts`
|
||||
- `sdk.ts` (the `createAgentSession()` factory — the primary public API of this package)
|
||||
- `artifact-manager.ts`, `blob-store.ts`
|
||||
- `export-html/`
|
||||
|
||||
### R2 — New package: `@gsd/agent-modes`
|
||||
|
||||
A new workspace package at `packages/gsd-agent-modes/` that owns all run-mode and CLI code. It depends on `@gsd/agent-core`, `@gsd/pi-coding-agent`, and `@gsd/pi-tui`. It is the layer the top-level `gsd-pi` binary entry point assembles.
|
||||
|
||||
Must contain:
|
||||
- `modes/interactive/` (full TUI interactive mode and all components)
|
||||
- `modes/rpc/` (RPC server, RPC client, JSON protocol)
|
||||
- `modes/print/` (print/headless mode)
|
||||
- `cli/` (arg parsing, config selector, session picker, model lister, file processor)
|
||||
- `main.ts` entry point logic
|
||||
|
||||
### R3 — `pi-coding-agent` contains only upstream code and the extension system
|
||||
|
||||
After the migration, the vendored `pi-coding-agent` source must not contain files that:
|
||||
- Import from `@gsd/agent-core` or `@gsd/agent-modes`
|
||||
- Contain GSD business logic (compaction, session management, run modes, CLI)
|
||||
|
||||
The extension system (`src/core/extensions/`) remains in `pi-coding-agent` because it is legitimately pi-typed: extension authors write against pi's `AgentMessage`, `Model`, and `TUI` types. The virtual module map in `extensions/loader.ts` must be updated to include `@gsd/agent-core` and `@gsd/agent-modes` so extensions can import from them.
|
||||
|
||||
### R4 — Public API surfaces are explicit
|
||||
|
||||
Each new package must have an `index.ts` that declares its public API. Internal files must not be imported by path from outside the package. Specifically:
|
||||
- `web/bridge-service.ts` currently imports `AgentSessionEvent` from an internal path in `pi-coding-agent` — this must be fixed to use the public export from `@gsd/agent-core`
|
||||
- Any other internal-path imports identified during migration must be fixed
|
||||
|
||||
### R5 — Build order is updated
|
||||
|
||||
The workspace build script must be updated to build packages in dependency order:
|
||||
1. `@gsd/pi-agent-core`, `@gsd/pi-ai`, `@gsd/pi-tui` (parallel, no dependencies between them)
|
||||
2. `@gsd/pi-coding-agent`
|
||||
3. `@gsd/agent-core`
|
||||
4. `@gsd/agent-modes`
|
||||
5. `gsd-pi` (top-level binary)
|
||||
|
||||
### R6 — No change to the extension loader's public interface
|
||||
|
||||
Extensions are loaded by `pi-coding-agent`'s jiti-based loader. The virtual module map (`STATIC_BUNDLED_MODULES`) must be updated to resolve `@gsd/agent-core` and `@gsd/agent-modes` alongside the existing pi package mappings. This requires both a map entry and a top-level bundle import in `loader.ts` (see ADR-009 for the exact diff). Extension authors must not need to change their import paths.
|
||||
|
||||
## Open Questions
|
||||
|
||||
1. Does `clearQueue()` on `AgentSession` need to be added to a public type export, or is it already accessible to the auto-mode extension that uses it?
|
||||
2. Does `buildSessionContext()` on `SessionManager` need a public re-export from `@gsd/agent-core`?
|
||||
3. Should `@gsd/agent-modes` re-export `createAgentSession()` as a convenience, or should consumers always import it from `@gsd/agent-core` directly?
|
||||
Loading…
Add table
Reference in a new issue