Jeff King <peff@xxxxxxxx> writes: > I think a left a few things unsaid in my "v1.0-bob" example. I was > imagining that there are _two_ v1.0 tags floating around. One that you > consider "wrong", tagged by Bob, and one you like. You keep the latter > in refs/tags/v1.0. Ahh, OK. To continue playing devil's advocate and to step back a bit, - The "git describe" command finds that the given commit is "closest" to that tag Bob called "v1.0". - But if it outputs "v1.0" like the current code does, it cannot be fed back to get_oid() to name the right object, if the given commit is "at" the tag (i.e. there is no "-$number-g$objectname" suffix), which is a problem. We want "git describe" to give an output usable with get_oid() and the name must refer to the correct object (i.e. the one given to "git describe" as an input). There are multiple approaches to make it possible to feed the output back to get_oid() to obtain correct result: - We can describe it based on "v1.0-bob" (i.e. refname, not tagname), which is what the proposed patch wants to do. This is nice as it simply exploits the fact that namespace of the refs ensures that there can locally be only one tag "v1.0". - We can always add "-$number-g$objectname" suffix when we need to base the output of "git describe" on such a tag whose name does not match its refname. Both names "v1.0-bob-0-g0123456" and "v1.0-0-g0123456" would be accepted by get_oid() and refer to the same object 0123456. If we do this, there is no longer any requirement that the "tagname" part alone of the output must be usable with get_oid() to name the correct object, and because "v1.0-bob" is merely a local name external people may not even know about, using "v1.0-bob-0-g0123456" may be less desirable than using "v1.0-0-g0123456". - We can skip the "wrong" tag and not use it to name anything. "git describe" may use some other tag that is stored in its right place, which may be a bit more distant than tag "v1.0-bob". The warning message may indicate "we would have used this tag to name the object because it was the closest, but we skipped because of a tagname anomaly". This may be what the person who moved Bob's "v1.0" to "v1.0-bob" intended---it is a "wrong" tag that is kept only to communicate _about_ the tag, not to be used to refer to other objects relative to it. The "use the refname" and the "use -0-gXXXXXX suffix if using a tag at a wrong place" approaches are simple and would produce a more "correct" result than what we currently give. The "don't use it" approach simply sidesteps the problem altogether, which is sort-of attractive ;-)