gpt4 book ai didi

mercurial - 克隆后存储库中的文件,但没有历史记录

转载 作者:行者123 更新时间:2023-12-02 23:37:38 24 4
gpt4 key购买 nike

我们不久前有一个从 Subversion 转换而来的 Mercurial 存储库,今天注意到存储库中的某些文件没有任何历史记录。

此行为的症状之一是 hg status 将文件报告为干净,而 hg log 报告同一文件没有更改集:

> hg clone [repo]
> hg st -c FileWithMissingHistory.cs

C FileWithMissingHistory.cs

> hg blame FileWithMissingHistory.cs
FileWithMissingHistory.cs: no such file in rev [...]
> hg log FileWithMissingHistory.cs
> hg log FileWithMissingHistory.cs -f
abort: cannot follow nonexistent file: "FileWithMissingHistory.cs"

> hg log -v | grep FileWithMissingHistory.cs

[gives output, there arechangesets mentioning the file]

显然示例中的文件名已更改。我尝试过使用 hg verify,但此命令报告存储库正常。有没有人经历过这种情况?我们可以做些什么来让历史“复活”?将虚拟历史记录放在有问题的文件上是可以接受的,但不是最理想的。

编辑:我做了更多调查,注意到“FileWithMissingHistory.cs”在修订版 238 中从另一个文件名(hg 复制 + 删除)重命名。如果我在该修订版中执行 hg update -r238 和 hg 登录文件,我不会得到任何历史。对原始文件执行 hg log 按预期报告历史记录,因此似乎历史记录在复制过程中以某种方式丢失(同样,使用 hg copy 重命名该文件,并且更改集清楚地表明该文件已被复制)。

最佳答案

听起来很奇怪,实际上不可能。我要尝试调试此问题的方法是更新到不同的修订版,并检查文件第一次出现在工作副本中的修订版。如果您以二分搜索方式执行此操作(类似于 bisect extension 的工作方式),您应该找到在几次更新后引入该文件的修订版。

这并不能解决问题,但可能有助于追踪其根源。

关于mercurial - 克隆后存储库中的文件,但没有历史记录,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4956804/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com