我正在尝试使用Mercurial,我希望借助Bookmark扩展来重现git分支模型。这就是问题所在。
想象一下,我有一个转座。我添加了2个书签
user@host:/tmp/hgtest$ hg bookmark main
user@host:/tmp/hgtest$ hg bookmark feature
user@host:/tmp/hgtest$ hg bookmarks
* feature 0:76c6736b4548
main 0:76c6736b4548
之后我提交了一些代码,并确定该功能已准备就绪(此功能在不久的将来无法开发)。此时书签指向不同的提交。
user@host:/tmp/hgtest$ hg bookmarks
* feature 2:9d32bb6bdbc6
main 0:76c6736b4548
现在我回到我已经开始开发我的功能的状态
user@host:/tmp/hgtest$ hg up main
resolving manifests
removing second.file
getting first.file
1 files updated, 0 files merged, 1 files removed, 0 files unresolved
我想发出merge
命令,以使历史图表看起来像这样
user@host:/tmp/test-git$ git log --graph
* commit d8a957350fc8fbaf542e20aac0d4c95477cc2d3c
|\ Merge: 20493a7 7b59a16
| | Author: Author
| | Date: Mon Jul 11 18:35:09 2011 +1100
| |
| | Merge branch 'testfeature'
| |
| * commit 7b59a16d0b01d9bcc22f21a3c68f63acf60f37da
| | Author: Author
| | Date: Mon Jul 11 18:34:34 2011 +1100
| |
| | Added line to test.file
| |
| * commit 20ea105cf300f7f3e952ac7eddffd2aee6811f7c
|/ Author: Author
| Date: Mon Jul 11 18:32:27 2011 +1100
|
| Added code for testfeature
|
* commit 20493a7a61705967b092780cae9fadd76ec49019
Author: Author
Date: Mon Jul 11 18:25:17 2011 +1100
但是Mercurial不允许这个
user@host:/tmp/hgtest$ hg merge feature
abort: nothing to merge (use 'hg update' or check 'hg heads')
user@host:/tmp/hgtest$
我想重现git方法,因为它允许将大量的开发提交分解为一系列与功能相关的提交,使其更容易理解历史。
如果我可以使用其他技术实现此类行为,请随时与我分享。
答案 0 :(得分:5)
我想你可能会做些什么。
Mercurial没有以git术语进行“快进”合并。这就是它告诉你的:没有什么可以合并,你应该hg update feature
。但是这不会将您的main
书签移动到您想要的位置(并且它也会更改您当前的书签)。
这基本上会在更新后立即迫使你hg bookmark -f main
,这似乎不对。
我会把它带到mercurial-devel邮件列表,看看其他人的想法,并在得到一些新闻后更新这个答案。