On 03-02-2007, Giorgos Keramidas wrote: > On 2007-02-02 11:01, Linus Torvalds <torvalds@xxxxxxxxxxxxxxxxxxxx> wrote: >>On Fri, 2 Feb 2007, Giorgos Keramidas wrote: >>> Sometimes, 'sliding a tag' is a real-world need. Losing the >>> information of who did the tag sliding and when, is not good. >> >> In practice, this is not much of an issue. > > Sure it is. Maybe not in the context of all projects or all teams, but > properly versioning tag names and knowing who installed the tag, and > when is quite often an issue with unversioned tags in some of the teams > I have worked with. Knowing who installed (made) a tag, and when is totally separate issue from versioning tag names. In git first (along with tag description, and optional PGP signing of tag) is solved by using tag objects, it means indirect pointers: name like v1.4.0 (refs/tags/v1.4.0) refers to tag object, which looks like below: object 41292ddd37202ff6dce34986c87a6000c5d3fbfa type commit tag v1.4.0 tagger Junio C Hamano <junkio@xxxxxxx> Sat Jun 10 12:43:37 2006 -0700 GIT 1.4.0 -----BEGIN PGP SIGNATURE----- Version: GnuPG v1.4.3 (GNU/Linux) iD8DBQBEiyDswMbZpPMRm5oRAr5KAJ95nnyY8x7nRVIxkV87AHux6Kdf2gCgi4xu NxK2qKsAkGXCil7zSFviawA= =Qhax -----END PGP SIGNATURE----- Second, [local] versioning tags (if it is really needed, see discussion below) is solved using reflogs for tags, which look like below: 000000... fab4f1... Jakub Narebski <jnareb@xxxxxxxxx> 1163751632 +0100 \ fetch origin git://git.kernel.org/pub/scm/git/git.git: storing tag (it is in single line, broken here for better readibility). It is local history; I don't thing global history of tags is needed (see below). >> First off, CVS tag usage is insane, but it's insane for *other* >> reasons (ie people use tags differently in CVS, but they do it not >> because they want to use tags that way, but because CVS makes it >> impossible to do anything saner). >> >> So pointing to CVS tag usage as an argument is pointless. You might as >> well say that you shouldn't save the merge information, because CVS >> doesn't do it, and manual tags are a good way to do it. >> >> Secondly, the problems with tags having "history" is that you can't >> really resolve them anyway. You have to pick one. You can't "merge" >> them. > > Ok, maybe CVS was not so good as an example of why versioned tags *are* > useful, but my comment came from the experience I have with the tagging > of FreeBSD release builds. The -STABLE branch os FreeBSD may be tagged > with RELENG_X_Y_Z_RELEASE at a particular point in time. If we find > that some important bug fix has to go in, the fix is committed, and the > tag can 'slide' forward for only a particular file or set of files. That is a bad, bad idea. You should have v1.4.4 tag, and published tag should be immutable, so if someone tells that there is bug in v1.4.4 you know what this version is. If you want to gather fixes for v1.4.4, you make v1.4.4-fixes _branch_, commit fix on this branch (perhaps also merging it into current work), and tag result v1.4.4.1 or v1.4.4-patch1. Tags are meant to be immutable. > When tags are versioned, this operation is properly versioned too. It's > apparent from browsing the global tag history that the specific tag > *was* moved forward; it's obvious where it was pointing before the > 'slide' operation; it's obvious which files the 'slide' affected, etc. This operation IBHO has no sense; I understand that you can have local, private tags you slide like bisect-low, bisect-up, before-merge,... Public tags: no. [...] >> In other words, tags are atomic *events*, not history. And I certainly >> agree that you shouldn't lose the events (unless you want to, of course). > > Tags are a little of two different things: > > (1) They are 'events' in the sense that someone has placed them to a > tree, and this operation is a very real, very natural event, and *this* > event should be versioned. Tags should not be placed to a tree. [...] -- Jakub Narebski Poland - To unsubscribe from this list: send the line "unsubscribe git" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html