Project Icon

rebase-editor

轻量级终端编辑器优化Git交互式变基流程

rebase-editor是一个基于Node.js的Git交互式变基工具,通过简洁的终端界面提升操作效率。它支持多行选择、撤销重做、自定义键位和颜色配置,方便用户编辑提交顺序、合并或删除提交。兼容主流操作系统,适合开发者优化Git工作流程。

rebase-editor

Git交互式变基的简单终端序列编辑器。 使用Node.js编写,发布到npm,使用terminal-kit

构建状态 覆盖率状态

rebase-editor

2.0版本已发布 :sparkles: :camel: :boom:
新特性:选择多行、撤销更改、update-ref、rebase-merges!
查看更新日志了解详情。

安装

 npm install -g rebase-editor
 git config --global sequence.editor rebase-editor

注意:也可以使用Yarn:yarn global add rebase-editor

使用方法

终端会打印出Git创建的标准交互式变基文件,以及注释中的一些额外命令信息。 使用标准命令时,当前行的操作会更改为相应的操作:

命令:

  • p, pick = 使用提交
  • r, reword = 使用提交,但编辑提交信息
  • e, edit = 使用提交,但停止以进行修改
  • s, squash = 使用提交,但与前一个提交合并
  • f, fixup = 类似"squash",但丢弃此提交的日志消息
  • b, break = 在此处停止(稍后使用git rebase --continue继续变基)
  • d, drop = 删除提交

注意:不支持x, exec命令

支持的额外命令有:

  • DOWN/UP = 在行间移动光标
  • SHIFT_RIGHT/SHIFT_DOWN = 向下选择一行
  • SHIFT_LEFT/SHIFT_UP = 向上选择一行
  • RIGHT/CTRL_DOWN = 将当前行向下移动一个位置
  • LEFT/CTRL_UP = 将当前行向上移动一个位置
  • HOME/END/PAGE_UP/PAGE_DOWN = 移动光标并使用SHIFT选择
  • z, CTRL_Z = 撤销
  • Z, CTRL_SHIFT_Z = 重做
  • ENTER, q = 保存并退出
  • ESC, CTRL_C = 中止

要一次性使用不同的编辑器,可以使用GIT_SEQUENCE_EDITOR环境变量(将vi替换为你喜欢的编辑器):

GIT_SEQUENCE_EDITOR="vi" git rebase -i master

命令行参数

编辑器接受以下命令行参数:

  • -s, --status:在顶部打印状态行。对调试自定义键映射很有用。
  • -k, --keys:设置自定义键绑定。必须定义为.json文件或导出json对象的.js文件。
  • -c, --color:使用彩色编辑器输出。此参数接受一个额外的可选参数,以逗号分隔的terminal-kit样式字符字符串形式指定自定义颜色。你可以指定3种颜色,第一个用于行操作('pick'、'squash'等),第二个用于哈希,第三个用于消息。空字符串表示无特殊颜色。例如(-c ^r,^y,^b(红、黄、蓝)或-c ^r(仅为操作着色)或-c ,,^b(仅为消息着色))
  • -m, --marker:设置自定义标记以标记选定的行。它可以是任何字符串,如'>> ',或terminal-kit样式字符之一。默认值为'^!'(反转),除了Windows,因为那里不起作用(见#9),使用黄色代替:'^Y'。
  • --no-alternate-screen:禁用备用屏幕。(见#11)
  git config --global sequence.editor "rebase-editor -s -c -m '> ' -k ~/.rebase-editor-keybindings.json --"

注意:使用命令行参数时,命令应以--结尾,以分隔自定义参数和变基文件的文件名

自定义键绑定

键绑定必须是可以被require的文件,可以是JSON或导出简单对象的Node模块。 支持的特殊键由terminal-kit定义。

默认键绑定

{
  "UP": "up",
  "DOWN": "down",
  "LEFT": "moveUp",
  "CTRL_UP": "moveUp",
  "RIGHT": "moveDown",
  "CTRL_DOWN": "moveDown",
  "END": "end",
  "HOME": "home",
  "PAGE_DOWN": "pageDown",
  "PAGE_UP": "pageUp",
  "SHIFT_UP": "selectUp",
  "SHIFT_DOWN": "selectDown",
  "SHIFT_LEFT": "selectUp",
  "SHIFT_RIGHT": "selectDown",
  "SHIFT_PAGE_DOWN": "selectPageDown",
  "SHIFT_PAGE_UP": "selectPageUp",
  "SHIFT_HOME": "selectHome",
  "SHIFT_END": "selectEnd",
  "p": "pick",
  "r": "reword",
  "e": "edit",
  "s": "squash",
  "f": "fixup",
  "d": "drop",
  "BACKSPACE": "drop",
  "DELETE": "drop",
  "z": "undo",
  "CTRL_Z": "undo",
  "Z": "redo",
  "CTRL_SHIFT_Z": "redo",
  "q": "quit",
  "ENTER": "quit",
  "CTRL_C": "abort",
  "ESCAPE": "abort"
}

Mac键绑定注意事项

在Mac上,并非所有按键组合都能默认工作。最明显的是,没有修饰键可以与UP/DOWN一起使用(如SHIFT、CTRL、ALT、META/CMD)。Fn键可以使用,但它会转换为PAGE_UP/DOWN。因此,我决定将LEFT/RIGHT组合作为Mac的备选方案。但是,你可以手动配置你的终端。查看#8以获取如何操作的指南。

同样,CMD-Z、CMD-SHIFT-Z也不起作用(CMD根本不起作用)。所以我只使用z、Z作为撤销和重做。

它是否适用于...

平台支持
Mac
Linux
Windows是,但不适用于Git Bash (#7)

犯了错误?

git reflog是你的好朋友: git-reflog

卸载

npm remove -g rebase-editor
git config --global --unset sequence.editor

Yarn:yarn global remove rebase-editor

开发

测试

npm testnpm run tdd

为了调试,我一直在使用一个测试文件。

node index.js example

使用git进行调试:

GIT_SEQUENCE_EDITOR="./index.js" git rebase -i master

更新日志

v1.0.0

初始版本

v2.0.0

完全重写,采用新架构和测试驱动实现。

新特性:

  • 行选择。现在可以选择多行并一起移动或更改。使用Shift上/下(Mac除外),或Shift左/右进行选择。
  • 高亮行。现在选定的行会被高亮显示。
  • 支持drop命令,而不是删除行。
  • 撤销/重做。现在可以使用z、Z或CTRL_Z、CTRL_SHIFT_Z撤销和重做所有更改。
  • 自定义颜色。可以使用-c属性自定义颜色。

重大变更:

  • 颜色现在是选择加入而不是选择退出。随着新的行选择功能,我更喜欢无颜色。
  • 移除了剪切粘贴功能。替换为drop命令。
  • 将默认移动行键从u和d更改为CTRL_UP/CTRL_DOWN(Mac除外)或LEFT/RIGHT。可以通过自定义键映射恢复。

v2.0.5

新特性

  • 支持HOME、END、PAGE_UP和PAGE_DOWN

v2.0.6, v2.0.7

新特性

  • 支持break。添加一个带有break的新行。要删除该行,可以使用drop。

v2.0.8

新特性

  • 支持--update-refs。现在可以移动和删除update-ref行。
  • 支持--rebase-merges。现在可以移动和删除label、reset和merge行。

v2.0.9

错误修复

  • 分支注释没有内联放置。

待办事项

  • 支持exec命令
  • 添加和编辑label、reset、merge、update-refs命令

或者不做..我从未发现这个功能的用处,而且我不确定我希望工作流程和键映射如何工作。

贡献

欢迎提出意见和贡献,只需创建一个问题和/或拉取请求。

要开始,只需克隆仓库并运行npm install

要使用仓库中的示例文件进行手动测试:./index.js example

要使用git进行手动测试:GIT_SEQUENCE_EDITOR=./index.js git rebase -i HEAD^^^

在创建拉取请求之前,请确保运行测试npm test并检查测试覆盖率npm run cover。 我有完整的测试覆盖率,并希望保持这种状态。

致谢

感谢Node.js和wonderful terminal-kit项目。 还要感谢@perlun和@real-yfprojects的贡献。

另请参阅

还有git-interactive-rebase-tool,一个用Rust编写的类似工具。

项目侧边栏1项目侧边栏2
推荐项目
Project Cover

豆包MarsCode

豆包 MarsCode 是一款革命性的编程助手,通过AI技术提供代码补全、单测生成、代码解释和智能问答等功能,支持100+编程语言,与主流编辑器无缝集成,显著提升开发效率和代码质量。

Project Cover

AI写歌

Suno AI是一个革命性的AI音乐创作平台,能在短短30秒内帮助用户创作出一首完整的歌曲。无论是寻找创作灵感还是需要快速制作音乐,Suno AI都是音乐爱好者和专业人士的理想选择。

Project Cover

有言AI

有言平台提供一站式AIGC视频创作解决方案,通过智能技术简化视频制作流程。无论是企业宣传还是个人分享,有言都能帮助用户快速、轻松地制作出专业级别的视频内容。

Project Cover

Kimi

Kimi AI助手提供多语言对话支持,能够阅读和理解用户上传的文件内容,解析网页信息,并结合搜索结果为用户提供详尽的答案。无论是日常咨询还是专业问题,Kimi都能以友好、专业的方式提供帮助。

Project Cover

阿里绘蛙

绘蛙是阿里巴巴集团推出的革命性AI电商营销平台。利用尖端人工智能技术,为商家提供一键生成商品图和营销文案的服务,显著提升内容创作效率和营销效果。适用于淘宝、天猫等电商平台,让商品第一时间被种草。

Project Cover

吐司

探索Tensor.Art平台的独特AI模型,免费访问各种图像生成与AI训练工具,从Stable Diffusion等基础模型开始,轻松实现创新图像生成。体验前沿的AI技术,推动个人和企业的创新发展。

Project Cover

SubCat字幕猫

SubCat字幕猫APP是一款创新的视频播放器,它将改变您观看视频的方式!SubCat结合了先进的人工智能技术,为您提供即时视频字幕翻译,无论是本地视频还是网络流媒体,让您轻松享受各种语言的内容。

Project Cover

美间AI

美间AI创意设计平台,利用前沿AI技术,为设计师和营销人员提供一站式设计解决方案。从智能海报到3D效果图,再到文案生成,美间让创意设计更简单、更高效。

Project Cover

AIWritePaper论文写作

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

投诉举报邮箱: service@vectorlightyear.com
@2024 懂AI·鲁ICP备2024100362号-6·鲁公网安备37021002001498号