3

文档说所有标签都存储在 中.hgtags,但显然这里有一些黑魔法。

我的标签如下所示:

mbayazit:~/test$ cat .hgtags 
0d80b6ba4ba3b51a44f0f1d339fcac1d4b21f387 stable
c70d8e7e516d8b9e0c520063a575b4acea1b2f94 testtag
0d80b6ba4ba3b51a44f0f1d339fcac1d4b21f387 stable
b1a360af6daf536ddc55b6b50127e88c30a227dc stable

如果我更新到testtag,

mbayazit:~/test$ hg up testtag
1 files updated, 0 files merged, 2 files removed, 0 files unresolved

标签消失,

mbayazit:~/test$ cat .hgtags 
cat: .hgtags: No such file or directory

因为testtag比别人老;为什么不正常我不知道。

但是当我再次尝试更新stable时,

mbayazit:~/test$ hg up stable
3 files updated, 0 files merged, 0 files removed, 0 files unresolved

它神奇地起作用。如果那个标签甚至不在,那怎么可能.hgtags呢?

4

2 回答 2

5

在官方标签文档的第二部分中写下了这样的声明:

将工作目录更新到特定标记将使该目录回到标记本身存在之前的位置。

.hgtags当您标记特定修订时,第一次创建文件。当您将存储库状态更新为此标记的修订版时,存储库的状态实际上就在.hgtags添加到版本控制之前。

这是我们添加第一个标签然后将存储库状态更新到此标签修订版的示例:

PS D:\tagstest> hg init
PS D:\tagstest [default tip]> echo 'Something' > readme.txt
PS D:\tagstest [default ?1 tip]> hg addremove
adding readme.txt
PS D:\tagstest [default +1 tip]> hg ci -m "First commit"
PS D:\tagstest [default tip]> hg tag first
PS D:\tagstest [default tip]> cat .\.hgtags
9494cb0dc308d91ecae8514a341c2fa2324d3ade first
PS D:\tagstest [default tip]> hg update first
0 files updated, 0 files merged, 1 files removed, 0 files unresolved
PS D:\tagstest [default first]> cat .\.hgtags
cat : Cannot find path 'D:\tagstest\.hgtags' because it does not exist.

这种情况正是您在问题中所描述的。但让我们更进一步,添加另一个标签:

PS D:\tagstest [default first]> hg up tip
1 files updated, 0 files merged, 0 files removed, 0 files unresolved
PS D:\tagstest [default tip]> echo 'Something else' >> .\readme.txt
PS D:\tagstest [default ~1 tip]> hg ci -m "second commit"
PS D:\tagstest [default tip]> hg tag second
PS D:\tagstest [default tip]> cat .\.hgtags
9494cb0dc308d91ecae8514a341c2fa2324d3ade first
8b0455fffb17c978ef9e285905d76e34feae32f4 second
PS D:\tagstest [default tip]> hg up second
1 files updated, 0 files merged, 0 files removed, 0 files unresolved
PS D:\tagstest [default second]> cat .\.hgtags
9494cb0dc308d91ecae8514a341c2fa2324d3ade first

在这里您可以看到,将存储库状态更新为第二个标记.hgtags文件后并没有消失,但只有第一个标记,因为存储库的状态就在第二个标记添加到.hgtags文件之前。

更新:

在您的情况下,您似乎在创建修订版(您用 标记)后将第一个标签stable(导致创建 .hgtags 文件)添加到修订版。因此,当您将存储库状态更新为修订版时,没有文件,因为它尚未创建。0d80b6ba4ba3b51a44f0f1d339fcac1d4b21f387c70d8e7e516d8b9e0c520063a575b4acea1b2f94testtagtesttag.hgtags

例子:

PS D:\tagstest2> hg init
PS D:\tagstest2 [default tip]> echo "Something" > readme.txt
PS D:\tagstest2 [default ?1 tip]> hg addremove
adding readme.txt
PS D:\tagstest2 [default +1 tip]> hg ci -m "First commit"
PS D:\tagstest2 [default tip]> echo "Something else" > .\readme.txt
PS D:\tagstest2 [default ~1 tip]> hg ci -m "Second commit"
PS D:\tagstest2 [default tip]> echo "Something more" >> .\readme.txt
PS D:\tagstest2 [default ~1 tip]> hg ci -m "Third commit"
PS D:\tagstest2 [default tip]> hg tag -r 0 first
PS D:\tagstest2 [default tip]> hg tag -r 1 second
PS D:\tagstest2 [default tip]> hg gl
@  4[tip]   a0753742f012   2013-08-21 00:29 +0400   peshkovroman
|    Added tag second for changeset 7e4896c8ef3e
|
o  3   cee5760a9d1c   2013-08-21 00:29 +0400   peshkovroman
|    Added tag first for changeset 12f055c90ee8
|
o  2   f4c00a7394e1   2013-08-21 00:29 +0400   peshkovroman
|    Third commit
|
o  1[second]   7e4896c8ef3e   2013-08-21 00:28 +0400   peshkovroman
|    Second commit
|
o  0[first]   12f055c90ee8   2013-08-21 00:28 +0400   peshkovroman

当您调用 时hg up second,您的存储库状态将更新为修订版 1,但.hgtags仅在修订版 2 中创建。

于 2013-08-20T20:01:14.933 回答
4

可用的标签是所有 .hgtags 在你的 repo 的所有头中的联合。因此,要查看所有内容,您需要.hgtags查看hg heads. .hgtags@black_wizard 很好地解释了为什么在更新到它们时看不到标签,并且“从.hgtags文件中读取文件hg heads”是它们仍然有效的原因。

于 2013-08-20T22:05:56.253 回答