git for-each-ref
tells you what each ref is to by default, its id and its type. To restrict it to just tags, do git for-each-ref refs/tags
.
[T]he output has three fields: The hash of an object, the type of the object, and the name in refs/tags that refers to the object. A so-called “lightweight” tag is a name in refs/tags that refers to a
commit
¹ object. An “annotated” tag is a name in refs/tags that refers to atag
object.– Solomon Slow (in the comments)
Here is an example:
$ git for-each-ref refs/tags
902fa933e4a9d018574cbb7b5783a130338b47b8 commit refs/tags/v1.0-light
1f486472ccac3250c19235d843d196a3a7fbd78b tag refs/tags/v1.1-annot
fd3cf147ac6b0bb9da13ae2fb2b73122b919a036 commit refs/tags/v1.2-light
To do this for just one ref, you can use git cat-file
-t
on the local ref, to continue the example:
$ git cat-file -t v1.0-light
commit
$ git cat-file -t v1.1-annot
tag
¹ tags can refer to any Git object, if you want a buddy to fetch just one file and your repo’s got a git server, you can git tag forsam :that.file
and Sam can fetch it and show it. Most of the convenience commands don’t know what to do with tagged blobs or trees, but the core commands like update-index and such do