Jeff King <p...@peff.net> writes:

> ... Knowing what each state _means_
> and what operations are meaningful to perform is much trickier (e.g., if
> we are in a rebase, you probably do not want to start a new rebase. But
> is it wrong to cherry-pick?).
>
> It would be nice if we could find a way to generalize in-progress
> operations and what they mean for starting new operations, but that is
> a much harder problem (if it is even possible at all).

Very good points. Thinking aloud, to see if we can start from a few
rules of thumb.

You can be "in the middle" for two largely different reasons.

One is that the command inherently wants to give control back to
you.  Think of a case where you said "exec false" in the "rebase -i"
insn sheet, or "bisect" checked out a version for you to try.

The other is that the command wanted to continue in the ideal world,
but couldn't and stopped asking for your help.  Think of a case
where "am" stopped due to corrupt patch, "cherry-pick A..B" or
"revert" stopped due to conflicts.

In the former case, depending on the nature of the command, what are
sensible things you can do are very different (during "bisect" you
would typically not want to do anything that causes a commit
created.  During "rebase -i" you may want to run any command that
creates a commit, to insert a new one into the series).  But a good
rule of thumb would be "If I should be able to edit the working tree
file, I should also be able to do "cherry-pick --no-commit", "merge
--no-commit", "apply", etc." "If I should be able to manually
commit, I should also be able to "cherry-pick", "merge", etc.

In the latter, the _only_ reason you are given control back is to
help the interrupted operation.  So "cherry-pick --no-commit" or
"apply" in lieu of editing files manually in order to fix conflicts
should be allowed, but a random "git merge" (without --no-commit)
would not be.

So after thinking aloud for a while, I very much agree with you that
you cannot say "X is allowed but not Y" in many situations.

One thing we can say for sure is that in a middle of a multi-step
operation (e.g. rebase, range pick) is stopped for either one of the
two reasons, you cannot do another multi-step operation.  This is
not fundamental but a consequence of how the sequencing machinery is
implemented.  But other than that, it really is case-by-case and not
even command-by-command.
--
To unsubscribe from this list: send the line "unsubscribe git" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to