On Mon, Dec 7, 2020 at 1:26 AM Junio C Hamano <gitster@xxxxxxxxx> wrote: > Elijah Newren <newren@xxxxxxxxx> writes: > >> Do you think the crew should disregard the passenger's volition and > >> force him to pay attention to the safety demonstration? > > An example that is irrelevant. Passengers who sit on the aisle side > and clutter the floor with their luggages can pose public hazard, > and it is quite sensible for crews to remove them from the plane. That's a completely different example that mixes policy with regulations. Apples and oranges. > A team member who runs "pull --[no-]rebase" pushes the result, which > may be a new history in a wrong shape, back to the shared repository > probably falls into a different category. ... Or perhaps in the > same public hazard category? Yes, but if it's a public hazard or not is up to the maintainers of specific projects. Some projects are perfectly fine with those merges. It's the maintainer of the project that should decide what is the best policy for the project, and instruct his/her contributors. It's not up for individuals to decide what is a public hazard, and it's not up to Git either. Similarly; passengers can't decide what raises to the level of public hazzard, but neither can a flight attendant. > > Useful link there. Based on his comments, we may want to make > > --ff-only, --merge, and --rebase all be mutually exclusive and result > > in an error message if more than one is specified at the command line. > > I hope "his comment" does not refer to what I said. Redefining the > semantics of --ff-only (but not --ff=no and friends) to make it > mutually incompatible with merge/rebase was what Felipe wanted to > do, not me. That's not true. What I want is to introduce a "pull.mode=ff-only", not change the semantics of --ff-only. What I have been saying is that you can't make --ff-only the default without changing its semantics. But since the patch series that introduced such pull.mode [1] was completely ignored, I decided to take a shot at making --ff-only work. You said [2]: > > What we want to see can be done without such backward incompatible > > changes, e.g. declaring the combination of "--ff-only" and > > "--[no-]rebase" incompatible and/or the last one wins, I would say, and > > I suspect Alex's RFC was an attempt to make the first step in that > > direction. But in all my attempts the desired result cannot be done without backwards incompatible changes. I'm just the messenger. To be crystal clear: I don't want to change the semantics of --ff-only; I want to introduce a new "pull.mode=ff-only". > FWIW, I see the general direction as > > - When the history you are pulling is not a descendant of what you > have on your current branch, you must show your preference > between merging their history into yours or rebasing your history > onto theirs. Agreed. > - In such a case, we error out, with an error message telling them > that they must tell us which one they want in this invocation > (e.g. with "--rebase" or "--no-rebase"). We further tell them > that pull.rebase can be used to record their preference, if they > almost always use the same. Not quite. See below. > Side note: I earlier said "see below" to refer to this. I > think the message should offer what they can do right now > with command line option first, and then give an option to > configure. IOW, the message quoted in the beginning of this > response gives information in a wrong order. Also, > "discouraged" is misleading, isn't it? When we give this > message, we refuse to proceed until the user specifies. That's why I keep pointing out the end goal. In the end it's not one message, it's *two*: You can see my suggestion for both messages in my patch series for pull.mode [1]. When the user has specified "pull.mode=ff-only", the command dies with: The pull was not fast-forward, please either merge or rebase. When the user has not specified any mode (by default), the command would output a warning: The pull was not fast-forward, in the future you will have to choose a merge, or a rebase. To squelch this message and maintain the current behavior, use: git config --global pull.mode merge To squelch this message and adopt the new behavior now, use: git config --global push.mode ff-only Falling back to old style for now (merge). Read 'git pull --help' for more information. But in order to reach that point we first need to decide what will be the default mode, and how it will be configured (--ff-only or "pull.mode=ff-only"). In the meantime this particular series is not committing for any particular decision, and thus it's changing the warning message for the *current* situation in which the command does not fail, but only shows a warning. So today it's merely discouraged. This particular patch is pretty far from the end goal. It's just patch #2 of part 1. > Another thing to consider is that pull.ff=only (and > --ff-only) may be wrong choice to offer in the error message > quoted above, if one of the objectives is to reduce the > "annoying" message that tells the user that they must > choose. By definition, we do not give the message when our > side do not have our own development, so "I could run 'pull > --ff-only'" is a unusable knowledge to those who see the > message and want to get out of the situation. Those commands will squelch the warning, but won't change the underlying nature of the warning, which is that the user must choose to either merge or rebase. The temporary warning will disappear, but the permanent error message will not: The pull was not fast-forward, please either merge or rebase. > - But when the history being pulled is a descendant of the current > branch, and the user does not give us preference between merge > and rebase (either from the command line or with configuration), > there is no need to give such an error message---if you do not > have your own development, we can just fast-forward the current > branch to what we fetched from the other side. This does not > happen with the current system, which is what we want to fix. It's not an error message, it's a warning. But yes. > - Also when the history from the other side is a descedant and the > user has preference, either to rebase or to merge, either from > the command line or with configuration, we can fast-forward the > current branch to their tip, but there are wrinkles: > > . when --ff=no is given and the choice is to merge (not rebase), > we must create an extra merge commit. --ff receives no arguments, it's --no-ff. Yes. > . when the choice is to rebase, by definition, rebasing what you > have on top of theirs in this case is the same as fast-forwarding > the current branch to theirs, because "what you have" is an > empty set. Agreed. > . I am not sure how "pull --rebase --ff=no" should interact if we > don't have our own development. Rebasing our work on top of > theirs is philosophically incompatible with marking where the > side branch begins and ends with an extra commit, so it either > should be rejected when the command line and configuration is > parsed (i.e. regardless of the shape of the history we have at > hand), or --ff=no gets silently ignored when --rebase is given. > I haven't thought this one through. I thought of this instance as well. In my opinion such combination should fail. But it doesn't actually affect anything. Just to put this series in context: it's only part 1; it does not introduce pull.mode, and it doesn't make --ff-only the default. There's one patch prefixed with "tentative" that changes the semantics of --ff-only to see how it could look like when making it the default, but in no way am I proposing that patch to be merged. The series is entirely about improving the current situation, nothing contentious. In part 2 I will introduce pull.mode, which is the solution I propose, and that would be basically rebasing [1] on top of this series (hopefully). I would have hoped that by this point it would have been clear why --ff-only is not the way forward. But oh well, we'll see what happens. Cheers. [1] https://lore.kernel.org/git/20201125032938.786393-1-felipe.contreras@xxxxxxxxx/ [2] https://lore.kernel.org/git/xmqqpn3qfhps.fsf@xxxxxxxxxxxxxxxxxxxxxx -- Felipe Contreras