Mercurial (hg)
附上两个站点:
http://z42.readthedocs.org/zh/latest/devtools/hg.html
http://bucunzai.net/hginit/
Mercurial(hg)是个版本管理工具,类似于git,但是它有自己的特点,比如可以一键生成web。
添加用户名
在.hg目录下有个hgrc文件,将下面代码丢到该文件的最底下即可,代码中的等号之后并无要求,写中文都是可以的。
[ui]
username = John Doe<john@example.com>
初始化一个仓库:hg init
查看当前工作目录跟仓库的区别:hg sum
提交未跟踪的文件:hg add    如果没有带文件名的话就提交全部了
变更
新文件即将需要被commit:hg add <new_file>
将某个已跟踪的文件从下一次commit开始移除:hg remove     文件可能暂时还在,但是commit之后就不在咯。
将当前目录切换到一个历史版本:hg update -r <版本号>    版本号写简写就行了,目录下的任何东西会被处理。
提交到远程仓库:hg commit    这样会提交所有文件,我们可以在commit后加文件名来只提交几个文件,也可以-m <评论>来写log信息,也可以com来代替commit。
列出当前版本库等待推送的变更列表:hg outgoing    列出即将被push的内容。
列出中央库中我所没有的所有变更:hg incoming    列出即将被pull下来的内容。
拉取远程库的最新变更:hg pull    所有最新的都被拉下来。
有两个head需要merge:hg merge    自动合并,如果没有冲突的话。
有两个以上head需要merge:hg merge -r <版本号>    需要指定tip与哪个版本号一块merge。
切换本地目录到tip上去:hg up    直接就切了,其实用的是update指令的简写。
清除掉那些残余的修改:hg update --clean    在误merge时,或者奇怪的问题出现可以试试。
将修改的文件恢复到最近一次提交后的状态:hg revert
撤销最后一次提交, 前提是你还没有push:hg rollback    注意看heads的变化啊。
推送当前的变更:hg push     url是可以省略的,就推到hg paths那里。
查看
查看一个文件的任何历史版本:hg cat     还可以试用-r <版本号>来看这个变更。
查看一个文件在两个版本中的变动:hg diff -r :     v1和v2是版本号。
查看当前是在哪个版本下工作的:hg parent    很可能不是tip。
显示远程版本库列表:hg paths    你推送的东西就是到这里了。
功能
启用一个本地web server供别人拉取仓库:hg serve
拉取仓库默认需要ssl,可以关了它:在hgrc文件中设置[web]push_ssl=False allow_push=*重启即可,重启也是hg serve。
克隆别人的仓库:hg clone <地址>    也就是别人试用hg serve跑起来之后的地址复制过来就可以了。
Mercurial (hg)的更多相关文章
- 分布式版本控制工具:git与Mercurial(zz)
		
分布式版本控制工具:git与Mercurial [收藏此页] [打印] 作者:cyfdecyf 2007-12-26 内容导航: 第1页 [IT168 技术文档] 说到版本控制工具,很 ...
 - 袭击Mercurial SCM(HG)
		
这个叫水银的源代码管理工具尽管默默无闻,但还是得到了非常多团队的使用. 为了迎合某些团队的须要,我们也要用它来管理我们的代码. 今天的任务是先袭击学习.磨刀不误砍柴工. 对工具的掌握越快.工作的效率就 ...
 - scapy学习笔记(1)
		
转载请注明:小五义 http://www.cnblogs.com/xiaowuyi scapy是python写的一个功能强大的交互式数据包处理程序,可用来发送.嗅探.解析和伪造网络数据包,常常被用到网 ...
 - 用MSBuild和Jenkins搭建持续集成环境(2)
		
http://www.infoq.com/cn/articles/MSBuild-2 作者 Mustafa Saeed Haji Ali ,译者 李剑 发布于 2012年10月23日 | 注意: ...
 - Golang 环境配置建议(Atom)
		
http://www.philo.top/2015/02/06/golang-%E7%8E%AF%E5%A2%83%E9%85%8D%E7%BD%AE%E5%BB%BA%E8%AE%AE/ 开发环境的 ...
 - Windows平台软件推荐:神器小工具(骨灰级)
		
底层工具 "If you know how to use Process Monitor competently, people of both sexes will immediately ...
 - (转)python生态环境简介
		
Python生态环境简介 作者: Mir Nazim 原文: Python Ecosystem - An Introduction 译者: dccrazyboy 原译: Python生态环境简介 当 ...
 - 【Git使用】SourceTree+Git简单使用(Windows)(转)
		
导读: 本人过去Git的可视化工具用的是TortoiseGit,虽然Android Studio也能进行版本管理,但是用下来,感觉SoureTree这款工具是最舒服的(免费的),下面就给大家介绍下我的 ...
 - 代码管理(三)sourcetree 的使用
		
一.SourceTree简介 SourceTree 是 Windows 和Mac OS X 下免费的 Git 和 Hg 客户端,拥有可视化界面,容易上手操作.同时它也是Mercurial和Subv ...
 
随机推荐
- django导入 views.py
			
网上找了各种教程..均无解....自己摸索出来了..分享 给大家... 首先INSTALLED_APP 加入 自己的 app pili,然后如下图 from App名称 import views 就 ...
 - eclipse.ini X64 Oxygen.2 Release (4.7.2) lombok
			
X64 Eclipse Java EE IDE for Web Developers. Version: Oxygen.2 Release (4.7.2)Build id: 20171218-0600 ...
 - Linux内核硬件访问技术
			
① 驱动程序控制设备,主要是通过访问设备内的寄存器来达到控制目的.因此我们讨论如何访问硬件,就成了如何访问这些寄存器. ② 在Linux系统中,无论是内核程序还是应用程序,都只能使用虚拟地址,而芯片手 ...
 - LBS开发
			
功能:用户发送自动的位置,返回周围的厕所信息 思路:根据用户的经纬度信息,调用百度地图的api,查询周围的厕所位置并且返回! 步骤:进入百度地图官网注册账号,选择web api接入 我们先看开发者文档 ...
 - py---------面向对象基础篇
			
引子 你现在是一家游戏公司的开发人员,现在你需要开发一款叫做<人猫大战>的小游戏,你就思考呀,人猫大战,那至少需要两个角色,一个是人,一个是猫,且人和猫有不同的技能,比如人拿棍打狗,狗可以 ...
 - sass注释中有中文出现报错解决方法
			
在使用koala编译sass成css过程中出现这样的报错 后来查资料说是自己在sass中的注释中有中文引起的, 解决方案: 进入C:\Ruby25-x64\lib\ruby\gems\2.5.0\ge ...
 - Java日志组件1---Jdk自带Logger(java.util.logging.Logger)
			
最近在看日志的一些东西,发现利用JDK自带的log也可以简单的实现日志的输出,将日志写入文件的过程记录如下: 1.新建LogUtil.Java( 里面写了几个静态方法,为log设置等级.添加log控制 ...
 - Mybatis学习笔记13 - 动态sql之set标签
			
示例代码: 接口定义: package com.mybatis.dao; import com.mybatis.bean.Employee; public interface EmployeeMapp ...
 - Kudu 常见的几个应用场景
			
不多说,直接上干货! Kudu 常见的几个应用场景 实时更新的应用.刚刚到达的数据就马上要被终端用户使用访问到. 时间序列相关的应用,需要同时支持: 根据海量历史数据查询. 必须非常快地返回关于单个实 ...
 - Hash表的原理
			
哈希的概念:Hash,一般翻译做“散列”,也有直接音译为“哈希”的,就是把任意长度的输入(又叫做预映射, pre-image),通过散列算法,变换成固定长度的输出,该输出就是散列值.这种转换是一种压缩 ...