pi-edit-session-in-place
v0.1.14
Published
pi extension that lets you re-edit or delete an earlier user message in the current session branch
Maintainers
Readme
pi edit-session-in-place
A pi extension that lets you rewind to an earlier user message in the current branch, then either edit it in place or delete it and continue from there.
Compatibility
Tested with:
@earendil-works/pi-coding-agent0.78.0@earendil-works/pi-tui0.78.0- Node.js
>=22 <25
Local development and verification in this repo target pi 0.78.0. @earendil-works/pi-coding-agent and @earendil-works/pi-tui stay in devDependencies for local typechecking and tests, while pi core packages are declared as optional wildcard peers and the extension relies on pi's bundled runtime packages at execution time. That keeps installs forward-open for future pi releases: npm peer ranges should not block users from trying a newer pi, though runtime behavior is only verified against the tested baseline until a follow-up package release confirms it.
What it does
- Adds
/edit-turn - Adds a global hotkey:
Ctrl+Shift+E - Lets you choose an earlier user message from the current branch
- Rewinds pi to that point in the same session file
- Loads your edited text back into the main editor
- Treats an empty submit as delete this message and continue from here
Install
Install from npm with pi:
pi install npm:pi-edit-session-in-placeOr install directly from GitHub with pi:
pi install https://github.com/fitchmultz/pi-edit-session-in-placeThen reload pi from inside the app with:
/reloadUsage
Inside pi:
/edit-turnOr press:
Ctrl+Shift+EMessage picker behavior
- Shows earlier user messages from the current branch only
- Uses a viewport so long threads stay navigable
- Orders messages oldest → newest
- Starts with the newest message selected at the bottom
↑moves to older messages,↓moves to newer onesPageUp/PageDownjump faster
Editor behavior
Ctrl+Xclears the entire selected message instantlyEntersubmits the edited messageShift+Enterinserts a newlineEscapecancels without changing historyCtrl+Gopens your external editor if$VISUALor$EDITORis set
If you clear the message and submit an empty value, the selected message is effectively deleted: pi rewinds to just before that message and leaves the main editor empty so you can type a new prompt.
Behavior notes
- Works in interactive mode; non-interactive modes do not show the picker/editor UI
- Later messages on the abandoned branch are not deleted from the session file; they remain reachable through
/tree - If the selected message contains images, the extension warns that re-editing or deleting it will drop the images and keep only text behavior
- The extension only offers text-bearing user messages for editing; image-only or whitespace-only user messages are skipped
- Queued messages must be cleared before using the command
Development
For local development you can point pi at the extension directly:
pi -e ./extensions/edit-session-in-place.tsLocal verification:
npm run verifyThat runs:
npm test— compiles the TypeScript test fixtures to.test-dist/and runs them with Node's built-in test runnernpm run typecheck— strict TypeScript type-checkingnpm pack --dry-run— publishability check for the npm package contents
Current regression coverage in tests/edit-session-in-place.test.ts includes:
- message extraction from mixed session content
- oldest-to-newest ordering for the picker
- skipping image-only and whitespace-only user messages
- preserving the image-warning flag for mixed text+image messages
$VISUAL/$EDITORresolution rules- external editor command parsing with quoting/escaping
- trimming exactly one trailing newline from external-editor output
Files
extensions/edit-session-in-place.ts— publishable extension implementationtests/edit-session-in-place.test.ts— regression tests for message extraction, ordering, and external-editor helpers
