From: Junio C Hamano <gitster@pobox.com>
To: Matthias Andree <matthias.andree@gmx.de>
Cc: "Randal L. Schwartz" <merlyn@stonehenge.com>,
Junio C Hamano <gitster@pobox.com>,
Linus Torvalds <torvalds@linux-foundation.org>,
Git Mailing List <git@vger.kernel.org>
Subject: Re: Could this be done simpler?
Date: Thu, 25 Jun 2009 10:25:52 -0700 [thread overview]
Message-ID: <7v3a9ogr8f.fsf@alter.siamese.dyndns.org> (raw)
In-Reply-To: <4A43A6B3.5020407@gmx.de> (Matthias Andree's message of "Thu\, 25 Jun 2009 18\:32\:51 +0200")
Matthias Andree <matthias.andree@gmx.de> writes:
> Could we ditch the current git-pull --append description? Can then please
> somebody rewrite this paragraph? This somebody must have completely understood
> (1) what this feature is good for (practically speaking)
>
> (2) how it works (technically speaking, to provide reference information)
>
> That would be much more useful, and the use would last longer :-)
>
> I don't dare ask Junio directly.
But if you run blame and mailing list archive search, you would discover
that "fetch --append" was my invention. After all, the entire Octopus
idea originates from me at 211232b (Octopus merge of the following five
patches., 2005-05-05). It is interesting to realize that it was actually
a Pentapus made on the day of 5/5/5 ;-)
I thought I was going to take blame on the incomprehensive documentation
and pass it on to me being non-native speaker/writer of English, but the
situation is bit funny. Documentation/fetch-options.txt says this:
-a::
--append::
Append ref names and object names of fetched refs to the
existing contents of `.git/FETCH_HEAD`. Without this
option old data in `.git/FETCH_HEAD` will be overwritten.
Perhaps there has a cut&paste error? I haven't looked.
Now answers to (1) and (2).
(1) The feature was designed exactly for the use case Linus described.
(2) "git fetch" leaves list of <commit object, repo, branch, flag> for
each ref fetched from repository in .git/FETCH_HEAD, where flag tells
if it is meant for merging. "git pull" runs "git fetch", reads from
this file to learn which ones to pass to "git merge". The
information also is given to "git fmt-merge-msg" to come up with the
message.
Usually "git fetch" first empties the existing contents of the file
and stores the list of refs it fetched. With --append, it doesn't
empty the file; refs fetched by the previous invocation of "git
fetch" will be kept and the refs it fetched are appenede.
So:
$ git fetch one a
$ git fetch --append two b
$ git pull --apend three c
will end up having all the three refs from different repositories in
.git/FETCH_HEAD. I.e.
branch a, from repo one, to be merged
branch b, from repo two, to be merged
branch c, from repo three, to be merged
when "git fetch" run by the the last "git pull" returns. "git pull"
reads the file and learn what to give to "git fmt-merge-msg" (to come
up with the message for the merge commit) and "git merge" (to create
the merge commit).
next prev parent reply other threads:[~2009-06-25 17:26 UTC|newest]
Thread overview: 15+ messages / expand[flat|nested] mbox.gz Atom feed top
2009-06-24 21:35 Could this be done simpler? Linus Torvalds
2009-06-25 1:04 ` Junio C Hamano
2009-06-25 14:33 ` Randal L. Schwartz
2009-06-25 16:32 ` Matthias Andree
2009-06-25 17:25 ` Junio C Hamano [this message]
2009-06-25 21:54 ` Matthias Andree
2009-06-27 0:26 ` Junio C Hamano
2009-06-25 18:32 ` Junio C Hamano
2009-06-25 17:19 ` Michael J Gruber
2009-06-25 22:02 ` Christian Couder
2009-06-25 22:23 ` Christian Couder
2009-06-25 22:29 ` Junio C Hamano
2009-06-25 22:50 ` Linus Torvalds
2009-06-25 23:17 ` Junio C Hamano
2009-06-25 22:55 ` Christian Couder
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=7v3a9ogr8f.fsf@alter.siamese.dyndns.org \
--to=gitster@pobox.com \
--cc=git@vger.kernel.org \
--cc=matthias.andree@gmx.de \
--cc=merlyn@stonehenge.com \
--cc=torvalds@linux-foundation.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).