Re: Git training wheels for the pimple faced maintainer

From: Kyle Moffett
Date: Fri Oct 20 2006 - 00:29:03 EST


On Oct 19, 2006, at 19:44:41, Linus Torvalds wrote:
- If you actually want your development tree to "track" my tree, I'd suggest you have your "for-linus" branch that you put the work you want to track into, and then a plain "linus" branch which tracks _my_ tree. Then you can just fetch my tree (to keep your "linus" branch up-to-date), and if you want your development branch to track those changes, you can just do a "git rebase linus" in your "for-linus" branch.

I'm no official maintainer, but I have several random local GIT trees I use for local development and patches which don't make a lot of sense outside my personal systems. Because of this it's important for me to be able to migrate my changes over to newer versions easily, but I don't care all that much about maintaining old history, I just want my separate patches to work on latest Linus.

It also matters a lot to me to be able to wipe out a devel tree with a quick rm and create it from scratch.

As a result, I have an "upstream" tree with various "linus", "libata- dev", etc upstream branches that I pull from for various reasons. I then have a "linux-template" tree which has no objects of its own but references the "upstream" tree's object directory and "pulls" from some branch in the upstream tree. To create a new devel tree I just copy the "upsteram" tree which is the size of a single checkout, and start patching. To update all my patchsets to latest linus:

### This gets the upstream tree to the latest state
$ cd ~/git/linux/upstream
$ cg-fetch linus
$ cg-fetch libata-dev
$ cg-fetch $OTHER_UPSTREAM_SRC

## Optionally repack the single copy of the upstream objects for better speed
$ git-repack -a -d -l -f

### Now fast-forward the patches in $MY_TREE to be based on the latest version of the random upstream tree
$ cd ~/git/linux/$MY_TREE
$ cg-fetch upstream
$ git-rebase upstream
### Now I resolve rebase-conflicts

When I want to export a GIT tree for somebody else to look at I just pull into the HTTP-accessible GIT directories from my various development trees, optionally merging if necessary.

This isn't "The Best Solution(TM)" for everyone, but it works really well for me and has the advantage of only storing one easily-repacked copy of the upstream sources; the rest of my dev trees have only the overhead of my local changesets and a single copy of the kernel sources. In the event I have to wipe out a dev tree it's a very fast "rm -rf $OLD_TREE", and creating one is also a fast "cp -a linux- template $NEW_TREE"

Cheers,
Kyle Moffett

-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/