- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
$ hg update [-r REV]
这会将工作目录切换到指定的修订版本。但是,如果我的工作目录已修改更改,则这些更改将与 REV
merge 回来。 。我意识到我可以使用-C
标记放弃我的更改,但我试图表达我对 update
行为的担忧不同场景下的命令。
$ hg update <bname>
这会将我的工作目录切换到 <bname>
分支。但是,在我明确使用 merge
之前,我未提交的更改不会 merge 命令。
$ hg pull
$ hg update
这再次将我的工作目录与最近的 pull
之后来自远程存储库的更改集 merge 。 。
最佳答案
Mercurial 1.9.1
它与变更集之间的关系有关。如果工作目录的父变更集和要更新到的目标变更集之间存在直接路径,Mercurial 将尝试通过 merge 操作传输工作目录中的更改。因此,如果您所在的变更集是您要更新到的变更集的直接后代或直接祖先,那么它通常会起作用。
在下图中,字母代表分支名称,数字代表连续的修订号。 wd
是工作目录。
在同一分支上更新:
--A1----A3----A5---wd
\ /
A2------A4
以上是在A5的基础上进行的更改。如果您更新到 A4,Mercurial 将 merge 未提交的更改以传输它们。
--A1----A3----A5---A6---wd
\ /
A2------A4
此外,如果有其他变更集(例如 A6),这仍然有效,因为 A4
更新到不同的分支(这次更新到B4):
--A1----A3----A5---wd
\ /
B2------B4
上面,修订版 2 和 4 位于不同的分支 B 上,该分支最近已 merge 回分支 A 。 Mercurial 还会传输未提交的更改,因为 A5 和 B4 密切相关。还有:
--A1----A3----A5---A6---wd
\ /
B2------B4
同样,当您从远程存储库中提取新更改时,通常它们将是工作目录父级更改集的后代,因此提供了直接关系,可以 merge 未提交的更改:
--A1----A3----A5---A6---wd
\ / \
A2------A4 A7---A8---A9 (A7 through A9 pulled)
在同一分支上更新:
--A1----A3----A5
\ /
A2------A4---A6---wd
以上是在A6的基础上进行的更改。如果您更新到A5,Mercurial 将拒绝,并表示“未完成的未提交更改”或“跨分支”。这是因为您试图将未提交的更改从一个头 merge 到另一个头,并且它们(根据定义)不是彼此的祖先或后代。当然,命名分支也会发生同样的情况:
--A1----A3----A5
\ /
B2------B4---B6---wd
当 Mercurial 不会自动尝试 merge 未提交的更改时,您可以通过几种不同的方式将更改移至新的父级:
关于mercurial - 为什么 hg update 命令在某些情况下会 merge ,但不是全部?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7048141/
这个问题在这里已经有了答案: 关闭 10 年前。 Possible Duplicate: How can I see incoming commits in git? “hg 传出”或“hg 传入”
mercurial 命令之间有什么区别, hg 条 hg 取消 hg 恢复 所有这些命令基本上都用于恢复/撤消早期变更集的影响。 最佳答案 hg strip 从存储库中删除变更集及其所有后代。就好像这
您可以使用什么 mercurial 命令在变更集 xyz 之前查看变更集? 如果你这样做 hg log -r :xyz您会看到(包括)xyz 之前的所有变更集 - 按升序列出。但我想轻松地看到之前的变
当我在克隆我的 Git 存储库时,远程内容发生了变化: $ hg push ... abort: refs/heads/master changed on the server, please pul
有人能告诉我为什么最后没有找到任何变化吗? 此外,我收到一条烦人的消息,“.hg/hgrc 中未指定用户名。将不会使用 key 环。” 版本工具:Hg最新版服务器:Linux工作区:~/2012WS
我在我的 Windows 机器上安装了 Tortoise Hg,并且一直通过 Tortoise GUI 和 Windows 命令行使用 mercurial。我按照 http://hg-git.gith
我的项目.hg目录为 40MB。如果我 hg push --verbose --debug到一个空的远程存储库,我看到它发送了数百 MB。额外的开销从何而来? 更新 :hg bundle -a生成一个
对于那些使用带有 MQ 扩展的 Mercurial 的人: 这是我第二次不小心将更改提交到中央存储库( hg push ),而不是将补丁应用到我的工作目录( hg qpush )。 我认为这是非常不幸
在 Mercurial 中,有什么区别 hg revert --all 和 hg up -C? 这两个命令似乎都会恢复所有更改。但有什么区别呢? 最佳答案 通过 hg up,您实际上切换到另一个版本(
如果我从本地 Mercurial 存储库开始,我认为它是“主要”存储库(请原谅我,我的 dvcs 领主),并打算使用 bitbucket 作为备份和问题跟踪工具,我可以进行所有更改在我的本地存储库中并
我的团队使用 mercurial 已经有一段时间了。我们使用 ssh 连接到中央远程存储库。将 ssh 推或拉到远程存储库时没有任何问题......直到今天! 其他人都在局域网上,我远程工作并使用 v
hg revert 和 hg backout 都会还原先前版本所做的更改。两者有什么区别? 最佳答案 考虑到变更集的历史: A --- B --- C --- D --- E [b
我创建了一个新的存储库 test-backout,并在其中添加了一个新文件 file。然后,我每次进行 4 次提交,并使用 将提交编号附加到 file 中 echo [manually entered
在工作中,我使用的是 svn存储库在 7 人之间共享。 为了避免在提交中困扰我的错误并破坏每个人的构建并避免在 svn 中分支,我创建了一个hg svn 的一部分中的存储库我目前正在处理的目录。 我在
我一直在一个分支上做一些开发,并意识到在它完成之前需要先完成其他事情。我决定我将分支我当前的分支并在该分支中进行必要的更改,然后将它们 merge 在一起,然后将我的工作分支 merge 为默认分支。
我有一个使用 mercurial 作为存储库的网络服务器。每天,我们都有应用程序将文件写入我们的服务器,我希望这些文件反射(reflect)在存储库中。有没有一种方法可以添加每天运行的自动“hg ad
在某些情况下,我需要强制 Mercurial 用户运行 hg pull -u在任何之前 hg commit可以允许,即 hg pull将意味着传入队列是空的——此外,我还希望该人使用分支的头部版本。
我正在 Mercurial 中开发一个项目,突然间,当我运行“hg status”时,我在“.hg”目录中看到一堆文件,报告为“未跟踪”。它看起来像这样: ? .hg/00changelog.i ?
这里的问题是 hg 的工作流程显然是在绕圈子: hg pull,再拿一个头 hg merge ,得到未完成的警告未提交的更改 hg commit -m "pre merge commit", 获取消息
我昨天在我的 Mac(雪豹)上重新安装了 Mercurial。 Mercurial 的 UI/控制台语言已从英语更改为丹麦语。我的机器设置为美国英语,键盘布局为丹麦语。我不希望丹麦语翻译生效,因为它不
我是一名优秀的程序员,十分优秀!