pi-workspace-history
Real workspace undo/redo for Pi. Bring Claude Code style /rewind and OpenCode /undo safety to @mariozechner/pi-coding-agent.
Package details
Install pi-workspace-history from npm and Pi will load the resources declared by the package manifest.
$ pi install npm:pi-workspace-history- Package
pi-workspace-history- Version
0.1.9- Published
- May 5, 2026
- Downloads
- 978/mo · 978/wk
- Author
- wcldyx1000
- License
- MIT
- Types
- extension
- Size
- 79.6 KB
- Dependencies
- 1 dependency · 1 peer
Pi manifest JSON
{
"extensions": [
".pi/extensions/workspace-history.ts"
]
}Security note
Pi packages can execute code and influence agent behavior. Review the source before installing third-party packages.
README
pi-workspace-history
给 Pi 补上真正可用的工作区级 Undo / Redo。
把接近 OpenCode 的 /undo 体验带给 Pi,并补上类似 Claude Code 那种让人敢放心改代码的工作区回退安全感。

为什么值得用
- 撤销的是整个工作区,不只是聊天记录
- 让你敢放心让 Agent 真改代码
- 通过
/tree恢复历史分支对应的工作区状态 - 通过
/checkpoint保护手动修改
这是什么
workspace-history 是一个面向 @mariozechner/pi-coding-agent 的工作区历史插件。
它不是单纯给 pi 增加一个 /undo 命令,而是要让聊天历史和本地工作区文件状态一起回到过去、回到未来、或切换到任意历史分支节点。
它的核心目标是:
当用户在历史聊天树中切换到任意节点时,
聊天上下文和工作区文件状态都应该同步恢复到那个节点对应的真实状态。
换句话说:
/tree是真正的时间机器/undo是沿着/tree向后导航一步的快捷命令/redo是回到刚才撤销前位置的快捷命令
这个插件有什么用
在使用 Agent 编程时,经常会遇到这些问题:
- Agent 改坏了代码
- Agent 误删了文件
- Agent 创建了很多无用文件
- 你想回到某个历史节点重新探索另一条路线
- 你在两轮 Agent 之间手动改过代码、创建过文件、删掉过文件
- 你不希望错误上下文继续污染后续推理
这个插件解决的不是“单步撤销文本编辑”,而是“把整个工作区和聊天状态一起时光穿梭”。
它的价值在于:
- 让
/undo真正撤销一整轮 Agent 的结果,而不只是恢复一部分文件 - 让
/tree不只是切换聊天视图,还能同步恢复工作区 - 让你安全地在历史分支之间来回切换
- 保留用户在 Agent 回合之间的手动修改语义
- 避免把插件内部状态污染进用户项目自己的 Git 历史
具体诉求
这个插件围绕下面这些明确诉求设计:
- 每轮 Agent 开始前,记录一份
before快照。 - 每轮 Agent 完成后,记录一份
after快照。 - 当用户通过
/tree、/undo、/redo切换历史节点时,工作区必须同步恢复。 /undo恢复的应该是“这一轮开始前的真实状态”,而不是简单回到上一轮 Agent 完成后的状态。- 如果用户在两轮 Agent 之间手动删了文件、改了代码、建了新文件,这些变化在下一轮开始前应被记录进
before snapshot。 - 如果当前工作区有还没有被快照保存的手动修改,插件不应该默默覆盖,而应该阻止切换,提示用户先
/checkpoint。 - 插件自己的内部状态应该和用户项目主 Git 历史隔离,不能污染用户仓库。
- 多个 session 之间的快照和 redo 状态应该相互隔离,不能串台。
主要功能
/undo- 回到最近一轮 Agent 开始前的工作区状态
- 把该轮用户 prompt 放回输入框,方便修改后重试
/redo- 回到刚才
/undo之前的位置 - 同步恢复对应的工作区状态
- 回到刚才
/checkpoint [label]- 保存当前工作区为一个手动检查点
- 用于保护尚未发送新 prompt 的手动修改
基于
/tree的工作区恢复- 切换历史节点时自动恢复对应的工作区状态
- 支持在不同历史分支之间来回切换
Dirty guard
- 如果当前工作区有未快照的手动修改,会阻止危险切换
- 默认要求先执行
/checkpoint
Session isolation
- 每个 session 使用独立的 shadow git 和 redo 状态
- 避免新会话
/undo时串到旧会话历史
工作方式
插件内部使用独立的 shadow git 来保存快照,而不是依赖用户项目本身的 .git 历史。
默认快照范围:
- Git tracked 文件
- 未被 ignore 的 untracked 文件
- 命中工作区
.gitignore的路径会被过滤掉,即使它们此前已经进入过快照范围
默认排除:
.git/.pi/workspace-history/node_modules/dist/build/.cache/.next/.turbo/coverage/.env.env.*
恢复时,插件只恢复它纳管的文件集合,不会粗暴地对整个工作区做无差别清理。
配置
通过 Pi 的 settings 配置:
- 全局:
~/.pi/agent/settings.json - 项目:
.pi/settings.json
示例:
{
"workspaceHistory": {
"storageDir": "D:\\pi-history",
"maxSessionsPerWorkspace": 3,
"maxWorkspaces": 10
}
}
配置项:
workspaceHistory.storageDir- shadow history 的外部存储根目录
- 默认:
~/.pi/agent/state/workspace-history
workspaceHistory.maxSessionsPerWorkspace- 每个工作区最多保留最近使用的 session 数
- 默认:
3
workspaceHistory.maxWorkspaces- 全局最多保留最近使用的工作区数
- 默认:
10
workspaceHistory.enabledauto(默认)会在非项目目录自动禁用插件true强制启用false完全禁用
workspaceHistory.allowHomeDirectory- 是否允许在用户 home 目录启用
- 默认:
false
workspaceHistory.requireProjectMarker- 是否要求存在
.git、package.json等项目标记 - 默认:
true
- 是否要求存在
workspaceHistory.maxScanFiles/workspaceHistory.maxScanDirs/workspaceHistory.maxScanMs- 工作区扫描的安全预算
workspaceHistory.gitTimeoutMs- 插件内部 git 操作超时时间
安装与使用
如果作为插件包安装:
pi install npm:pi-workspace-history
当这个包发布到 npm 后,用户就可以直接用上面的命令安装。
如果从本地仓库安装:
pi install /path/to/workspace-history
本地开发
当前仓库也支持项目内直接加载扩展,便于开发调试:
.pi/extensions/workspace-history.ts
.pi/settings.json
在这个目录启动 pi,或执行 /reload 后即可测试本地修改。
也可以把 workspace-history.ts 放到:
~/.pi/agent/extensions/.pi/extensions/
测试
运行自动化测试:
npm test
运行类型检查:
npm run typecheck
最近更新
- 历史默认存到工作区外
- 增加
workspaceHistory.storageDir - 增加 session / workspace 保留策略
- 通过缓存设置/路径和节流 cleanup 降低运行时开销
存储目录
插件默认把历史存到工作区外:
~/.pi/agent/state/workspace-history/
workspaces/
<workspaceHash>/
meta.json
sessions/
<sessionId>/
repo.git/
redo.json
meta.json
logs/
timemachine.log
说明:
- shadow git 与用户项目自身的
.git历史隔离 - 旧的工作区内
.pi/workspace-history/状态不会自动迁移 - 清理策略基于最近使用时间(LRU 风格)
- 在
auto模式下,插件会在像用户 home 目录这样的宽泛目录里自动禁用,避免启动扫描过大导致卡顿