Mercurial 推送某些修改
我在这里搜索过,但没有发现任何与此相关的问题。我在 Mercurial 中遇到了这样的问题: 我在 bitbucket 中管理开源项目,因此我在本地克隆了源代码。但我也将该项目用于我自己的实时站点,所以我制作了 Bitbucket 存储库的 2 个克隆
Bitbucket Repo
|
==local_clone1
|
==local_clone2-> commit1 => commit2 => commit3
(personalization) (bug fix) (add feature)
问题是,我想将 commit2 和 commit3 推送回 local_clone1,以便稍后我可以推送到 Bitbucket 存储库。但不想推送 commit1,因为它有我的个人数据。
想知道我们如何在 Mercurial 中做到这一点?
I have searched here, but haven't found any question related to this. I got a problem like this in mercurial:
I manage open source project in bitbucket, so i have clone of the source code in my local. But I also using that project for my own live site, so I made 2 clone of bitbucket repo
Bitbucket Repo
|
==local_clone1
|
==local_clone2-> commit1 => commit2 => commit3
(personalization) (bug fix) (add feature)
The question is, I want to push commit2 and commit3 back to local_clone1, so later on I can push to Bitbucket repo. But don't want to push commit1, since it has my personal data.
Wondering how we do that in mercurial?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
在这种情况下,这可以毫无困难地完成。有关详细信息,请参阅 Mercurial 指南中的删除历史记录。
以下是您需要执行的基本操作:
hg Tip
将向您显示)。我们将其称为 731。hg export 730-731 > ../local_clone1/changes.diff
(或任何您喜欢的位置)hg importchanges.diff
您可能需要手动编辑内容;在这种情况下,请参阅该指南以获取更多信息。
This can be done without too much difficulty in this case. See Removing history in the Mercurial guide for more information.
Here's the basics of what you'll need to do:
hg tip
will show you) from the current number. We'll call it 731.hg export 730-731 > ../local_clone1/changes.diff
(or wherever you like)hg import changes.diff
You may need to edit things manually; refer to that guide for more info in that case.
这里有几个选项:
回退
给定一个历史记录,构造如下:
那么如果当前工作目录是提示,以下命令将“撤消”个性化修订:
优点是历史记录保持不可变,但显示历史记录的添加和回退个性化变更集。
Mercurial 队列
通过 mq 扩展,可以编辑历史记录以删除变更集:
优点是个性化变更集消失。缺点是变更集哈希值会因历史编辑而发生变化,因此永远不要对已经推送给其他人的变更集执行此操作。还存在编辑历史记录错误的风险。
Here are a couple of options:
backout
Given a history constructed as:
Then if the current working directory is the tip, the following commands will "undo" the personalization revision:
The advantage is history remains immutable, but shows the addition and backout of the personalization changeset.
Mercurial Queues
With the mq extension, history can be edited to remove a changeset:
The advantage is the personalization changeset disappears. The disadvantage is the changeset hashes change due to the history edit, so this should never be done to changesets that have already been pushed to others. There is also the risk of a mistake editing history.