From: linux@horizon.com
To: git@vger.kernel.org
Cc: junkio@cox.net, linux@horizon.com
Subject: Re: More merge questions (why doesn't this work?)
Date: 2 Dec 2005 04:19:46 -0500 [thread overview]
Message-ID: <20051202091946.1631.qmail@science.horizon.com> (raw)
In-Reply-To: <7vek4xsx49.fsf@assigned-by-dhcp.cox.net>
I was playing with the implications of the "deleted file in the
index is not a conflict" merge rule, and came up with the following
octopus test which fails to work. Note line 2 when choosing a
directory to run it in!
#!/bin/bash -xe
rm -rf .git
git-init-db
echo "File A" > a
echo "File B" > b
echo "File C" > c
git-add a b c
git-commit -a -m "Octopus test repository"
git-checkout -b a
echo "Modifications to a" >> a
git-commit -a -m "Modified file a"
git-checkout -b b master
echo "Modifications to b" >> b
git-commit -a -m "Modified file b"
git-checkout -b c master
rm c
git-commit -a -m "Deleted file c"
git-checkout master
#git merge --no-commit "" master c b a
#git merge --no-commit "" master a b c
git-rev-parse a b c > .git/FETCH_HEAD
git-octopus
(Commented out are the first few things I tried.)
Can someone tell me why this doesn't work? It should be a simple
in-index merge.
Right after the incomplete merge (I hacked this into the
git-octopus script), git-ls-files -s produces
100644 8fb437b77759c7709c122fbc8ba43f720e1fbc0a 0 a
100644 b3418f25da4393974aa205e2863f012e5b503369 0 b
100644 df78d3d51c369e1d2f1eadb73464aadd931d56b4 1 c
100644 df78d3d51c369e1d2f1eadb73464aadd931d56b4 2 c
Which should be case 10 of the t/t1000-read-tree-m-3way.sh
table and succeed.
Other things I've discovered...
1) The MAJOR difference between "git checkout" and "git reset --hard"
are that git-checkout takes a *head* as an argument and changes the
.git/HEAD *symlink* to point to that head (ln -sf refs/heads/<head>
.git/HEAD). "git reset" takes a *commit* (<rev>) as an argument and
changes the head that .git/HEAD points to to have that commit as its
hew tip (git-rev-parse <rev> > .git/HEAD)
All the other behavioural differences are relatively minor, and
appropriate for this big difference.
2) Don't use "git branch" to create branches, unless you really
*don't* want to switch to them. Use "git checkout -b".
3) Dumb question: why does "git-commit-tree" need "-p" before the
parent commit arguments? Isn't just argv[2]..argv[argc-1]
good enough?
4) If the "git-read-tree" docs for "--reset", does "ignored" mean
"not overwritten" or "overwritten"?
5) The final "error" message on "git-merge --no-commit" is a bit
alarming for a newbie who uses it because they don't quite trust
git's enough to enable auto-commit. And it should be changed
from ""Automatic merge failed/prevented; fix up by hand" to
"fix up and commit by hand".
Or how about:
"Automatic commit prevented; edit and commit by hand."
which actually tells the truth.
6) The "pickaxe" options are being a bit confusing, and the fact they're
only documented in cvs-migration.txt doesn't help.
7) The git-tag man page could use a little better description of -a.
next prev parent reply other threads:[~2005-12-02 9:20 UTC|newest]
Thread overview: 64+ messages / expand[flat|nested] mbox.gz Atom feed top
2005-11-28 23:42 git-name-rev off-by-one bug linux
2005-11-29 5:54 ` Junio C Hamano
2005-11-29 8:05 ` linux
2005-11-29 9:29 ` Junio C Hamano
2005-11-30 8:37 ` Junio C Hamano
2005-11-29 10:31 ` Petr Baudis
2005-11-29 18:46 ` Junio C Hamano
2005-12-04 21:34 ` Petr Baudis
2005-12-08 6:34 ` as promised, docs: git for the confused linux
2005-12-08 21:53 ` Junio C Hamano
2005-12-08 22:02 ` H. Peter Anvin
2005-12-09 0:47 ` Alan Chandler
2005-12-09 1:45 ` Petr Baudis
2005-12-09 1:19 ` Josef Weidendorfer
2005-11-29 21:40 ` git-name-rev off-by-one bug linux
2005-11-29 23:14 ` Junio C Hamano
2005-11-30 0:15 ` linux
2005-11-30 0:53 ` Junio C Hamano
2005-11-30 1:27 ` Junio C Hamano
2005-11-30 1:51 ` Linus Torvalds
2005-11-30 2:06 ` Junio C Hamano
2005-11-30 2:33 ` Junio C Hamano
2005-11-30 3:12 ` Linus Torvalds
2005-11-30 5:06 ` Linus Torvalds
2005-11-30 5:51 ` Junio C Hamano
2005-11-30 6:11 ` Junio C Hamano
2005-11-30 16:13 ` Linus Torvalds
2005-11-30 16:08 ` Linus Torvalds
2005-12-02 8:25 ` Junio C Hamano
2005-12-02 9:14 ` [PATCH] merge-one-file: make sure we create the merged file Junio C Hamano
2005-12-02 9:15 ` [PATCH] merge-one-file: make sure we do not mismerge symbolic links Junio C Hamano
2005-12-02 9:16 ` [PATCH] git-merge documentation: conflicting merge leaves higher stages in index Junio C Hamano
2005-11-30 6:09 ` git-name-rev off-by-one bug linux
2005-11-30 6:39 ` Junio C Hamano
2005-11-30 13:10 ` More merge questions linux
2005-11-30 18:37 ` Daniel Barkalow
2005-11-30 20:23 ` Junio C Hamano
2005-12-02 9:19 ` linux [this message]
2005-12-02 10:12 ` More merge questions (why doesn't this work?) Junio C Hamano
2005-12-02 13:09 ` Sven Verdoolaege
2005-12-02 20:32 ` Junio C Hamano
2005-12-05 15:01 ` Sven Verdoolaege
2005-12-02 11:37 ` linux
2005-12-02 20:31 ` Junio C Hamano
2005-12-02 21:32 ` linux
2005-12-02 22:00 ` Junio C Hamano
2005-12-02 22:12 ` Linus Torvalds
2005-12-02 23:14 ` linux
2005-12-02 21:56 ` More merge questions linux
2005-11-30 16:12 ` git-name-rev off-by-one bug Linus Torvalds
2005-11-30 7:18 ` Junio C Hamano
2005-11-30 9:05 ` Junio C Hamano
2005-11-30 9:42 ` Junio C Hamano
2005-11-30 3:15 ` linux
2005-11-30 18:11 ` Daniel Barkalow
2005-11-30 17:46 ` Daniel Barkalow
2005-11-30 20:05 ` Junio C Hamano
2005-11-30 21:06 ` Daniel Barkalow
2005-11-30 22:00 ` Junio C Hamano
2005-11-30 23:12 ` Daniel Barkalow
2005-12-01 7:46 ` Junio C Hamano
2005-12-01 10:14 ` Junio C Hamano
2005-12-01 21:50 ` Petr Baudis
2005-12-01 21:53 ` Randal L. Schwartz
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=20051202091946.1631.qmail@science.horizon.com \
--to=linux@horizon.com \
--cc=git@vger.kernel.org \
--cc=junkio@cox.net \
/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).