I'll redo the patch, when we got a better text....
On 29/06/2021 18:35, Junio C Hamano wrote:
Martin<git@xxxxxxxxxx> writes:
Similar to `--create` except that if `<new-branch>` already
- exists, it will be reset to `<start-point>`. This is a
- convenient shortcut for:
+ exists, it will be reset to `<start-point>`.
+ This forces the branch to the new location.
I would have written "This forces the branch to point at a different
commit", as we do not have to use a fuzzy word "location" in this
context (is it a location in the directory structure in the working
tree? is it a location in the history dag? is it a location in
some other dimension?).
Ok.
Up to this point, it makes sense.
+ It also forces
+ any commit hold by the branch to be dropped, unless the
+ commit is also part of any other branch too. You may
+ therefore loose some of your data.
Aside from typo on "lose" (not "loose") and "held" (not "hold"),
this paragraph does not seem to add much value, at least to me, and
I suspect that it makes things even more confusing to new readers.
* Repointing the branch tip to a different commit is not limited to
"git switch -C". Any commands that allow you to move the branch
tip, like "git branch -f", "git checkout -B", "git push --force",
"git reset", share the same property and singling "switch -C" out
gives a false impression that all other commands are OK.
Well, yes. There may be more doc pages that could be updated. But that
should not stop us
from starting at some point.
I chose "git switch", because as I understand it, it was made in an
effort to make git
easier to use (by distinguishing between the clumped together commands
that were
all done with "git checkout")
In that sense, I see "git switch" as a particular important improvement
for people new
to git. Hence I felt that its documentation needed the extra bit of
attention.
* "to be dropped" is unnecessarily alarming (and not even correct).
"gc" will not reclaim while the reflog entries hold onto them.
"Some commits that used to be reachable from the original branch
tip may become unreachable." would not be an incorrect
description per-se (and would be a vast improvement over what is
in the posted patch), but it is dubious to stress the obvious,
especially given that the whole point of "branch -f" is to make
wrong commits disappear by pointing at corrected commits with the
branch tip.
My text may indeed have lacked clarity. I was trying to emphasize to
hard, that this
command's "force" enables 2 actions that may both not be wanted. Usually
if one applies
"force" to a command only one such action is expected, or at least I
would only expect the one.
The actions being, giving up the link to the commit that is the tip of
the branch; and
making commits unreachable. (for an expert in git tightly linked
together, but not for everyone)
Because you already need force, just to give up link to the tip, it is
not clear that there
might be additional unwanted actions that are enabled with the same "force".
(And the "unreachable commits" do not always happen, which makes it even
more dangerous, as a user may misjudge if it applies to his current case
/ I started
another mail on that too).
In general the direction of your proposed text is ok for me. But I
highly doubt that a user
who is new to git, will understand "reachable" without further context.
Maybe
" As a result some commits may be removed from the reachable part
of the repository and will be scheduled to be purged (see reflog
documentation)"
or
" As a result some commits may no longer be in a reachable part
of the repository and will be scheduled to be purged (see reflog
documentation)"
It is the same "reachable" that you used (the reflog can be reached, but
one usually does not
want the reflog to be the only place from where to access data still needed)
. It adds the word "removed" which most people (regardless of their git
skill,
or English skills) will recognize.
The intend is, that a new user should clearly take the message, those
commits will
"go away" (even if they "only" go to the reflog)
Because "switch -c <new-branch>", unlike "switch <existing-branch>"
would not have to touch the working tree at all, the only reason why
the user has to force the operation by using "-C" is to override the
safety offered by "-c" that protects existing branches from accidental
overwriting. Perhaps adding some description on "why" -c prevents
an existing branch from being overwritten would help reduce the
confusion better than an additional warning on "-C"?
Well, I am not convinced. The "danger" lies in the "-C" (which is why it
is a "force" command).
So it should be explained there.
It could be explained as "Unlike -c this does not protect your existing
branch".
But the entire point is, that the user must be aware what happens when a
branch is
removed (before it is recreated).
However the current documentation only mentions "if |<new-branch>|
already exists, it will be reset to ".
There is no explanation what "reset" means.
The doc does not even mention, the branch is ..."re-created" or "removed
and re-created".
Nor does it mention that the newly (re-)created branch is created
without any of the commits that it contained.
All of this, is very obvious to you and me. But it's not that obvious
for new users (who relay on the
docs more than anyone else).
Based on that, another approach to create clarity might be
Force creating a branch, means that an existing branch of the same
name is removed.
And that a new branch is created at the specified <start point>. The
new branch will not
necessarily have all the commits of that the existing branch used to
have.
It therefore also means that commits from the old existing branch
may be no longer reachable.
Here I think it can be left at "no longer reachable" as it already has
been indicated, that the commits may no longer be on that branch.
The "also means" underlines that this is a second potentially unwanted
effect of this command.