- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
使用 Mercurial (hg),您是否可以“hg backout”您为不想推送的文件所做的所有提交,然后再进行推送?
因为 Mercurial(或 Git)不允许我们将单个文件或单个文件夹推送到另一个存储库,所以我在想:
1) 怎么样,我们只查看我们所做的提交,hg backout
我们不想推送的提交。
2) hg out -v
查看要推送的文件列表
3) 现在通过 hg push
进行推送
这个方法好吗?
这是因为我得到了以下建议:
1) 如果您不想推送该文件,请不要提交它(但有时甚至只是为了实验,我确实想保留中间修订版)(-- 也许我可以 hg commit
和 hg backout
以防止它被推送。)
2) 有些人告诉我只是从我要推送到的存储库中hg clone tmp
,然后将本地文件复制到这个 tmp 工作目录,hg commit
到这个 tmp
存储库,然后进行推送。但是我发现hg clone tmp
会占用400MB的新数据和文件,让硬盘工作很辛苦,就为了push 1个文件?所以我宁愿不用这种方法。
最佳答案
如果你执行hg backout
,那么文件仍然会被推送,但在tip revision中会被忽略。远程存储库将接收变更集以添加文件,然后接收回退变更集以删除它们。因此它会包含您不想推送的文件的历史记录。
一旦您提交了一个文件,任何涉及该文件的变更集移动到另一个存储库都将包括对该文件的更改。如果您想做的只是防止 check out 远程存储库的尖端以包含该文件,那么您所描述的将起作用。如果不是,那么除了从不推送任何涉及相关文件的变更集之外,没有任何保留历史的方法来完成你想要的。您可以通过使用 convert
创建一个新的存储库来删除它,而不会留下任何不需要的文件的痕迹,但会生成一个具有新历史记录的新存储库。
关于git - 使用 Mercurial (hg),您是否可以只将您为不想推送的文件所做的所有提交都设为 "hg backout",然后进行推送?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3041765/
这个问题在这里已经有了答案: 关闭 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/控制台语言已从英语更改为丹麦语。我的机器设置为美国英语,键盘布局为丹麦语。我不希望丹麦语翻译生效,因为它不
我是一名优秀的程序员,十分优秀!