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

extension

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-agent 0.72.0
  • @mariozechner/pi-tui 0.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 ones
  • PageUp / PageDown jump faster

Editor behavior

  • Ctrl+X clears the entire selected message instantly
  • Enter submits the edited message
  • Shift+Enter inserts a newline
  • Escape cancels without changing history
  • Ctrl+G opens your external editor if $VISUAL or $EDITOR is 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 runner
  • npm run typecheck — strict TypeScript type-checking
  • npm 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/$EDITOR resolution 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 implementation
  • tests/edit-session-in-place.test.ts — regression tests for message extraction, ordering, and external-editor helpers