Emacs学习笔记(14):在Emacs中使用git

在Emacs中使用git

Table of Contents

1 工具的选择

在Emacs中使用git有很多中选择,比如古老的Emacs VC ,经典的git.el, 强大的git-emacs, 以及新潮的magit / egg(egg是magit的一个分支)。

Emacs VC在Emacs中内置支持,配合后端,对各种版本控制工具如CVS、SVN、GIT、Hg等都能够支持,但是功能比较单一,操作方式简单而且古怪。

git.el 是git项目的官方工具,但是已经很久没有更新了,据说对git的有些特性并没有提供支持。

而magit和egg个人感觉还有待时间的检验。

所以这里选择的是git-emacs。

2 安装和配置

git clone https://github.com/tsgates/git-emacs.git 之后,只需要在Emacs配置文件中增加:

;;git-emacs
(add-to-list 'load-path "/path/to/git-emacs/")
(require 'git-emacs)

然后可以通过 M-x git-config-init 进行配置。

3 基本操作

如果当前打开的文件所在的文件夹处于版本控制中,可以通过M-x git-status查看状态,如下图:

《Emacs学习笔记(14):在Emacs中使用git》

在这个界面下可以使用一些命令:

 

keyCommandComment
p/n 在所有文件之间上下移动
P/N 在变更过的文件之间上下移动
</> 定位到列表的头部/尾部
v 以只读方式打开文件
m/u/SPC 设置/取消/切换标记,标记用于批量处理文件
a 将文件加入版本控制
i 将文件加入ignore
c 提交

其他命令可以参考此时出现的Git-Emacs菜单。

4 提交

在状态清单中使用“c”,或者在任何buffer中运行M-x git-commit/git-commit-all/git-commit-file,可以提交index/所有文件/当前文件。

提交时会要求填写注释,如下图:

《Emacs学习笔记(14):在Emacs中使用git》

填写注释后:

 

C-c C-c提交
C-c C-q取消

5 版本历史

通过命令 M-x git-history可以查看整个工程的版本历史,M-x git-log可以查看当前标记文件的版本历史,两个命令都会打开一个新的buffer:

《Emacs学习笔记(14):在Emacs中使用git》

如果你很喜欢gitk,也可以通过M-x gitk(前提是已经安装了gitk)直接打开gitk窗口:

《Emacs学习笔记(14):在Emacs中使用git》

6 标签(tag)和分支(branch)

M-x git-branch:列出所有分支,在这里可以通过快捷键c/d/RET实现创建/删除/切换分支。

tag的操作也很简单:

M-x git-tag可以创建一个标签,以后在git-checkout时可以指定标签的名字,也可以通过git-checkout-to-new-branch来基于tag创建分支。

7 小结

git-emacs在Emacs中实现了git命令行的所有功能,并且基于Emacs的强大功能使用起来更加方便。

使用git-emacs,不需要在Emacs和Terminal之间来回切换,提高了效率。

Author: Holbrook Wong <wanghaikuo@gmail.com>

Date: 2012-04-26 09:42:33 CST

HTML generated by org-mode 6.33x in emacs 23

    原文作者:心内求法
    原文地址: https://www.cnblogs.com/holbrook/archive/2012/04/26/2470923.html
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞