"Paolo Ciarrocchi" <paolo.ciarrocchi@xxxxxxxxx> writes: > On Mon, Mar 3, 2008 at 2:14 PM, Matthieu Moy <Matthieu.Moy@xxxxxxx> wrote: >> "Paolo Ciarrocchi" <paolo.ciarrocchi@xxxxxxxxx> writes: >> >>> What is still not clear to me is where git is storing >>> the objects downloaded during a git fetch operation. >> >> git fetch downloads the objects to the object database, i.e. >> .git/objects/, usualy as a pack. Downloading as individual objects ("exploded") or as a pack depends on fetch.unpackLimit configuration. >> Now, just "having" the objects locally doesn't change much, an object >> starts being really interesting if you have a reference (typically, a >> branch) pointing to it. "git fetch" will update the remote references >> (for example, origin/master), but won't touch the working tree, and >> won't do any merge, fast-forward or not, to a local branch. So, most >> likely, "git fetch" will be followed by either a merge or a rebase. What is important git-fetch _always_ stores what it fetched in $GIT_DIR/FETCH_HEAD. Then depending on configuration and command line options it updates appropriate remote-tracking branches. For example if you do one-shot "git pull <remote> <branch>" git would not store fetched refs (heads) in tracking branches: see git-fetch(1). > Yes, your explanation perfectly match my understanding. > > I was, and I'm still, confused by the following sentence in the git merge > documentation: > > "A merge is always between the current HEAD and one or more > remote branch heads" This "remote" is here invalid. Merge can merge in any ref, not only remote-tracking branches. "git merge <branch>" would merge given branch into current (HEAD) branch: Before: 1---2---3---4---5---6---7 <-- master <-- HEAD \ \-A---B <-- devel (or origin/master) After "git merge devel" 1---2---3---4---5---6---7---M <-- master <-- HEAD \ / \-A---B-----/ <-- devel (or origin/master) where 'M' is merge (multi-parent) commit. > If I think to the following scenario: > > git fetch > git diff (to look at what I downloaded via git fetch) Because you download _series_ of commits "git log" would be usually more useful than "git diff". You can use <branch>@{1} for position of branch before fetch, or even ORIG_HEAD for position of HEAD branch before fetch (or pull). > git merge I'm not sure if "git merge" without branch specified would work. "git pull" should, so perhaps "git merge" would too. "git pull" would merge 'first' branch, or branch specified in branch/remote configuration. -- Jakub Narebski 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