Linus Torvalds <torva...@linux-foundation.org> writes:
> And some maintainers end up using multiple repositories as branches
> (the old _original_ git model). Again, you can just use "git fetch +
> git reset", of course, but that's a bit unsafe. In contrast, doing
> "git pull --ff-only" is a safe convenient operation that does both the
> fetch and the update to whatever state.
> But you do need that "--ff-only" to avoid the merge.
OK. I guess it is legit (and semi-sensible) for downstream
contributors to "git pull --ff-only $upstream $release_tag_X" to
bring their long-running topic currently based on release X-1 up to
date with respect to release X. It probably makes more sense than
rebasing on top of release X, even though it makes a lot less sense
than merging their topics into release X.
As you said, pull of a tag that forbids fast-forward by default is
rather old development (I am kind of surprised that it was so old,
in v1.7.9), so it may be a bit difficult to transition.
ff = only
but pull.ff is quite global, and not good for intermediate level
maintainers who pull to integrate work of their downstream (for
which they do want the current "do not ff, record the tag in a merge
commit" behaviour) and also pull to catch up from their upstream
(which they want "ff-when-able"). They need to control between
ff=only and ff=when-able, depending on whom they are pulling from.
We may want per-remote equivalent for it, i.e. e.g.
ff=false ;# good default for collecting contributions
pullFF = only ;# good default for catching up
or something like that, perhaps?