其实这两年,能够采用mercurial的项目我都尽量用,甚至有些上游是git的,或者需要托管到公司内gitlab上与别人协作的,我都装上hg-git。无它,只是因为mercurial易用性比git好得多——比如我一直记不清git reset[那么多神奇的功能](http://git-scm.com/2011/07/11/reset.html)

下面是几个小技巧,可以让易用性进一步改善

输出自动自动分页

hg log缺省会一口气输出所有commit记录,这很可能不是你想要的,所以你不得不自己加pager: hg log | less

另一个办法是启用pager这个扩展,实现跟git log一样的行为:自动调用less显示输出(这样也可以用上less的搜索功能了)

~/.hgrc添加如下配置

[extensions]
pager = [pager]
pager = less

然后hg log就会自动调用less来分页了

补充说明:

  1. hg diff, hg annotate等命令也会。详细列表可用hg help pager查看[pager]attend设置的默认值,这个配置项决定了哪些命令的输出会用pager。也可以通过在~/.hgrc中设置这个值,比如hg help命令默认就没有启用pager,所以可以修改为:
  [pager]
attend = annotate, cat, diff, export, glog, log, qdiff, help
  1. 如果设置了环境变量PAGER,则会优先采用环境变量指定的pager,忽略.hgrc的值
  2. 如果使用less为pager的话,推荐设置为:
[pager]
pager = 'LESS=FRX' less

或者设置环境变量LESS='FRX'。less的选项-R是为了支持ansi color的(参看下面的color扩展说明),其它参数的具体含义可查看explainshell网站的解释或者参看less的manpage

详细说明: http://mercurial.selenic.com/wiki/PagerExtension

加点色彩

Color这个扩展 可以给hg statushg diff的输出加上颜色,使得输出看起来更清楚。

启用方法:编辑~/.hgrc

[extensions]
color =

效果图:

详细说明:http://mercurial.selenic.com/wiki/ColorExtension

查看分支/合并关系

如果你的hg库里面有分支(有名或者匿名的),很难从hg log的输出里看出关系来(从哪里分支的,在哪里合并的)。

方法一: 用hg serve在web浏览器上查看分支关系

hg比git好的一点是,如果你工作在一个没有装X window的服务器,没法运行一些GUI的hg前端时,你可以简单地用hg serve起一个web 服务,然后在浏览器查看。那里面可以看到分支关系(点击左边的Graph进入)

方法二: 用GraphLog扩展

另一个办法更简单:启用graphlog extension,然后用hg glog命令查看。

启用方法是编辑 ~/.hgrc:

[extensions]
graphlog =

hg glog的效果如下:

参考: Stay Sane with Graphlog / hg tip

为pull/push设置不同的远端地址

我常用的一个操作是:在家里推送到bitbucket网站,到公司后从bitbucket网站将内容拉下来,推到公司内的一个Kallithea 实例上。

[paths]
default = http://bitbucket.org/bamanzi/misc-utils
rhodecode = http://rhodecode.example.com/yang.guilong/misc-utils

然后我用如下命令完成代码的同步

hg pull -u
hg push rhodecode

其实hg支持对pull/push设置不同的地址 :

[paths]
default = http://bitbucket.org/bamanzi/misc-utils
default-push = http://rhodecode.example.com/yang.guilong/misc-utils

于是我可以简单地执行下面的命令完成两个库的同步

hg pull -u
hg push

当然,采用这个技巧,只是少敲了几个字符而已,不过至少可以少记忆一个别名。

用外部比较工具查看差异

很多时候我们想用其它工具来比较整个文件的前后差异(有的时候是因为不熟悉hg diff的输出格式(阮一峰有篇博客文章读懂diff讲解得比较清楚),有的时候是前后差异的确有点复杂以至于diff的输出不能正确反映代码在逻辑上的差异)。

方法一

这种情况下DiffUse很值得推荐,它有个不错的功能是能感知文件夹内的版本控制系统(比如mercurial, git, subversion...),并支持比较两个revision的差异:

# compare revision 123 of foo.C and revision 321 of foo.C
diffuse -r 123 -r 321 foo.C # display a 3-way merge between revision MERGE_HEAD of foo.C,
# the local foo.C file, and revision HEAD of foo.C
diffuse -r MERGE_HEAD foo.C foo.C -r HEAD foo.C

​### 方法二:启动ExtDiff扩展

[extensions]
hgext.extdiff = [extdiff]
cmd.vimdiff = vimdiff # add new command called vimdiff, runs gvimdiff with DirDiff plugin
#(see http://www.vim.org/scripts/script.php?script_id=102)
# Non english user, be sure to put "let g:DirDiffDynamicDiffText = 1" in
# your .vimrc
cmd.vimdiff2 = gvim
opts.vimdiff2 = -f '+next' '+execute "DirDiff" fnameescape(argv(0)) fnameescape(argv(1))' # add new command called vdiff, runs kdiff3
cmd.vdiff = kdiff3 # add new command called ediff, runs emacs ediff
cmd.ediff = sh
opts.ediff = -c 'if [ -d $0 ]; then emacs --eval "(ediff-directories \"$0\" \"$1\" \"\")"; else emacs --eval "(ediff-files \"$0\" \"$1\")"; fi'

然后就可以用如下命令来对比文件了

hg vimdiff rope/base/fscommands.py

hg vimdiff2 -r 31 -r 32 rope/base/fscommands.py

hg ediff rope/base/fscommands.py

详细说明: ExtDiffExtension

mercurial的几个易用性小技巧的更多相关文章

  1. 前端网络、JavaScript优化以及开发小技巧

    一.网络优化 YSlow有23条规则,中文可以参考这里.这几十条规则最主要是在做消除或减少不必要的网络延迟,将需要传输的数据压缩至最少. 1)合并压缩CSS.JavaScript.图片,静态资源CDN ...

  2. Git小技巧 - 指令别名及使用Beyond Compare作为差异比较工具

    前言 本文主要写给使用命令行来操作Git的用户,用于提高Git使用的效率.至于使用命令还是GUI(Tortoise Git或VS的Git插件)就不在此讨论了,大家根据自己的的喜好选择就好.我个人是比较 ...

  3. 分享两个BPM配置小技巧

    1.小技巧 流程图修改后发布的话版本号会+1,修改次数多了之后可能会导致版本号很高,这个时候可以将流程导出,然后删除对应的流程包再导入,发布数据模型和流程图之后,版本清零 2.小技巧 有的同事入职后使 ...

  4. linux系统维护时的一些小技巧,包括系统挂载新磁盘的方法!可收藏!

    这里发布一些平时所用到的小技巧,不多,不过会持续更新.... 1.需要将history创建硬链接ln 全盘需要备份硬链接 ln /etc/xxx /home/xxx 2.root用户不可以远程 /et ...

  5. JS处理事件小技巧

    今天,就分享一下我自己总结的一些JS的小技巧: ①防止鼠标选中事件 <div class="mask" onselectstart="return false&qu ...

  6. iOS:小技巧(不断更新)

    记录下一些不常用技巧,以防忘记,复制用. 1.获取当前的View在Window的frame: UIWindow * window=[[[UIApplication sharedApplication] ...

  7. css小技巧(1)

    1.-webkit-overflow-scrolling: touch; 解决ios滑动时无缓冲问题 2.::-webkit-scrollbar 设置ios滑动时是否显示滚动条 3.::selecti ...

  8. 最强 Android Studio 使用小技巧和快捷键

    写在前面 本文翻译自 Android Studio Tips by Philippe Breault,一共收集了62个 Android Studio 使用小技巧和快捷键. 根据这些小技巧的使用场景,本 ...

  9. ios开发中的小技巧

    在这里总结一些iOS开发中的小技巧,能大大方便我们的开发,持续更新. UITableView的Group样式下顶部空白处理 //分组列表头部空白处理 UIView *view = [[UIViewal ...

随机推荐

  1. HDU1789 Doing Homework again 做作业【贪心】

    题目链接:https://vjudge.net/problem/HDU-1789 题目大意: 给出N个作业的截至日期,和N个作业不交所扣掉的分数,要求输出扣除分数做少的方案. 解析: 与上一道销售商品 ...

  2. 使用MSF发现主机和端口扫描

    使用MSF发现主机和端口扫描 使用search命令查找需要的模块 MSF模块太多,记不住怎么办!!! 我们不需要记住所有模块,我们只要能找到我们想用的模块就行,平时积累使用的模块也行哦! 比如,我们通 ...

  3. 中间人攻击工具ettercap

    中间人攻击工具ettercap (一).简介 (二).模块划分 1.Snifer 2.MITM 3.Filter 4.Log 5.Plugin (三).特性 (四).用户操作界面 (五).指定目标 ( ...

  4. 002.HAProxy安装及常见配置

    一 HAProxy安装 官方链接:http://www.haproxy.org/ (国内可能无法打开) 下载连接:http://pkgs.fedoraproject.org/repo/pkgs/hap ...

  5. muduo网络库架构总结

    目录 muduo网络库简介 muduo网络库模块组成 Recator反应器 EventLoop的两个组件 TimerQueue定时器 Eventfd Connector和Acceptor连接器和监听器 ...

  6. BZOJ.3667.Rabin-Miller算法(MillerRabin PollardRho)

    题目链接 Pollard_Rho:http://blog.csdn.net/thy_asdf/article/details/51347390 #include<cstdio> #incl ...

  7. android:ProgressDialog控件

    ProgressDialog 和 AlertDialog 有点类似,都可以在界面上弹出一个对话框,都能够屏蔽 掉其他控件的交互能力.不同的是,ProgressDialog 会在对话框中显示一个进度条, ...

  8. gson的简单使用方法

    gson和其他现有java json类库最大的不同时gson需要序列化得实体类不需要使用annotation来标识需要序列化得字段,同时gson又可以通过使用annotation来灵活配置需要序列化的 ...

  9. windows server 2008 R2安装图片浏览器/照片查看器方法

    有用户的电脑安装了windows server 2008 R2,浏览大量图片时很不方便,因为系统中没有照片查看器或图片浏览器.其实,win2008 R2是有照片查看器的,只是默认情况下没有开启.参考以 ...

  10. he canvas has been tainted by cross-origin data and tainted canvases may not be exported

    来自: https://ourcodeworld.com/articles/read/182/the-canvas-has-been-tainted-by-cross-origin-data-and- ...