From: Christian Couder <christian.couder@gmail.com>
To: Junio C Hamano <gitster@pobox.com>
Cc: Christian Couder <chriscool@tuxfamily.org>,
git@vger.kernel.org,
Johannes Schindelin <Johannes.Schindelin@gmx.de>,
Stephan Beyer <s-beyer@gmx.net>,
Daniel Barkalow <barkalow@iabervon.org>,
Jakub Narebski <jnareb@gmail.com>,
Linus Torvalds <torvalds@linux-foundation.org>
Subject: Re: [PATCH v3 3/4] reset: add option "--merge-safe" to "git reset"
Date: Thu, 17 Sep 2009 14:25:40 +0200 [thread overview]
Message-ID: <c07716ae0909170525h21ab26f5y84b0fbce2192c69@mail.gmail.com> (raw)
In-Reply-To: <7vk4zykv7o.fsf@alter.siamese.dyndns.org>
On Thu, Sep 17, 2009 at 7:15 AM, Junio C Hamano <gitster@pobox.com> wrote:
> Christian Couder <chriscool@tuxfamily.org> writes:
>
>> From: Stephan Beyer <s-beyer@gmx.net>
>>
>> This option is nearly like "--merge" except that it is
>> safer.
>
> Do you still want to have this description after the last round?
>
>> The table below shows what happens when running
>> "git reset --option target" to reset the HEAD to another
>> commit (as a special case "target" could be the same as
>> HEAD) in the cases where "--merge" and "--merge-safe"
>> (abreviated --m-s) behave differently.
>>
>> working index HEAD target working index HEAD
>> B B A A --m-s B A A
>> --merge A A A
>> B B A C --m-s (disallowed)
>> --merge C C C
>
> I'd like to see at least the following rows filled as well.
>
> X U A A --m-s ??? ??? ???
> --merge ??? ??? ???
> X U B A --m-s ??? ??? ???
> --merge ??? ??? ???
>
>> In this table, A, B and C are some different states of a file.
>
> ... and X is "don't care", and U is "unmerged index".
I will have a look, but it seems to me that --m-s and --merge
behave the same in these cases.
>> The code comes from the sequencer GSoC project:
>>
>> git://repo.or.cz/git/sbeyer.git
>>
>> (at commit 5a78908b70ceb5a4ea9fd4b82f07ceba1f019079)
>>
>> But in the sequencer project the "reset" flag was set in the "struct
>> unpack_trees_options" passed to "unpack_trees()". With this flag the
>> changes in the working tree were discarded if the file was different
>> between HEAD and the reset target.
>
> If you need to have four lines worth of description here, is this still
> Stephan's patch, or would it be more appropriate to say "This is based on
> an earlier GSoC work by Stephan in git://repo.or.cz/git/sbeyer.git
> repository." and you take all the credit and blame?
As you insist, I will take all the credit and blame.
>> static const char * const git_reset_usage[] = {
>> - "git reset [--mixed | --soft | --hard | --merge] [-q] [<commit>]",
>> + "git reset [--mixed | --soft | --hard | --merge | --merge-safe] [-q] [<commit>]",
>> "git reset [--mixed] <commit> [--] <paths>...",
>> NULL
>> };
>
> As we established in the previous round, this is _different_ from --merge,
> but *not* in the sense that --merge is more dangerous and users should be
> using this new option instead, but in the sense that --merge perfectly
> works well for its intended use case, and this new option triggers a mode
> of operation that is meant to be used in a completely different use case,
> which is unspecified in this series without documentation.
>
> In that light, is --merge-safe still a good name for the option, or merely
> a misleading one?
I agree that it could be misleading. What about "--stash" ?
> As I said in the previous round, --merge discards the modified index state
> when switching, and it is absolutely _the right thing to do_ in the use
> case it was intended for. It is _not_ dangerous, and using --merge-safe
> in that scenario is not being _safe_ but is actively a _wrong_ thing to do.
Ok.
>> @@ -95,6 +98,16 @@ static int reset_index_file(const unsigned char *sha1, int reset_type, int quiet
>>
>> read_cache_unmerged();
>>
>> + if (reset_type == MERGE_SAFE) {
>> + unsigned char *head_sha1;
>> + if (get_sha1("HEAD", head_sha1))
>> + return error("You do not have a valid HEAD.");
>> + if (parse_and_init_tree_desc(head_sha1, desc))
>> + return error("Failed to find tree of HEAD.");
>> + nr++;
>> + opts.fn = twoway_merge;
>> + }
>
> get_sha1() takes an allocated buffer, does not allocate space on its own.
> I think you meant "unsigned char head_sha1[20];" here.
Yes.
Thanks,
Christian.
next prev parent reply other threads:[~2009-09-17 12:26 UTC|newest]
Thread overview: 15+ messages / expand[flat|nested] mbox.gz Atom feed top
2009-09-17 4:14 [PATCH v3 0/4] "git reset --merge" related improvements Christian Couder
2009-09-17 4:14 ` [PATCH v3 1/4] reset: add a few tests for "git reset --merge" Christian Couder
2009-09-17 4:14 ` [PATCH v3 2/4] reset: use "unpack_trees()" directly instead of "git read-tree" Christian Couder
2009-09-17 4:14 ` [PATCH v3 3/4] reset: add option "--merge-safe" to "git reset" Christian Couder
2009-09-17 5:15 ` Junio C Hamano
2009-09-17 6:38 ` Johannes Sixt
2009-09-17 7:07 ` Junio C Hamano
2009-09-17 7:24 ` Johannes Sixt
2009-09-17 12:12 ` Christian Couder
2009-09-17 13:05 ` Johannes Sixt
2009-09-17 13:25 ` Christian Couder
2009-09-17 20:43 ` Junio C Hamano
2009-09-17 12:25 ` Christian Couder [this message]
2009-09-17 21:04 ` Daniel Barkalow
2009-09-17 4:14 ` [PATCH v3 4/4] reset: add test cases for "--merge-safe" option 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
List information: http://vger.kernel.org/majordomo-info.html
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=c07716ae0909170525h21ab26f5y84b0fbce2192c69@mail.gmail.com \
--to=christian.couder@gmail.com \
--cc=Johannes.Schindelin@gmx.de \
--cc=barkalow@iabervon.org \
--cc=chriscool@tuxfamily.org \
--cc=git@vger.kernel.org \
--cc=gitster@pobox.com \
--cc=jnareb@gmail.com \
--cc=s-beyer@gmx.net \
--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.
Code repositories for project(s) associated with this public inbox
https://80x24.org/mirrors/git.git
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 read-only IMAP folder(s) and NNTP newsgroup(s).