Keybindings(快捷键)

本页面是 Pi 官方文档 的中文翻译。仅供学习参考。

所有键盘快捷键可通过 ~/.pi/agent/keybindings.json 自定义。每个操作可绑定一个或多个按键。

配置文件使用 Pi 内部使用的相同命名空间快捷键 ID,扩展作者在 keyHint() 和注入的 keybindings 管理器中也使用这些 ID。

使用旧的非命名空间 ID(如 cursorUpexpandTools)的旧配置在启动时会自动迁移到命名空间 ID。

编辑 keybindings.json 后,运行 /reload 在 Pi 中应用更改,无需重启会话。

按键格式

格式:modifier+key,修饰键包括 ctrlshiftalt(可组合),按键包括:

  • 字母键a-z
  • 数字键0-9
  • 特殊键escapeescenterreturntabspacebackspacedeleteinsertclearhomeendpageUppageDownupdownleftright
  • 功能键f1f12
  • 符号`-=[]\;',./!@#$%^&*()_+|~{}:<>?

修饰键组合示例:ctrl+shift+xalt+ctrl+xctrl+shift+alt+xctrl+1 等。

所有操作

TUI 编辑器光标移动

ID默认键说明
tui.editor.cursorUpup光标上移
tui.editor.cursorDowndown光标下移
tui.editor.cursorLeftleftctrl+b光标左移
tui.editor.cursorRightrightctrl+f光标右移
tui.editor.cursorWordLeftalt+leftctrl+leftalt+b光标左移一个单词
tui.editor.cursorWordRightalt+rightctrl+rightalt+f光标右移一个单词
tui.editor.cursorLineStarthomectrl+a移至行首
tui.editor.cursorLineEndendctrl+e移至行尾
tui.editor.jumpForwardctrl+]向前跳转至字符
tui.editor.jumpBackwardctrl+alt+]向后跳转至字符
tui.editor.pageUppageUp上翻页
tui.editor.pageDownpageDown下翻页

TUI 编辑器删除

ID默认键说明
tui.editor.deleteCharBackwardbackspace删除前一个字符
tui.editor.deleteCharForwarddeletectrl+d删除后一个字符
tui.editor.deleteWordBackwardctrl+walt+backspace向前删除一个单词
tui.editor.deleteWordForwardalt+dalt+delete向后删除一个单词
tui.editor.deleteToLineStartctrl+u删除到行首
tui.editor.deleteToLineEndctrl+k删除到行尾

TUI 输入

ID默认键说明
tui.input.newLineshift+enter插入新行
tui.input.submitenter提交输入
tui.input.tabtabTab / 自动补全

TUI Kill Ring

ID默认键说明
tui.editor.yankctrl+y粘贴最近删除的文本
tui.editor.yankPopalt+y在 yank 后循环已删除文本
tui.editor.undoctrl+-撤销上次编辑

TUI 剪贴板和选择

ID默认键说明
tui.input.copyctrl+c复制选中
tui.select.upup向上移动选择
tui.select.downdown向下移动选择
tui.select.pageUppageUp列表中向上翻页
tui.select.pageDownpageDown列表中向下翻页
tui.select.confirmenter确认选择
tui.select.cancelescapectrl+c取消选择

应用程序

ID默认键说明
app.interruptescape取消/中断
app.clearctrl+c清空编辑器
app.exitctrl+d退出(编辑器为空时)
app.suspendctrl+z(Windows 上无)挂起到后台
app.editor.externalctrl+g在外部编辑器打开($VISUAL$EDITOR
app.clipboard.pasteImagectrl+v(Windows 为 alt+v从剪贴板粘贴图像

会话

ID默认键说明
app.session.new开始新会话(/new
app.session.tree打开会话树导航器(/tree
app.session.fork分叉当前会话(/fork
app.session.resume打开会话恢复选择器(/resume
app.session.togglePathctrl+p切换路径显示
app.session.toggleSortctrl+s切换排序模式
app.session.toggleNamedFilterctrl+n切换仅显示命名会话过滤器
app.session.renamectrl+r重命名会话
app.session.deletectrl+d删除会话
app.session.deleteNoninvasivectrl+backspace查询为空时删除会话

模型和思维

ID默认键说明
app.model.selectctrl+l打开模型选择器
app.model.cycleForwardctrl+p切换到下一个模型
app.model.cycleBackwardshift+ctrl+p切换到上一个模型
app.thinking.cycleshift+tab循环切换 thinking level
app.thinking.togglectrl+t折叠/展开 thinking block

显示和消息队列

ID默认键说明
app.tools.expandctrl+o折叠/展开工具输出
app.message.followUpalt+enter队列 follow-up 消息
app.message.dequeuealt+up恢复队列消息到编辑器

树导航

ID默认键说明
app.tree.foldOrUpctrl+leftalt+left折叠当前分支段,或跳转到上一个段起始
app.tree.unfoldOrDownctrl+rightalt+right展开当前分支段,或跳转到下一个段起始或分支结束
app.tree.editLabelshift+l编辑树节点上的标签
app.tree.toggleLabelTimestampshift+t切换树中标签时间戳显示
app.tree.filter.defaultctrl+d设置树过滤器为默认视图
app.tree.filter.noToolsctrl+t切换隐藏工具结果的树过滤器
app.tree.filter.userOnlyctrl+u切换仅显示用户消息的树过滤器
app.tree.filter.labeledOnlyctrl+l切换仅显示带标签条目的树过滤器
app.tree.filter.allctrl+a切换显示所有条目的树过滤器
app.tree.filter.cycleForwardctrl+o循环向前切换树过滤器
app.tree.filter.cycleBackwardshift+ctrl+o循环向后切换树过滤器

Scoped Models 选择器

在 scoped models 选择器(通过 /scoped-models 打开)内使用。

ID默认键说明
app.models.savectrl+s将当前模型选择保存到设置
app.models.enableAllctrl+a启用所有模型(或所有匹配当前搜索的)
app.models.clearAllctrl+x清除所有模型(或所有匹配当前搜索的)
app.models.toggleProviderctrl+p切换当前 Provider 的所有模型
app.models.reorderUpalt+up将选中模型在循环顺序中上移
app.models.reorderDownalt+down将选中模型在循环顺序中下移

自定义配置

创建 ~/.pi/agent/keybindings.json

{
  "tui.editor.cursorUp": ["up", "ctrl+p"],
  "tui.editor.cursorDown": ["down", "ctrl+n"],
  "tui.editor.deleteWordBackward": ["ctrl+w", "alt+backspace"]
}

每个操作可以有一个按键或一个按键数组。用户配置覆盖默认值。

在原生 Windows 上,app.suspend 没有默认绑定,因为 Windows 终端不支持 Unix 作业控制。如果手动绑定,Pi 会显示状态消息而非挂起。在 WSL 中,正常的 Linux ctrl+z/fg 行为仍然适用。

Emacs 风格示例

{
  "tui.editor.cursorUp": ["up", "ctrl+p"],
  "tui.editor.cursorDown": ["down", "ctrl+n"],
  "tui.editor.cursorLeft": ["left", "ctrl+b"],
  "tui.editor.cursorRight": ["right", "ctrl+f"],
  "tui.editor.cursorWordLeft": ["alt+left", "alt+b"],
  "tui.editor.cursorWordRight": ["alt+right", "alt+f"],
  "tui.editor.deleteCharForward": ["delete", "ctrl+d"],
  "tui.editor.deleteCharBackward": ["backspace", "ctrl+h"],
  "tui.input.newLine": ["shift+enter", "ctrl+j"]
}

Vim 风格示例

{
  "tui.editor.cursorUp": ["up", "alt+k"],
  "tui.editor.cursorDown": ["down", "alt+j"],
  "tui.editor.cursorLeft": ["left", "alt+h"],
  "tui.editor.cursorRight": ["right", "alt+l"],
  "tui.editor.cursorWordLeft": ["alt+left", "alt+b"],
  "tui.editor.cursorWordRight": ["alt+right", "alt+w"]
}

法律声明:本页面是 pi.dev 官方文档的中文翻译版本,仅供学习参考。本网站与 pi.dev 及 Earendil Inc. 无任何法律关系。