1

列出远程存储库的最新标记会产生与克隆该存储库然后描述其标记不同的答案。例如

$ ​git ls-remote --refs git://git.kernel.org/pub/scm/git/git.git | tail -1
dcba104ffdcf2f27bc5058d8321e7a6c2fe8f27e    refs/tags/v2.9.5
$ git clone -q git://git.kernel.org/pub/scm/git/git.git gitdir && cd gitdir && git describe --tags
v2.31.1-606-gdf6c4f7

这两种价值观如何相互关联?它们有何不同?

我知道“标签名称是本地的”,我的问题可能与此有关,但我想我不明白这句话的含义。在打电话之前我确实尝试了另一个建议,但无济于事。git fetch --tagsdescribe

我最终想要做的是以编程方式找到最稳定的版本或标签(如果他们不使用版本),并检查该版本以在本地构建它。

4

2 回答 2

1

引用似乎按字母顺序排序,而不是按数值排序,因此tail -1返回的不是最新标签,而是字母排序中的最后一个。查看git ls-remote;的全部输出 这是相关部分:

a320a5c4764b02f0898a98b4b58e11fad5e54e09        refs/tags/v2.3.9
2d9685d47a7e516281aa093bf0cddc8aafa72448        refs/tags/v2.30.0
a8eaf9de52c2d49799d7dc724e688ccbfa74390c        refs/tags/v2.30.0-rc0
cb70effebd91d9e0d4ce81650785e973b5d16ad1        refs/tags/v2.30.0-rc1
a6fee3f22b95c86086b11e3c93d0f1752f9a75c5        refs/tags/v2.30.0-rc2
36b80a59b799802fe776ed390870fe520d262f5c        refs/tags/v2.30.1
4340cdd2bdf420acc349f5cda141141230d5095a        refs/tags/v2.30.2
3e90d4b58f3819cfd58ac61cb8668e83d3ea0563        refs/tags/v2.31.0
4c4ac06896d8b9ec1ded1d5d9aeedb4e8ece44ab        refs/tags/v2.31.0-rc0
6a80b8083c4be2c5703ec122e511a6747af53295        refs/tags/v2.31.0-rc1
ca1f84a036c5658938d72650ae34630ebb140866        refs/tags/v2.31.0-rc2
28afb7555c7013c02b5ee5dc0286546f1f8e2b8f        refs/tags/v2.31.1
67308bd628c6235dbc1bad60c9ad1f2d27d576cc        refs/tags/v2.4.0
92db05f2a784fe0a715de29fc97172eac6bb5089        refs/tags/v2.4.0-rc0
1c8737f27f912aa2438ce3bf9d4e83eb178de00a        refs/tags/v2.4.0-rc1
48e512c8c9397baa5533efa6683f45646234ae1e        refs/tags/v2.4.0-rc2
4beece6ef56cb59ea05afb326fd17c1839b8f282        refs/tags/v2.4.0-rc3
2be062dfcfd1fd4aca132ec02a40b56f63776202        refs/tags/v2.4.1
dd0e3e9610a9b312236fb926c5a9d8cbd73190d9        refs/tags/v2.4.10
4f24175ae76efaf8265e179662a4258387019256        refs/tags/v2.4.11
0a493fee385e530baa898a4ba4c0a64fd02ed0d6        refs/tags/v2.4.12
29932f3915935d773dc8d52c292cadd81c81071d        refs/tags/v2.4.2

要按数值排序,请使用--sort=v:refname

$ git ls-remote --sort=v:refname --refs git://git.kernel.org/pub/scm/git/git.gitt | tail -10
a8eaf9de52c2d49799d7dc724e688ccbfa74390c        refs/tags/v2.30.0-rc0
cb70effebd91d9e0d4ce81650785e973b5d16ad1        refs/tags/v2.30.0-rc1
a6fee3f22b95c86086b11e3c93d0f1752f9a75c5        refs/tags/v2.30.0-rc2
36b80a59b799802fe776ed390870fe520d262f5c        refs/tags/v2.30.1
4340cdd2bdf420acc349f5cda141141230d5095a        refs/tags/v2.30.2
3e90d4b58f3819cfd58ac61cb8668e83d3ea0563        refs/tags/v2.31.0
4c4ac06896d8b9ec1ded1d5d9aeedb4e8ece44ab        refs/tags/v2.31.0-rc0
6a80b8083c4be2c5703ec122e511a6747af53295        refs/tags/v2.31.0-rc1
ca1f84a036c5658938d72650ae34630ebb140866        refs/tags/v2.31.0-rc2
28afb7555c7013c02b5ee5dc0286546f1f8e2b8f        refs/tags/v2.31.1
于 2021-05-13T21:17:36.537 回答
1

TL;博士

我相信您想要的是git describe --tags.

细节

这两个命令有不同的用途。

git ls-remote列出远程存储库上的引用,但不对它们列出的顺序做出任何承诺。当然,最近的通常是最后一个,但它不一定是最相关的,特别是如果该标签位于尚未合并的分支上。

git describe另一方面,它试图为您提供HEAD(默认情况下,或您指定的提交)关于可从那里到达的最新标签的简明描述。如果您仅将标签用于稳定提交,那么这可能就是您想要的标签。然后,一旦它找到该标签,它就会告诉您还有多少次提交HEAD,在您的示例中有 606 个,然后是“g”(不知道为什么),然后是HEAD. 这意味着任何提交的人类可读描述,如“哦,你在 v2.31.1 之前提交了 606 次”,但也是一个明确的描述,因为你得到了 sha1。

至于将--tags选项添加到git describe,如果您有没有注释的标签,则需要它,例如,如果某些标签是使用git tag <tagname> <commit>而不是git tag -a <tagname> <commit>. 后者更可取,因为它允许标记器描述标记的内容,但你不能总是指望每个人都在使用它。因此,添加--tagsgit describe.

如果您的存储库仅包含稳定版本的标签,并且这些版本不在​​不同的发布分支上,并且您的标签名称中从来没有连字符,那么这将是最新的稳定版本,它是 的父级HEAD

git describe --tags | sed 's/-.*//'
于 2021-05-13T21:17:06.077 回答