Re: [PATCH/RFC] improve no-op push output

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

 



Jeff King <peff@xxxxxxxx> writes:

> I noticed the mention of the "Everything up-to-date" message in a nearby
> thread. This patch doesn't help with the case there, but it made me
> think about how vague that message is.
>
> -- >8 --
> When a push is a no-op because all refs are up-to-date, we print
> "Everything up-to-date". That is reasonable when push.default is
> "matching" (or when a wildcard refspec is given), because "Everything"
> pretty obviously means "everything you asked git to push".
>
> But when one of the single-ref push.default modes is used, the
> "Everything" is slightly misleading; we only tried to push one thing,
> and we should not give the user the impression that the remote is
> completely in sync with what is in their local repo.
>
> Instead, let's detect the case that we attempted to push a single ref,
> and if so, just show the verbose status table (which includes the
> up-to-date ref). We don't want to show it if we tried to push many refs,
> because it could be quite long (e.g., in the case of "matching").
>
> ---
> So before, running:
>
>   git init -q --bare parent &&
>   git clone -q parent child 2>/dev/null &&
>   cd child &&
>   echo one >one && git add one && git commit -q -m one &&
>   git branch other &&
>   git -c push.default=simple push
>
> would just print:
>
>   Everything up-to-date
>
> and now you get:
>
>   To /tmp/push-message/parent
>    = [up to date]      master -> master
>
> which is much more informative.

I think a more interesting case is to do this in the child:

	git checkout other
        git -c push.default=matching push

after the above sequence.  It will try to push master to master (and
the most important part is 'other' is not involved in this push at
all) and would give you the same updated message, which would make
it more clear that 'other' is not involved.  Although it by itself
is good, but unless you are paying attention, you may not catch that
your current branch is *not* listed in the output, so it might not
help people that much, even if they weren't on a detached HEAD.

Somebody who is unaware that she has been working on detached HEAD
is by definition very unlikely to notice that the 'master' in the
output is different from her current branch, as she is not paying
attention to what branch she is working on.

It might be a better approach to check if the set of pushed refs
include the current branch and rephrase the message only in that
case, perhaps

	Everything up-to-date (the current branch not pushed)

or something.
--
To unsubscribe from this list: send the line "unsubscribe git" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html


[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]