From: Jeff Garzik <jgarzik@pobox.com>
To: Dave Airlie <airlied@gmail.com>
Cc: Linux Kernel <linux-kernel@vger.kernel.org>,
Andrew Morton <akpm@osdl.org>,
Git Mailing List <git@vger.kernel.org>,
Linus Torvalds <torvalds@osdl.org>
Subject: Re: [doc]playing with git, and netdev/libata-dev trees
Date: Sat, 04 Jun 2005 06:26:09 -0400 [thread overview]
Message-ID: <42A181C1.3010902@pobox.com> (raw)
In-Reply-To: <21d7e99705060401405cfd5a11@mail.gmail.com>
[-- Attachment #1: Type: text/plain, Size: 2660 bytes --]
Dave Airlie wrote:
>>When I merge a patch for drivers/net/forcedeth.c, I merge it into a
>>brand new 'forcedeth' repository, a peer to the 40+ other such
>>repository. Under BitKeeper, I made these repositories available merged
>>together into one big "netdev-2.6" repository because it was too time
>>consuming to make the individual 50+ trees publicly available. With
>>git, developers have direct access to the individual trees.
>>
>>I thought I would write up a quick guide describing how to mess around
>>with the netdev and libata-dev trees, and with git in general.
>>
>
>
> Thanks for this, I'm starting to get up to speed on git now...
>
> Two questions,
>
> 1. when you want to publish your tree what do you do? just rsync it
> onto kernel.org?
Basically. I copy the attached script into each repo, customize the
script for the upload destination.
When I publish the tree, I just cd to the toplevel dir on my local
workstation, and run "./push"
> 2. When you are taking things from your queue for Linus do you create
> another tree and merge your branches into it or what?
Not quite sure what you're asking, but I'll attempt to answer anyway :)
When I prepare a submission for Linus, I will pull several branches into
a single 'for-linus' conglomeration branch. I do this with the
following incantation, for each branch I am pushing upstream:
git-resolve-script $(cat .git/HEAD) $(cat .git/refs/heads/$branch) \
`pwd` $branch
(Note that I modified my git-resolve-script to take an additional $4
argument, which causes the string " branch $4" to be added to the merge
cset's commit msg)
After I take care of all the merge conflicts[1] from the
git-resolve-script run, I give the big pile of mush a final build and
test, and then run "./push".
For the "please pull" email, I use diffstat, git-diff-tree,
git-changes-script and the newly written git-shortlog.
Jeff
[1] I'm still scared of conflicts in the merge process. Simple and
automatic merging works just fine, like it did under BitKeeper. But if
there are conflicts that cause git-pull-script/git-resolve-script to
bail, then I bail as well: I export a patch, run patch(1), and then
handle the merge the Old Fashioned Way(tm) by looking at .rej files.
I really wish somebody would write a merge helper for git that places
the conflicts side-by-side in the code [in the working dir]. BitKeeper
and CVS both presented conflicts to you in this manner.
The "I resolved this conflict, now let's continue where we left off"
process is still quite raw in git. I suppose this is something that is
left for others to script, above the plumbing, but hey...
[-- Attachment #2: push --]
[-- Type: text/plain, Size: 137 bytes --]
#!/bin/sh
rsync -e ssh --verbose --delete --stats --progress -az .git/ master.kernel.org:/pub/scm/linux/kernel/git/jgarzik/misc-2.6.git
next prev parent reply other threads:[~2005-06-04 10:23 UTC|newest]
Thread overview: 7+ messages / expand[flat|nested] mbox.gz Atom feed top
2005-05-26 5:26 [doc][git] playing with git, and netdev/libata-dev trees Jeff Garzik
2005-05-26 8:19 ` [doc]playing " Frank Sorenson
2005-05-26 11:54 ` James Purser
2005-06-04 8:40 ` Dave Airlie
2005-06-04 10:26 ` Jeff Garzik [this message]
2005-06-04 10:31 ` Dave Airlie
2005-06-04 18:16 ` Jeff Garzik
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=42A181C1.3010902@pobox.com \
--to=jgarzik@pobox.com \
--cc=airlied@gmail.com \
--cc=akpm@osdl.org \
--cc=git@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=torvalds@osdl.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).