虽然Bitbucket的UI允许标记mercurial存储库的给定提交,但我找不到删除标记的方法(基于Web或命令行),这可能会被错误添加(实际上,那里没有确认提示添加它)。当用于控制版本时,这种错误可能是一个主要问题。
答案 0 :(得分:1)
Mercurial为所有命令提供内置帮助机制。在这种情况下,hg help tag
所示:
options:
-f --force force tag
让我们添加一个标签然后移动它:
$ hg init foo
$ cd foo/
$ touch a
$ hg add a
$ hg commit -m 'add a'
$ hg tag 0.1.0
历史是什么?
$ hg log -G
@ changeset: 1:9352d8865ee5
| tag: tip
| summary: Added tag 0.1.0 for changeset a4cab63b7c86
|
o changeset: 0:a4cab63b7c86
tag: 0.1.0
summary: add a
啊,我们改变了主意。我们缺少一个文件。让我们添加它(等等 在hg历史中添加一些内容):
$ touch b
$ hg add b
$ hg commit -m 'add b'
我们希望将0.1.0
标记移至提示。试试吧:
$ hg tag 0.1.0
abort: tag '0.1.0' already exists (use -f to force)
很清楚。让我们再试一次:
hg tag --force 0.1.0
历史是什么?
hg log -G
@ changeset: 3:04b62f2a9b16
| tag: tip
| summary: Added tag 0.1.0 for changeset 3d8bb8a977e6
|
o changeset: 2:3d8bb8a977e6
| tag: 0.1.0
| summary: add b
|
o changeset: 1:9352d8865ee5
| summary: Added tag 0.1.0 for changeset a4cab63b7c86
|
o changeset: 0:a4cab63b7c86
summary: add a
正如我们所看到的,标签已移至新位置。
为了好奇,标签是如何存储的?在一个简单的文本文件中:
$ cat .hgtags
a4cab63b7c868638e51a45d93443b1a0eb56e1e4 0.1.0
a4cab63b7c868638e51a45d93443b1a0eb56e1e4 0.1.0
3d8bb8a977e6be693a30c30d7d7675d04623690f 0.1.0
如果.hgtags
文件有多个具有相同标记的条目,则为最后一个
胜。合并分支时经常会出现这种情况。
留给读者:显然这些变化是本地的。你必须推动 bitbucket让它们公开。
修改强>
回答其他问题:是否有办法删除标记,或重命名同一提交的标记?
最安全的方法是不重命名标记,而是为同一个提交添加新的标记名称(使用hg tag -r REV
)。换句话说:单个提交可以根据需要关联任意数量的标签。
也可以删除标签,只需从.hgtags
中删除相应的行即可。这很正确,因为每个分支都有一个该文件的副本,并且它可以作为合并的结果返回。