如何在 Vim 里直接完成 Git 操作?
vim 是 linux 下一款很常用的文本编辑器,虽然它对初学者而言并不友好,但通过一些插件的配合,它可以被打造成一款很强大的 ide 。良许曾经介绍过三款很常用的插件,可点击以下链接查看:
本文再介绍一款 vim 编辑器中的一款很强大插件—— vim fugitive
。这款插件可以实现你在 vim 编辑器里直接完成 git 操作,而无需退出 vim 。更多 linux 精选干货电子书,可在公众号「良许linux」后台回复 「资料」获取。
这个插件是开源项目,我们可以在以下地址获取源码:
https://github.com/tpope/vim-fugitive
安装方法:
cd ~/.vim/bundle git clone https://github.com/tpope/vim-fugitive.git vim -u none -c "helptags vim-fugitive/doc" -c q
现在进行一些基本功能演示。假如现在有这么一段代码:
1 package main 2 3 import "fmt" 4 5 func main() { 6 x := true 7 items := []string{"tv", "pc", "tablet"} 8 9 if x { 10 for _, i := range items { 11 fmt.println(i) 12 } 13 } 14 }
现在我们将第 6 行删除,再修改第 9 行,同时在 11 行后添加一行代码。现在我们想查看这些修改,按往常做法,我们是先保存文档再退出,然后执行 git status 。
但现在,我们不必退出,直接在命令模式下输入 :gstatus ,直接就可以看到改动:
1 # on branch master 2 # your branch is up to date with 'origin/master'. 3 # 4 # changes not staged for commit: 5 # (use "git add <file>..." to update what will be committed) 6 # (use "git checkout -- <file>..." to discard changes in working directory) 7 # 8 # modified: vim-5plugins/examples/test1.go 9 # 10 no changes added to commit (use "git add" and/or "git commit -a") -------------------------------------------------------------------------------------------------------- 1 package main 2 3 import "fmt" 4 _ 5 func main() { 6 items := []string{"tv", "pc", "tablet"} 7 ~ 8 if len(items) > 0 { 9 for _, i := range items { 10 fmt.println(i) + 11 fmt.println("------") 12 } 13 } 14 }
如结果所示,vim fugitive 打开了一个有上下分屏的界面,上面一半,跟我们平常执行 git status 看到的结果一样,下面一半,就是具体发动内容,跟 git diff 类似。
2020 精选 阿里/腾讯等一线大厂 面试、简历、进阶、电子书 公众号「良许linux」后台回复「资料」免费获取
在下半屏里,有三个符号:_
表示在第 5 行与第 6 行之间有代码被删除,~
表示在第 8 行代码被修改过,+
表示 11 行新增了代码。
同样的,我们可以查看每行代码是谁改的,可以用 git blame ,而在这里对应的是 gblame 。
e9949066 (alvin yan 2019-6-7 18:17:19 -0500)│ 1 package main e9949066 (alvin yan 2019-6-7 18:17:19 -0500)│ 2 e9949066 (alvin yan 2019-6-7 18:17:19 -0500)│ 3 import "fmt" e9949066 (alvin yan 2019-6-7 18:17:19 -0500)│ 4 e9949066 (alvin yan 2019-6-7 18:17:19 -0500)│_ 5 func main() { e9949066 (alvin yan 2019-6-7 18:17:19 -0500)│ 6 items := []string{"tv", "pc", "tablet"} e9949066 (alvin yan 2019-6-7 18:17:19 -0500)│ 7 00000000 (not committed yet 2019-6-7 18:55:00 -0500)│~ 8 if len(items) > 0 { e9949066 (alvin yan 2019-6-7 18:17:19 -0500)│ 9 for _, i := range items { e9949066 (alvin yan 2019-6-7 18:17:19 -0500)│ 10 fmt.println(i) 00000000 (not committed yet 2019-6-7 18:55:00 -0500)│+ 11 fmt.println("------") e9949066 (alvin yan 2019-6-7 18:17:19 -0500)│ 12 } e9949066 (alvin yan 2019-6-7 18:17:19 -0500)│ 13 } e9949066 (alvin yan 2019-6-7 18:17:19 -0500)│ 14 }
我们同样也看到第 8 和 11 行还没有提交。
现在我们想要提交我们的改动,可以敲入 :gcommit 命令。vim fugitive 将打开另外一块区域,我们可以在里面写入要提交的信息。
1 vim-5plugins: updated test1.go example file 2 # please enter the commit message for your changes. lines starting 3 # with '#' will be ignored, and an empty message aborts the commit. 4 # 5 # on branch master 6 # your branch is up to date with 'origin/master'. 7 # 8 # changes to be committed: 9 # modified: vim-5plugins/examples/test1.go 10 #
然后我们就可以执行 :wq 结束提交。
[master c3bf80f] vim-5plugins: updated test1.go example file 1 file changed, 2 insertions(+), 2 deletions(-) press enter or type command to continue
我们同样可以继续使用 :gstatus 来查看提交后的状态,也可以使用 :gpush 将提交推送到远程仓库。
1 # on branch master 2 # your branch is ahead of 'origin/master' by 1 commit. 3 # (use "git push" to publish your local commits) 4 # 5 nothing to commit, working tree clean
以上这些是 vim fugitive 最基础的用法,如果想学习它的更高级用法,可以去它的 github仓库查看,那里有更详细的教程。
看完的都是真爱,点个赞再走呗?您的「三连」就是良许持续创作的最大动力!
- 关注原创公众号「良许linux」,第一时间获取最新linux干货!
- 公众号后台回复【资料】【面试】【简历】获取精选一线大厂面试、自我提升、简历等资料。
- 关注我的博客:
上一篇: C# 基本语法