Re: [PATCH] branch: make -v useful

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

 



Jeff King wrote:
> On Mon, Jun 07, 2021 at 10:57:42AM -0500, Felipe Contreras wrote:
> > Jeff King wrote:
> > > On Sat, Jun 05, 2021 at 10:18:14PM +0200, Ævar Arnfjörð Bjarmason wrote:

> > > > As for the proposal, I don't use "branch -v" all that much much, so I
> > > > don't have strong knee-jerk feelings on it, but just considering it now
> > > > I'd think that the current default is a fundamentally better
> > > > approximation of what most users would like as a default.
> > > > 
> > > > I.e. I think it's fair to say that to the extent that most users have
> > > > topic branches they're part of some pull-request workflow where they're
> > > > always tracking the one upstream they always care about, usually
> > > > origin/master.
> > > 
> > > I'm in the same boat. I don't use "branch -v" either, but showing the
> > > upstream name wouldn't be at all helpful to me, since it they would all
> > > just be "origin/master".
> > 
> > But this patch is not for you, it's for the majority of git users.
> 
> In the quoted text above, Ævar mentioned that many users will have a
> pull-request workflow tracking one upstream.

A pull-request workflow tracks *two* upstreams.

Option 1: track the base:

  git checkout -b fix -t origin/master # like you, Ævar, and me

Option 2: track the branch you push to:

  git push --set-upstream github fix # like apparently most users

It's two different preferences for the same workflow.

> So no, I don't think it's just for me, but anybody with that workflow.
> 
> But of course i also mentioned other workflows, like...

No. The same workflow can have two very different upstreams.

> > > (This will vary based on workflow, but the
> > > other common workflow would probably just show "topic" being based on
> > > "origin/topic").
> > 
> > Based on what evidence?
> > 
> > As I showed in [1], all the top results when googling "upstream branch"
> > show the upstream branch being used in the opposite way: it's set to the
> > place you push to:
> > 
> >   git push --set-upstream @ github/my-pull-request
> 
> That's exactly what I was talking about in the quoted text above.  If
> you use --set-upstream, then your local "topic" will track something
> like "origin/topic".

But it's not origin/topic. I'm not talking about
`git branch --set-upstream-to`, I'm talking `git *push* --set-upstream`.

Git is a distributed VCS, most people don't have commit access to the
original repository, therefore they push to their personal repository
(e.g. github fork).

So their upstream is not origin/topic, it's github-personal-repo/topic.

> > But even if that was implemented, the whole point of this patch is about
> > what the default value of branch.verboseFormat should be.
> 
> I'm saying that I find your proposed value for that default to be
> useless, and I suspect many other users will, too.

Explain how.

If most people use `git push --set-upstream`, their upstream is most
definitely not origin/master (nor origin/topic).

Even git itself recommends setting the upstream to where they push to:

  fatal: The current branch fix has no upstream branch.
  To push the current branch and set the remote as upstream, use

      git push --set-upstream origin fix

So they will get a benefit from seeing the upstream in `git branch -v`.

Would they not?

> > Do I need to produce a list of the top 10 Google results of
> > "git branch -v" vs. "git branch -vv", to show that most people don't
> > find the output of -v useful?
> > 
> > Or what kind of evidence would satisfy you?
> 
> Don't bother on my account. I have generally found that going more than
> one round deep of discussion with you does not lead anywhere productive,
> and I don't intend to continue this thread.

If there's no evidence that will ever convince you otherwise, that means
you are not interested in actual real users, only in your idea of users.


For the people who are actually interested in what actual users do, I
ran a poll on reddit [1], and so far:

  15: The base branch (e.g. origin/master)
  15: The branch you push to (e.g. github/my-pull-request)

They are tied, 50% use the same upstream as you, 50% don't... For the
*same* workflow.

Cheers.

[1] https://www.reddit.com/r/git/comments/nuf3p5/where_do_you_point_your_upstream_branch_to/

-- 
Felipe Contreras



[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