pi-edit-session-in-place
pi extension that lets you re-edit or delete an earlier user message in the current session branch
Package details
Install pi-edit-session-in-place from npm and Pi will load the resources declared by the package manifest.
$ pi install npm:pi-edit-session-in-place- Package
pi-edit-session-in-place- Version
0.1.8- Published
- May 2, 2026
- Downloads
- 952/mo · 154/wk
- Author
- fitchmultz
- License
- MIT
- Types
- extension
- Size
- 26.7 KB
- Dependencies
- 0 dependencies · 2 peers
Pi manifest JSON
{
"extensions": [
"./extensions"
]
}Security note
Pi packages can execute code and influence agent behavior. Review the source before installing third-party packages.
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:
@mariozechner/pi-coding-agent0.72.0@mariozechner/pi-tui0.72.0- Node.js
>=20.6.0
Local development and verification in this repo target pi 0.72.0. @mariozechner/pi-coding-agent stays in devDependencies for local typechecking and tests, while pi core packages are declared as wildcard peers and the extension relies on pi's bundled runtime packages at execution time.
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-place
Or install directly from GitHub with pi:
pi install https://github.com/fitchmultz/pi-edit-session-in-place
Then reload pi from inside the app with:
/reload
Usage
Inside pi:
/edit-turn
Or press:
Ctrl+Shift+E
Message 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.ts
Local verification:
npm run verify
That 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