我正在尝试如何下载Git存储库的特定标签,它比当前版本落后一个版本。

我看到git网页上有一个前一个版本的标记,对象名是长十六进制数。

但根据网站的说法,版本名为“标记版本1.1.5”。

我尝试了这样的命令(名称已更改):

git clone http://git.abc.net/git/abc.git my_abc

我确实得到了一些东西——一个目录,一堆子目录等等。

如果它是整个存储库,我如何获得我正在寻找的版本?如果没有,我如何下载该特定版本?


当前回答

签出标记

如果您想查看标记指向的文件版本,可以执行git签出,尽管这会使存储库处于“分离的HEAD”状态,这会产生一些不良副作用:

$ git checkout 2.0.0
Note: checking out '2.0.0'.

You are in 'detached HEAD' state. You can look around, make experimental
changes and commit them, and you can discard any commits you make in this
state without impacting any branches by performing another checkout.

If you want to create a new branch to retain commits you create, you may
do so (now or later) by using -b with the checkout command again. Example:

  git checkout -b <new-branch-name>

HEAD is now at 99ada87... Merge pull request #89 from schacon/appendix-final

$ git checkout 2.0-beta-0.1
Previous HEAD position was 99ada87... Merge pull request #89 from schacon/appendix-final
HEAD is now at df3f601... add atlas.json and cover image

在“分离的HEAD”状态下,如果您进行了更改,然后创建了一个提交,那么标记将保持不变,但是您的新提交将不属于任何分支,并且将无法访问,除非通过确切的提交哈希。因此,如果您需要进行更改,比如说您正在修复旧版本上的错误,您通常需要创建一个分支:

$ git checkout -b version2 v2.0.0
Switched to a new branch 'version2'

如果您这样做并提交,您的version2分支将与v2.0.0标记略有不同,因为它将随着您的新更改而前进,因此请务必小心。

其他回答

try:

git clone -b <name_of_the_tag> <repository_url> <destination>

如果可以使用linux sort命令对标记进行排序,请使用以下命令:

git tag | sort -n | tail -1

例如,如果git标记返回:

v1.0.1
v1.0.2
v1.0.5
v1.0.4

gittag|sort-n|tail-1将输出:

v1.0.5

gittag|sort-n|tail-2|head-1将输出:

v1.0.4

(因为您要求第二个最近的标签)

要签出标记,请首先克隆repo,然后键入:

git checkout v1.0.4

..或您需要的任何标签。

根据彼得·约翰逊的回答,我为自己创建了一个很好的别名:

alias gcolt="git checkout $(git tag | sort -V | tail -1)"

又名“git checkout最新标签”。

这依赖于GNU版本的sort,它可以恰当地处理lOranger指出的情况:

v1.0.1
...
v1.0.9
v1.0.10

如果您使用的是mac,请brew安装coreutils,然后调用gsort。

我查看了git结账文档,发现了一件有趣的事情:

git checkout-b<new_branch_name><start_point>,其中<start_point>是提交的名称开始新分支的位置;默认为HEAD

因此,我们可以将标记名(因为标记只是提交的名称)称为:

>>git checkout-b 1.0.2_branch 1.0.2稍后,修改一些文件>>git push--标记

P.S:在Git中,你不能直接更新标签(因为标签只是提交的标签),你需要签出与分支相同的标签,然后提交到它,然后创建一个单独的标签。

我不是git专家,但我认为这应该奏效:

git clone http://git.abc.net/git/abc.git
cd abc
git checkout my_abc 

OR

git clone http://git.abc.net/git/abc.git
cd abc
git checkout -b new_branch my_abc

第二个变体基于标记建立一个新的分支,这样可以避免“分离的HEAD”。(git结账手册)

每个git repo都包含整个修订历史,因此克隆repo可以让您访问最新的提交,以及之前的所有内容,包括您要查找的标记。