本文共 1329 字,大约阅读时间需要 4 分钟。
在Emacs中使用git有很多中选择,比如古老的Emacs VC ,经典的, 强大的, 以及新潮的 / (egg是magit的一个分支)。
Emacs VC在Emacs中内置支持,配合后端,对各种版本控制工具如CVS、SVN、GIT、Hg等都能够支持,但是功能比较单一,操作方式简单而且古怪。
git.el 是git项目的官方工具,但是已经很久没有更新了,据说对git的有些特性并没有提供支持。
而magit和egg个人感觉还有待时间的检验。
所以这里选择的是git-emacs。
git clone 之后,只需要在Emacs配置文件中增加:
;;git-emacs(add-to-list 'load-path "/path/to/git-emacs/")(require 'git-emacs)
然后可以通过 M-x git-config-init 进行配置。
如果当前打开的文件所在的文件夹处于版本控制中,可以通过M-x git-status查看状态,如下图:
在这个界面下可以使用一些命令:
key | Command | Comment |
---|---|---|
p/n | 在所有文件之间上下移动 | |
P/N | 在变更过的文件之间上下移动 | |
</> | 定位到列表的头部/尾部 | |
v | 以只读方式打开文件 | |
m/u/SPC | 设置/取消/切换标记,标记用于批量处理文件 | |
a | 将文件加入版本控制 | |
i | 将文件加入ignore | |
c | 提交 |
其他命令可以参考此时出现的Git-Emacs菜单。
在状态清单中使用“c",或者在任何buffer中运行M-x git-commit/git-commit-all/git-commit-file,可以提交index/所有文件/当前文件。
提交时会要求填写注释,如下图:
填写注释后:
C-c C-c | 提交 |
C-c C-q | 取消 |
通过命令 M-x git-history可以查看整个工程的版本历史,M-x git-log可以查看当前标记文件的版本历史,两个命令都会打开一个新的buffer:
如果你很喜欢gitk,也可以通过M-x gitk(前提是已经安装了gitk)直接打开gitk窗口:
M-x git-branch:列出所有分支,在这里可以通过快捷键c/d/RET实现创建/删除/切换分支。
tag的操作也很简单:
M-x git-tag可以创建一个标签,以后在git-checkout时可以指定标签的名字,也可以通过git-checkout-to-new-branch来基于tag创建分支。
git-emacs在Emacs中实现了git命令行的所有功能,并且基于Emacs的强大功能使用起来更加方便。
使用git-emacs,不需要在Emacs和Terminal之间来回切换,提高了效率。
Date: 2012-04-26 09:42:33 CST
HTML generated by org-mode 6.33x in emacs 23
转载地址:http://lmgyi.baihongyu.com/