hg 的使用简介

时间:2021-10-29 10:38:17

克隆仓库

仓库是一个目录,它包含所有我们希望保留历史的源代码和这些源代码的历史记录。

克隆就是生产一个仓库的副本,这样可以有一个本地私有的仓库来工作.

hg clone http://远程仓库地址:端口 

需要说明的是:在 Mercurial 中, 每一个仓库是自包含的。当你克隆一个仓库后,新仓库变成克隆时它的精确复本, 但是后续的两个仓库当中任一方改变都不会在对方显示,除非你用 Pull 或 Push 明确地传递改变。

本地克隆

hg clone curRepoPath toRepoPath 

查看仓库的历史

hg log 

$ cd my-hello

$ hg log

changeset: 1:97455d972b91

tag: tip

user: mpm@xxx.com

date: 2014-06-19

summary: Create a file

changeset: 0:97455d972b91

tag: tip

user: mpm@xxx.com

date: 2014-06-19

summary: Create a file

changeset 标识了一个 改变集.

冒号前面的数字代表版本号; 它是一种标识改变集的本地缩写.只是在你的本地仓库中这个版本号才有意义.

冒号后面的那个很长的十六进制串是 ChangeSetID; 它是标识改变集的全局唯一标识符, 在所有包含这个改变集的仓库中都相同. 如果你正在和其他人讨论某个改变集,请使用这个 ChangeSetID,而不是上面说的版本号.

查看指定版本号的改动,并且显示改动在哪

hg log -r版本号 -p 

处理改动

与仓库同步后,如果本地有任何改动,则hg自动给我们生成了一个变更集(changeset,简写为 cset),

它自动收集记录了本地仓库(俗称版本库)中的文件的任何改动,用 changeset ID 唯一标识(identify)一个变更集.

查看变更:

hg status 或简写 hg st 

查看改动:

hg diff 

放弃变更并重新开始:

hg revert hello.c 或者用--all选项来恢复所有文件 

revert重命名被编辑文件hello.c为hello.c.orig并恢复hello.c到它的未编辑状态。 status命令现在会将hello.c.orig视为不被追踪的(以"?"为前缀)。

如果我又改变主意想要重用我做的修改,我只需要移除未编辑状态的hello.c然后重命名我改过的hello.c.orig为hello.c

rm hello.c

mv hello.c.orig hello.c

hg st

M hello.c

执行提交

hg commit 

第一次,通常会出现

abort: no username supplied

这使因为没有配置本地仓库使用者的用户名,可以去.hg目录下简历hgrc文件,

[ui]

username = yourname

或者是这样

hg config --edit 

设定username后,再次commit,会出现一个编辑框,提示要输入一些变更信息

如果不习惯那样,那么可以这样

hg commit -m 'Add description of xxxxxx' 

与别的仓库分享改变

查看其他仓库的状况

可以使用 tip 命令来找出每一个仓库的Tip(Tip 是最后一个变更集).

localhost:my-hello cyk$ hg tip<br>

changeset: 2:b5b427d8a2ef

tag: tip

user: CodingLion

date: Thu Jun 19 22:50:11 2014 +0800

summary: have anything to say?

localhost:my-hello cyk$ hg tip

changeset: 3:863a46da4e7a

tag: tip

user: CodingLion

date: Thu Jun 19 22:52:11 2014 +0800

summary: wo qu !

可以看到,tip在不同的仓库中是不同的.

别人有,我也要有,pull之,

这个命令所有在别的仓库中有而在本仓库中没有的 变更集 从别的仓库拉到本仓库。

我有,别人没有,push之.

合并改变

已经对 A 仓库中的 hello.c 作了一个变更 , 同时对 B 仓库 中的 hello.c 作了另一个变更. 怎样合并这两个分叉开发主线?

hg pull B 
hg merge 

但是, 经常是不能自动合并的,因为同样源文件的相同的代码在每个ChangeSet中被不同的方式更改(一个是我们提交的更改方式,一个是我们[Pull]来的)。

hg merge时,会发生什么决定于电脑中安装了什么样的程序。如果装了图形的合并程序,我们就能够看到在两个更改之间发生了什么冲突,并决定如何去做。

三路合并,分别是:

  1. 本地文件(当前仓库)
  2. 其它文件(正在被合并的仓库)
  3. 基文件 (在分支分开前的最后一个版本

hg 的使用简介的更多相关文章

  1. 开源地图SharpMap源码解析-(1)简介

    1.简介 SharpMap最新版基于.NET Framework 4,采用C#开发的地图渲染引擎,非常易于使用.我这次研究的是比较稳定发布的V1.1版本.可以在GitHub下载该源码,地址:https ...

  2. Python生态环境简介&lbrack;转&rsqb;

    Python生态环境简介 作者: Mir Nazim 原文: Python Ecosystem - An Introduction 译者: dccrazyboy  原译: Python生态环境简介 当 ...

  3. Android—SDCard数据存取&amp&semi;Environment简介

    1:Environment简介: Environment是android.os包下的一个类,谷歌官方文旦的解释为:Provides access to environment variables(提供 ...

  4. mysql读写分离——中间件ProxySQL的简介与配置

    mysql实现读写分离的方式 mysql 实现读写分离的方式有以下几种: 程序修改mysql操作,直接和数据库通信,简单快捷的读写分离和随机的方式实现的负载均衡,权限独立分配,需要开发人员协助. am ...

  5. (转)python生态环境简介

    Python生态环境简介 作者: Mir Nazim 原文: Python Ecosystem - An Introduction 译者: dccrazyboy  原译: Python生态环境简介 当 ...

  6. RDLC系列之一 简介和入门

    一.简介 RDLC报表,通过Report Viewer Control来实现,制作微软RDLC报表由以下三部分构成:1.制作自己的DateSet集合(就是报表的数据集):2.制作自己的报表文件.rdl ...

  7. Mercurial&lpar;Hg&rpar;基本操作

    Mercurial(Hg)基本操作 来源 https://www.cnblogs.com/gb2013/archive/2012/05/18/Mercurial_Basic.html Mercuria ...

  8. 版本管理工具git与svn简介

    版本管理工具 版本管理工具简介 常见版本管理工具 cvs(Concurrent Versions System) vss(Visual SourceSafe) svn 常用的版本管理工具 git 流行 ...

  9. Python学习(二)Python 简介

    Python 简介 官方指南及文档 Python2.7官方指南(中文版):http://pan.baidu.com/s/1dDm18xr Python3.4官方指南(中文版):http://pan.b ...

随机推荐

  1. nginx笔记资料

    通配 hash 表 ngx_hash_init 实现注释:http://blog.csdn.net/gsnumen/article/details/7817396 ngx_hash_init之后的结构 ...

  2. &lbrack;TCPIP&rsqb; 分层 Note

    TCP/IP  分层 TCP/IP是一组不同层次上的多个协议的组合. 通常被分为:链路层.网络层.运输层.应用层 1. 链路层(数据链路层 或 网络接口层) 通常包括操作系统中的设备驱动程序和计算机中 ...

  3. UWP应用开发系列视频教程简介 - Built for Windows 10

    万分感谢Fdyo同学给我们带来的有中文字幕的系列教程! http://zhuanlan.zhihu.com/MSFaith/20364660 下面是这系列video教程中的一个截图作为示例,有代码,有 ...

  4. Spring 事务机制详解

    原文出处: 陶邦仁 Spring事务机制主要包括声明式事务和编程式事务,此处侧重讲解声明式事务,编程式事务在实际开发中得不到广泛使用,仅供学习参考. Spring声明式事务让我们从复杂的事务处理中得到 ...

  5. UVa120 - Stacks of Flapjacks

    Time limit: 3.000 seconds限时:3.000秒 Background背景 Stacks and Queues are often considered the bread and ...

  6. ImageSource使用心得&lpar;转&rpar;

    很多时候,我们会使用图片来装饰UI,比如作为控件背景等. 而这些图片可以分为两种形式,即存在于本地文件系统中的图片和存在于内存中的图片 对于这两种形式的图片,在WPF中,使用方法不同,下面主要说明针对 ...

  7. Netty、t-io、Voovan 框架比较

    以下是对三个框架在设计或者说是编码特点中选取的几个我比较关注的点的对比图: 首先我们对几个关键的概念进行一些解析,方便大家更好的理解上面表中的概念: NIO.AIO 的区别? 在这里我们来看一下两者最 ...

  8. ECharts(中国地图篇)的使用

    代码html <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <me ...

  9. 【C语言】字节对齐问题(以32位系统为例)

    1. 什么是对齐? 现代计算机中内存空间都是按照字节(byte)划分的,从理论上讲似乎对任何类型的变量的访问可以从任何地址开始,但实际情况是在访问特定变量的时候经常在特定的内存地址访问,这就需要各类型 ...

  10. react-native android 集成 react-native-baidu-map

    记录下 遇到的问题,方便以后查看,参考 文章 https://www.jianshu.com/p/7ca4d7acb6d2 1. npm install react-native-baidu-map ...