应用截图
❝GitButler 是一个重新被定义的 git 客户端,是2024年才可以产生的新的git工作流的管理工具。
从应用截图看,左边3列和传统的git客户端都有类似的功能;但是奇迹就发生右边的可拓展区,同一个工作区可以无限增加的多分支模式,让您同时在多个分支上工作。它允许您快速将文件更改组织到单独的分支中,同时仍然将它们应用到您的工作目录。然后,您可以将分支单独推送到远程,或直接创建拉取请求。
❝简而言之,它是
git add -p
和git rebase -i
的更灵活版本,允许您跨分支高效地执行多任务。
GitButler 在 Git 之上用一层跟踪未提交的更改。对文件或文件部分内容的更改可以分到我们所说的虚拟分支。只要您对虚拟分支的内容感到满意,就可以将其推送到远程。GitButler 确保其他虚拟分支的状态保持独立。
虚拟分支
与 Git 分支有何不同?我们喜欢 Git 的原因就是分支是完全独立开的,它们之间的切换是完整的上下文切换。GitButler 允许您在同一工作目录中并行处理多个分支。这实际上意味着多个分支的内容同时在一个工作区可用。
GitButler 在提交之前就知道更改。这使得它能够记录每个单独的差异属于哪个虚拟分支
。实际上,这意味着您可以随时将各个分支及其内容分开,以将它们推送到远程或从工作目录中取消应用它们。
最后,在 Git 中,您一般需要提前创建所需的分支,而使用 GitButler 您可以在开发过程中的任何时候在虚拟分支
之间移动更改。
大家开发的时候应该都是使用 Git 进行版本管理的。GitButler为什么能重新定义Git的工作流呢?跟他的创始人@schacon有关,他就是Pro Git的作者之一,相信这本书大家都或多或少的听过或者读过。与此同时,Git 的用户界面已经 15 年没有发生根本性改变,但如今大多数开发人员都有不同的工作流程和需求。
GitButler不是尝试将 Git CLI 的语义融入图形界面,而是从开发人员工作流程开始,并将其映射回 Git。
GitButler 是一个基于Tauri的应用程序。它的 UI 是使用TypeScript语言,用Svelte编写的,后端是用Rust编写的,从技术栈上看也是近期兴起的。
目前有macOS (Apple Silicon | Intel) · Linux (AppImage | deb)版本,因为是基于 Tauri 相信 Windows版本也会出(社区对于 Windows 的版本呼声很高,也已经有人在 WSL 上适配了 GitButler,但是无法登陆),大家还是等一等官方的 Windows 发布。
❝假设在开发一项功能时,您遇到了一个想要修复的错误。通常希望将修复程序作为单独的贡献(拉取请求)来提供。
使用 Git您可以存储更改并切换到另一个分支,您可以在其中提交并推送修复。
使用 GitButler只需将修复分配给一个单独的虚拟分支,您可以单独推送该分支(或直接创建 PR)。另一个好处是,您可以在等待 CI 和/或代码审查时将修复代码保留在工作目录中。
❝假设您想测试其他人的分支以进行代码审查。
使用 Git 尝试其他人的分支是与您自己的工作完全分开的上下文切换。
使用 GitButler,您可以直接在工作目录中应用和取消应用(添加/删除)任何远程分支。
虚拟分支需要有远程仓库支持
https://mpvideo.qpic.cn/0bc3aiadmaaasuah577hp5svaawdgybaanqa.f10002.mp4?