Differences between revisions 8 and 10 (spanning 2 versions)
Revision 8 as of 2009-01-08 03:06:51
Size: 2992
Editor: rolandsun
Comment:
Revision 10 as of 2011-03-27 10:30:12
Size: 2973
Editor: 114
Comment:
Deletions are marked like this. Additions are marked like this.
Line 5: Line 5:
在 ChineseTutorialExport 一节, 我们学会了如何与其他人共享变更. 但是因为(0.7 版本开始) ["Import"] 不能正确的处理通过邮件发送的合并, 我们要演示如何从其他做了不兼容变更的仓库用拖合并。 在 ChineseTutorialExport 一节, 我们学会了如何与其他人共享变更. 但是因为(0.7 版本开始) [[Import]] 不能正确的处理通过邮件发送的合并, 我们要演示如何从其他做了不兼容变更的仓库用拖合并。
Line 7: Line 7:
首先, 我们必须创建合并的目标. 我们再次 ["Clone"] {{{my-hello}}}的仓库: 首先, 我们必须创建合并的目标. 我们再次 [[Clone]] {{{my-hello}}}的仓库:
Line 33: Line 33:
我们存档并退出编辑器, 然后 ["Commit"] 我们的变更. 这次, 我们在{{{commit}}}命令中使用{{{-m}}} 选项来节省时间, 以免我们又要进入编辑器: 我们存档并退出编辑器, 然后 [[Commit]] 我们的变更. 这次, 我们在{{{commit}}}命令中使用{{{-m}}} 选项来节省时间, 以免我们又要进入编辑器:
Line 39: Line 39:
这时, 我们已经对 {{{my-hello-new-output}}} [:Repository:仓库]中的 {{{hello.c}}} 作了一个变更 , 同时对 {{{my-hello-desc}}} [:Repository:仓库] 中的 {{{hello.c}}} 作了另一个变更. 我们怎样 ''merge'' 这两个分叉开发主线? 我们从一个仓库拖进另外一个仓库的时候会出现问题吗? 这时, 我们已经对 {{{my-hello-new-output}}} [[Repository|仓库]]中的 {{{hello.c}}} 作了一个变更 , 同时对 {{{my-hello-desc}}} [[Repository|仓库]] 中的 {{{hello.c}}} 作了另一个变更. 我们怎样 ''merge'' 这两个分叉开发主线? 我们从一个仓库拖进另外一个仓库的时候会出现问题吗?
Line 41: Line 41:
这完全没有问题. 现在仍然在 {{{my-hello-desc}}}中, 我们从 {{{my-hello-new-output}}}中 ["Pull"] 并且看看发生了什么: 这完全没有问题. 现在仍然在 {{{my-hello-desc}}}中, 我们从 {{{my-hello-new-output}}}中 [[Pull]] 并且看看发生了什么:
Line 54: Line 54:
这看起来像 TutorialShareChange! 中 {{{pull}}} 的输出,所以我们现在要进行["Update"]了, 对吧? 这看起来像 TutorialShareChange! 中 {{{pull}}} 的输出,所以我们现在要进行[[Update]]了, 对吧?
Line 64: Line 64:
噢,好像发生了什么事情. ["Mercurial"] 告诉我们必须 ["Merge"]每个 [:Repository:仓库] 中的变更. 看起来有点麻烦, 对吗? 其实很简单. 现在我们按照输出最后一行的指令执行: 噢,好像发生了什么事情. [[Mercurial]] 告诉我们必须 [[Merge]]每个 [[Repository|仓库]] 中的变更. 看起来有点麻烦, 对吗? 其实很简单. 现在我们按照输出最后一行的指令执行:
Line 71: Line 71:
这就完成了! 通过调用{{{hgmerge}}}脚本(或者你自己定义的合并程序),["Mercurial"]可以自动的替你完成合并. Depending on your environment, the `hgmerge` may call a graphical merge resolver tool. If we look at {{{hello.c}}}, we find that it contains ''both'' the change from {{{my-hello-new-output}}} and the change from {{{my-hello-desc}}}. 这就完成了! 通过调用{{{hgmerge}}}脚本(或者你自己定义的合并程序),[[Mercurial]]可以自动的替你完成合并. Depending on your environment, the `hgmerge` may call a graphical merge resolver tool. If we look at {{{hello.c}}}, we find that it contains ''both'' the change from {{{my-hello-new-output}}} and the change from {{{my-hello-desc}}}.
Line 73: Line 73:
(~-Note: before Mercurial version 0.9, `hg update -m` should have been used in place of `hg merge`-~). (~-注意:在Mercurial 0.9版之前,因该使用`hg update -m`替代`hg merge`-~).
Line 75: Line 75:
When working with changes made by other people, this is the kind of merge you will end up performing most of the time. 当合并他人所做的修改时,大部分时间都是这种还算容易应付的合并方式。
Line 77: Line 77:
Let us continue on, however, and learn how to deal with situations where conflicting changes have been made in ChineseTutorialConflict. 恩,让我们继续去学习如何处理冲突性变更的情况,这部分将在[[ChineseTutorialConflict|合并有冲突的改变]]中介绍。

教程 - 合并改变

ChineseTutorialExport 一节, 我们学会了如何与其他人共享变更. 但是因为(0.7 版本开始) Import 不能正确的处理通过邮件发送的合并, 我们要演示如何从其他做了不兼容变更的仓库用拖合并。

首先, 我们必须创建合并的目标. 我们再次 Clone my-hello的仓库:

$ cd ..
$ hg clone my-hello my-hello-desc

我们给 hello.c 的注释段加一段描述.

$ cd my-hello-desc
$ vi hello.c

我们将第二行:

 * hello.c

改为:

 * hello.c - hello, world

我们存档并退出编辑器, 然后 Commit 我们的变更. 这次, 我们在commit命令中使用-m 选项来节省时间, 以免我们又要进入编辑器:

$ hg commit -m 'Add description of hello.c'

这时, 我们已经对 my-hello-new-output 仓库中的 hello.c 作了一个变更 , 同时对 my-hello-desc 仓库 中的 hello.c 作了另一个变更. 我们怎样 merge 这两个分叉开发主线? 我们从一个仓库拖进另外一个仓库的时候会出现问题吗?

这完全没有问题. 现在仍然在 my-hello-desc中, 我们从 my-hello-new-outputPull 并且看看发生了什么:

$ hg pull ../my-hello-new-output
pulling from ../my-hello-new-output
searching for changes
adding changesets
adding manifests
adding file changes
added 1 changesets with 1 changes to 1 files (+1 heads)
(run 'hg update' to get a working copy)

这看起来像 TutorialShareChange! 中 pull 的输出,所以我们现在要进行Update了, 对吧?

$ hg update
this update spans a branch affecting the following files:
 hello.c (resolve)
aborting update spanning branches!
(use 'hg merge' to merge across branches or 'hg update -C' to lose changes)

噢,好像发生了什么事情. Mercurial 告诉我们必须 Merge每个 仓库 中的变更. 看起来有点麻烦, 对吗? 其实很简单. 现在我们按照输出最后一行的指令执行:

$ hg merge
merging hello.c

这就完成了! 通过调用hgmerge脚本(或者你自己定义的合并程序),Mercurial可以自动的替你完成合并. Depending on your environment, the hgmerge may call a graphical merge resolver tool. If we look at hello.c, we find that it contains both the change from my-hello-new-output and the change from my-hello-desc.

(注意:在Mercurial 0.9版之前,因该使用hg update -m替代hg merge).

当合并他人所做的修改时,大部分时间都是这种还算容易应付的合并方式。

恩,让我们继续去学习如何处理冲突性变更的情况,这部分将在合并有冲突的改变中介绍。


CategoryChinese

ChineseTutorialMerge (last edited 2012-09-05 06:18:40 by 219)