Jon Smirl wrote: > On 9/13/06, Petr Baudis <pasky@xxxxxxx> wrote: >> Dear diary, on Wed, Sep 13, 2006 at 05:17:59PM CEST, I got a letter >> where Jon Smirl <jonsmirl@xxxxxxxxx> said that... >> > Abandoned branches are common in CVS since it is not distributed. >> > People start working on something in the main repo and then decide it >> > was a bad idea. In the git world these branches usually don't end up >> > in the main repo. >> >> Can't you just toss the branch away in that case? :-) > > It is a historical import. Everything that was in the initial repo > needs to be preserved otherwise they aren't going to get rid of the > old CVS repo. You can leave this in historical repository, and strip current repository from abandoned work, by the way. >> You could also stash the ref to refs/heads-abandoned/ instead of >> refs/heads/ if you want to keep the junk around for some reason. Of >> course you don't get the nice marker with explanation of why is this >> abandoned and who decided that, but you can just use an empty commit for >> the same purpose. > > If this is done with an object there should probably be some way to > encode it into the existing commit object. As it was said somewhere in this thread, you can use tags (tag objects) for that, i.e. tag each of the abandoned branches, explaining why branch wa abandoned for example, remove head refs, and move tag refs to refs/abandoned or refs/tags-abandoned/ or refs/Attic/ or in refs-abandoned/ (the last has the advantage to not be included by default in any command, even when --all is given) > Moving the refs into refs/abandoned would work too. We would need new > git commands to do this and flags on the visualization tools to > include the abandoned branches. On the other hand doing this is > recording state about the repository in the refs directory instead of > writing this state into the repo itself. There is no need for new flag. If you give --all flag to the gitk command line or the list of commits option field, all the refs in $GIT_DIR/refs/ would be included. If you will use refs-abandoned/ instead, it would be enough I guess to give refs-abandoned/ or refs-abandoned/*. Of course you would need some change to visualisers to mar abandoned branches in different way. gitweb as of now uses only refs/heads and refs/tags; markers are taken from $GIT_DIR/info/refs or "git-ls-remotes ." (i.e. all refs/) -- Jakub Narebski Warsaw, Poland ShadeHawk on #git - 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