Re: PATCH: improve git switch documentation

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



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.





[Index of Archives]     [Linux Kernel Development]     [Gcc Help]     [IETF Annouce]     [DCCP]     [Netdev]     [Networking]     [Security]     [V4L]     [Bugtraq]     [Yosemite]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux SCSI]     [Fedora Users]

  Powered by Linux