git.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* Update local tracking refs when pushing- no way to disable
@ 2007-07-06  0:22 Dan McGee
  2007-07-06  1:17 ` Johannes Schindelin
                   ` (2 more replies)
  0 siblings, 3 replies; 12+ messages in thread
From: Dan McGee @ 2007-07-06  0:22 UTC (permalink / raw)
  To: git

In this commit:
b516968ff62ec153e008d033c153affd7ba9ddc6

I don't know if anyone else has the same way of working as I do, but I
tend to set the "remote.<name>.skipDefaultUpdate" property to true for
my publicly visible repository, just so I don't have duplicate branch
heads lying around in my local repository. Call this peculiar, but I
like it that way. However, git-push does not respect this property,
meaning I know have these branches whether I want them or not. In a
tool such as qgit or even 'git branch -a' output, it starts to get
awful cluttered.

I'm not terribly familiar with GIT internals, so I don't know that I
am the best to make a patch for this, but I'll take no response as a
answer that I should start coding something up. Please CC me on
emails, I'm not on the GIT mailing list.

-Dan

^ permalink raw reply	[flat|nested] 12+ messages in thread

* Re: Update local tracking refs when pushing- no way to disable
  2007-07-06  0:22 Update local tracking refs when pushing- no way to disable Dan McGee
@ 2007-07-06  1:17 ` Johannes Schindelin
  2007-07-06  1:31 ` Junio C Hamano
  2007-07-06  3:37 ` Daniel Barkalow
  2 siblings, 0 replies; 12+ messages in thread
From: Johannes Schindelin @ 2007-07-06  1:17 UTC (permalink / raw)
  To: Dan McGee; +Cc: git

Hi,

[on this list, it is considered polite to not cull the Cc list anyway]

On Thu, 5 Jul 2007, Dan McGee wrote:

> In this commit:
> b516968ff62ec153e008d033c153affd7ba9ddc6

You might be interested to look only at the changes to builtin-push.c. I 
have a hunch that you just need to disable setting the remote if 
"remote.<name>.skipDefaultUpdate" is set.

Of course, for that to work, you would also need to add a member variable 
to struct remote in remote.h, and handle it at the end of handle_config() 
in remote.c.

Then just use remote->skip_default_update in builtin-push.c, to guard 
around lines 90--93.

As for submitting, please read Documentation/SubmittingPatches first, it 
is not really long, and most of it is obvious.

Hth,
Dscho

^ permalink raw reply	[flat|nested] 12+ messages in thread

* Re: Update local tracking refs when pushing- no way to disable
  2007-07-06  0:22 Update local tracking refs when pushing- no way to disable Dan McGee
  2007-07-06  1:17 ` Johannes Schindelin
@ 2007-07-06  1:31 ` Junio C Hamano
  2007-07-06  3:37 ` Daniel Barkalow
  2 siblings, 0 replies; 12+ messages in thread
From: Junio C Hamano @ 2007-07-06  1:31 UTC (permalink / raw)
  To: Dan McGee; +Cc: git, Daniel Barkalow

"Dan McGee" <dpmcgee@gmail.com> writes:

> In this commit:
> b516968ff62ec153e008d033c153affd7ba9ddc6
>
> I don't know if anyone else has the same way of working as I do, but I
> tend to set the "remote.<name>.skipDefaultUpdate" property to true for
> my publicly visible repository, just so I don't have duplicate branch
> heads lying around in my local repository. Call this peculiar, but I
> like it that way. However, git-push does not respect this property,
> meaning I know have these branches whether I want them or not. In a
> tool such as qgit or even 'git branch -a' output, it starts to get
> awful cluttered.

Actually I do not think git-push nor git-fetch are related to
what that configuration variable tries to control at all.  The
variable controls what "git remote update" does.

Do you fetch from your 'publicly visible repository', and do you
use tracking branches for it when you do "git fetch" from there?

    $ git push my-public

is supposed to pretend that immediately after the push you did
"git fetch my-public" _if_and_only_if_ your "git fetch
my-public" would fetch the branches you pushed, and you have
configured to store them in .git/refs/remotes/my-public/
(i.e. your tracking branches).  So if you do not fetch from your
remote and do not have configuration to use tracking branches
when you fetch from there, and if you still see that your push
updates your tracking branches, then you found a bug.

But if you do have configuration to use tracking branches when
you fetch from there, that is a different story.  I do not think
there currently is a way to disable that "pretend we have
fetched back immediately" behaviour.  There could be valid
reasons that you may _want_ to keep your existing tracking
branches stale after a push, in which case we may want to make
it overridable, but at the time that change was accepted, nobody
had such a convincing use scenario.

^ permalink raw reply	[flat|nested] 12+ messages in thread

* Re: Update local tracking refs when pushing- no way to disable
  2007-07-06  0:22 Update local tracking refs when pushing- no way to disable Dan McGee
  2007-07-06  1:17 ` Johannes Schindelin
  2007-07-06  1:31 ` Junio C Hamano
@ 2007-07-06  3:37 ` Daniel Barkalow
  2007-07-06  8:26   ` Marco Costalba
                     ` (2 more replies)
  2 siblings, 3 replies; 12+ messages in thread
From: Daniel Barkalow @ 2007-07-06  3:37 UTC (permalink / raw)
  To: Dan McGee; +Cc: git

On Thu, 5 Jul 2007, Dan McGee wrote:

> In this commit:
> b516968ff62ec153e008d033c153affd7ba9ddc6
> 
> I don't know if anyone else has the same way of working as I do, but I
> tend to set the "remote.<name>.skipDefaultUpdate" property to true for
> my publicly visible repository, just so I don't have duplicate branch
> heads lying around in my local repository. Call this peculiar, but I
> like it that way. However, git-push does not respect this property,
> meaning I know have these branches whether I want them or not. In a
> tool such as qgit or even 'git branch -a' output, it starts to get
> awful cluttered.

What git-fetch and git-push care about is whether you have an entry 
"remote.<name>.fetch" with a colon and stuff on the right of it. If so, 
this is a pattern that is used to generate the duplicate branch heads that 
you don't want. git clone sets it up to a default pattern 
(refs/remotes/origin/*), and I don't think there's any way to make it not 
do that, but you can just reconfigure it afterwards if you don't like it.

I can't see where git-push would get the names to use if you don't have 
such an entry, and having the entry isn't useful if you actually don't 
want those refs. It's probably just a matter of deleting it, since it was 
probably created for you by some tool trying to be helpful.

(AFAICT, the only additional stuff that -a shows with git branch is the 
stuff that you're deleting; perhaps qgit should have an option to not show 
remotes, or not show them by default or only show them if what they point 
to isn't otherwise marked? Anyway, it shouldn't be necessary to avoid 
having this information just so that it isn't shown in interfaces you 
use.)

	-Daniel
*This .sig left intentionally blank*

^ permalink raw reply	[flat|nested] 12+ messages in thread

* Re: Update local tracking refs when pushing- no way to disable
  2007-07-06  3:37 ` Daniel Barkalow
@ 2007-07-06  8:26   ` Marco Costalba
  2007-07-06  8:42     ` Shawn O. Pearce
  2007-07-06 12:46   ` Johannes Schindelin
  2007-07-06 13:20   ` Dan McGee
  2 siblings, 1 reply; 12+ messages in thread
From: Marco Costalba @ 2007-07-06  8:26 UTC (permalink / raw)
  To: Daniel Barkalow; +Cc: Dan McGee, git

On 7/6/07, Daniel Barkalow <barkalow@iabervon.org> wrote:
>
> (AFAICT, the only additional stuff that -a shows with git branch is the
> stuff that you're deleting; perhaps qgit should have an option to not show
> remotes, or not show them by default or only show them if what they point
> to isn't otherwise marked? Anyway, it shouldn't be necessary to avoid
> having this information just so that it isn't shown in interfaces you
> use.)
>

Probably an option "show remote branches" from a popup context menu
(right click) is the more natural and predictable solution.

In case someone is interested, please confirm me, I will add that.

Marco

^ permalink raw reply	[flat|nested] 12+ messages in thread

* Re: Update local tracking refs when pushing- no way to disable
  2007-07-06  8:26   ` Marco Costalba
@ 2007-07-06  8:42     ` Shawn O. Pearce
  0 siblings, 0 replies; 12+ messages in thread
From: Shawn O. Pearce @ 2007-07-06  8:42 UTC (permalink / raw)
  To: Marco Costalba; +Cc: Daniel Barkalow, Dan McGee, git

Marco Costalba <mcostalba@gmail.com> wrote:
> On 7/6/07, Daniel Barkalow <barkalow@iabervon.org> wrote:
> >
> >(AFAICT, the only additional stuff that -a shows with git branch is the
> >stuff that you're deleting; perhaps qgit should have an option to not show
> >remotes, or not show them by default or only show them if what they point
> >to isn't otherwise marked? Anyway, it shouldn't be necessary to avoid
> >having this information just so that it isn't shown in interfaces you
> >use.)
> >
> 
> Probably an option "show remote branches" from a popup context menu
> (right click) is the more natural and predictable solution.

Recently I was faced with handling a repository that has over
200 local refs/heads and 200+ refs/remotes that the user might
be interested in working on.  Yea, its fun to look at in gitk.
It is not fun to run `git fetch` when on Cygwin.

Anyway, the git-gui `pu` branch now has new UI to handle these
sorts of cases rather nicely.  The revision selection mega-widget
that I recently wrote lets the user select which "class" of ref
(head, tracking branch, tag) they want and then filter them using
a substring glob filter.  The trick works very well to let the user
weed the list of 400+ possible refs down to just a couple that they
can pick from with the keyboard, or the mouse.

The UI will be in 0.8.0.  Which I'm hoping to go into an rc status
later this week.


Minor warning: currently the `pu` branch of git-gui probably
requires git 1.5.3-rc0 or later.  It doesn't test for it and just
assumes your git is new enough.  I do plan on fixing the couple of
spots that might matter to be conditional and fallback gracefully
if 1.5.3 isn't available.  Just haven't done it yet.  Those will
be fixed before they merge to `master`.

-- 
Shawn.

^ permalink raw reply	[flat|nested] 12+ messages in thread

* Re: Update local tracking refs when pushing- no way to disable
  2007-07-06  3:37 ` Daniel Barkalow
  2007-07-06  8:26   ` Marco Costalba
@ 2007-07-06 12:46   ` Johannes Schindelin
  2007-07-06 18:56     ` Daniel Barkalow
  2007-07-06 13:20   ` Dan McGee
  2 siblings, 1 reply; 12+ messages in thread
From: Johannes Schindelin @ 2007-07-06 12:46 UTC (permalink / raw)
  To: Daniel Barkalow; +Cc: Dan McGee, git

Hi,

On Thu, 5 Jul 2007, Daniel Barkalow wrote:

> What git-fetch and git-push care about is whether you have an entry 
> "remote.<name>.fetch" with a colon and stuff on the right of it. If so, 
> this is a pattern that is used to generate the duplicate branch heads 
> that you don't want. git clone sets it up to a default pattern 
> (refs/remotes/origin/*), and I don't think there's any way to make it 
> not do that, but you can just reconfigure it afterwards if you don't 
> like it.

Related, but not identical, is the problem illustrated in 
http://thread.gmane.org/gmane.comp.version-control.git/49888

IMHO there is a bug. IIUC git push first looks for common ref names on the 
local and remote side (yes, refs/remotes are excluded since v1.5.3-rc0~9, 
but the underlying problem is still there). Then it pushes them. But here, 
something seems to have gone wrong: refs/remotes/origin/HEAD is a symref. 
And the corresponding ref is updated. Should git-push not just _not_ 
update symrefs?

Ciao,
Dscho

^ permalink raw reply	[flat|nested] 12+ messages in thread

* Re: Update local tracking refs when pushing- no way to disable
  2007-07-06  3:37 ` Daniel Barkalow
  2007-07-06  8:26   ` Marco Costalba
  2007-07-06 12:46   ` Johannes Schindelin
@ 2007-07-06 13:20   ` Dan McGee
  2 siblings, 0 replies; 12+ messages in thread
From: Dan McGee @ 2007-07-06 13:20 UTC (permalink / raw)
  To: git

On 7/5/07, Daniel Barkalow <barkalow@iabervon.org> wrote:
> On Thu, 5 Jul 2007, Dan McGee wrote:
>
> > In this commit:
> > b516968ff62ec153e008d033c153affd7ba9ddc6
> >
> > I don't know if anyone else has the same way of working as I do, but I
> > tend to set the "remote.<name>.skipDefaultUpdate" property to true for
> > my publicly visible repository, just so I don't have duplicate branch
> > heads lying around in my local repository. Call this peculiar, but I
> > like it that way. However, git-push does not respect this property,
> > meaning I know have these branches whether I want them or not. In a
> > tool such as qgit or even 'git branch -a' output, it starts to get
> > awful cluttered.
>
> What git-fetch and git-push care about is whether you have an entry
> "remote.<name>.fetch" with a colon and stuff on the right of it. If so,
> this is a pattern that is used to generate the duplicate branch heads that
> you don't want. git clone sets it up to a default pattern
> (refs/remotes/origin/*), and I don't think there's any way to make it not
> do that, but you can just reconfigure it afterwards if you don't like it.

Wow, my bad here on this one. Didn't even think about the default config line:
[remote "toofishes.net"]
       url = toofishes.net:~/gitprojects/shoepolish.git/
       fetch = +refs/heads/*:refs/remotes/toofishes.net/*
       push = +refs/heads/*:refs/heads/*

Getting rid of that fetch line makes it work as intended. And not to
hijack my own thread, but did behavior change between 1.5.2.3 and
1.5.3 wrt non-subset pushes?

$ git push toofishes.net
error: remote 'refs/heads/alpm_list_speed' is not a strict subset of
local ref 'refs/heads/alpm_list_speed'. maybe you are not up-to-date
and need to pull first?
error: remote 'refs/heads/asciidoc' is not a strict subset of local
ref 'refs/heads/asciidoc'. maybe you are not up-to-date and need to
pull first?
error: remote 'refs/heads/color' is not a strict subset of local ref
'refs/heads/color'. maybe you are not up-to-date and need to pull
first?
error: remote 'refs/heads/permissions' is not a strict subset of local
ref 'refs/heads/permissions'. maybe you are not up-to-date and need to
pull first?
error: remote 'refs/heads/pkgname_check' is not a strict subset of
local ref 'refs/heads/pkgname_check'. maybe you are not up-to-date and
need to pull first?
updating 'refs/heads/working'
 from 59d9ccf48d84fd1e59f78cb4dcf428e53d1c6911
 to   6b7b9743181078aa7152daffdfc1eaeb46304c0f
Generating pack...
Done counting 0 objects.
Writing 0 objects...
Total 0 (delta 0), reused 0 (delta 0)
refs/heads/working: 59d9ccf48d84fd1e59f78cb4dcf428e53d1c6911 ->
6b7b9743181078aa7152daffdfc1eaeb46304c0f

I thought the '+' sign in the push refspec would supress these errors,
but it doesn't seem to. Running 'git push -f' works but that was never
necessary before after doing some rebasing of these branches.

-Dan

^ permalink raw reply	[flat|nested] 12+ messages in thread

* Re: Update local tracking refs when pushing- no way to disable
  2007-07-06 12:46   ` Johannes Schindelin
@ 2007-07-06 18:56     ` Daniel Barkalow
  2007-07-06 18:59       ` Johannes Schindelin
  0 siblings, 1 reply; 12+ messages in thread
From: Daniel Barkalow @ 2007-07-06 18:56 UTC (permalink / raw)
  To: Johannes Schindelin; +Cc: Dan McGee, git

On Fri, 6 Jul 2007, Johannes Schindelin wrote:

> Hi,
> 
> Related, but not identical, is the problem illustrated in 
> http://thread.gmane.org/gmane.comp.version-control.git/49888
> 
> IMHO there is a bug. IIUC git push first looks for common ref names on the 
> local and remote side (yes, refs/remotes are excluded since v1.5.3-rc0~9, 
> but the underlying problem is still there). Then it pushes them. But here, 
> something seems to have gone wrong: refs/remotes/origin/HEAD is a symref. 
> And the corresponding ref is updated. Should git-push not just _not_ 
> update symrefs?

I believe this actually have nothing to do with git-push; it's actually 
git-receive-pack and maybe git-send-pack. Probably git-receive-pack 
shouldn't list symrefs at all, or should somehow report them as links so 
that they can be compared as links. The only refs that git-push itself 
updates are tracking refs on the local side for refs on the remote side 
which were updated. In the report, the reporter had (obviously) not 
configured any local tracking refs for the remote's tracking refs.

Now, if there are symref heads on the remote (maybe somebody wants to have 
a "dominus" branch which is a symref to "master" for people who only speak 
Latin), and this was in tracking refs as a symref as well, and the user 
pushed to both (with the remote side somehow identifying that the same 
change is being made to both names, and that's okay), then the tracking 
refs would need this same logic as well. But that requires an 
unimplemented and unrequested feature, with fixes in a number of other 
places first, before it's even possible to have git-push need to worry 
about it.

	-Daniel
*This .sig left intentionally blank*

^ permalink raw reply	[flat|nested] 12+ messages in thread

* Re: Update local tracking refs when pushing- no way to disable
  2007-07-06 18:56     ` Daniel Barkalow
@ 2007-07-06 18:59       ` Johannes Schindelin
  2007-07-06 19:20         ` Daniel Barkalow
  0 siblings, 1 reply; 12+ messages in thread
From: Johannes Schindelin @ 2007-07-06 18:59 UTC (permalink / raw)
  To: Daniel Barkalow; +Cc: Dan McGee, git

Hi,

On Fri, 6 Jul 2007, Daniel Barkalow wrote:

> On Fri, 6 Jul 2007, Johannes Schindelin wrote:
> 
> > Related, but not identical, is the problem illustrated in 
> > http://thread.gmane.org/gmane.comp.version-control.git/49888
> > 
> > IMHO there is a bug. IIUC git push first looks for common ref names on 
> > the local and remote side (yes, refs/remotes are excluded since 
> > v1.5.3-rc0~9, but the underlying problem is still there). Then it 
> > pushes them. But here, something seems to have gone wrong: 
> > refs/remotes/origin/HEAD is a symref. And the corresponding ref is 
> > updated. Should git-push not just _not_ update symrefs?
> 
> I believe this actually have nothing to do with git-push; it's actually 
> git-receive-pack and maybe git-send-pack. Probably git-receive-pack 
> shouldn't list symrefs at all, or should somehow report them as links so 
> that they can be compared as links. The only refs that git-push itself 
> updates are tracking refs on the local side for refs on the remote side 
> which were updated. In the report, the reporter had (obviously) not 
> configured any local tracking refs for the remote's tracking refs.

Sorry, I think I did not make myself clear. The updates refs were _local_ 
refs. And they _were_ symrefs.

Ciao,
Dscho

^ permalink raw reply	[flat|nested] 12+ messages in thread

* Re: Update local tracking refs when pushing- no way to disable
  2007-07-06 18:59       ` Johannes Schindelin
@ 2007-07-06 19:20         ` Daniel Barkalow
  2007-07-06 19:46           ` Johannes Schindelin
  0 siblings, 1 reply; 12+ messages in thread
From: Daniel Barkalow @ 2007-07-06 19:20 UTC (permalink / raw)
  To: Johannes Schindelin; +Cc: Dan McGee, git

On Fri, 6 Jul 2007, Johannes Schindelin wrote:

> Hi,
> 
> On Fri, 6 Jul 2007, Daniel Barkalow wrote:
> 
> > On Fri, 6 Jul 2007, Johannes Schindelin wrote:
> > 
> > > Related, but not identical, is the problem illustrated in 
> > > http://thread.gmane.org/gmane.comp.version-control.git/49888
> > > 
> > > IMHO there is a bug. IIUC git push first looks for common ref names on 
> > > the local and remote side (yes, refs/remotes are excluded since 
> > > v1.5.3-rc0~9, but the underlying problem is still there). Then it 
> > > pushes them. But here, something seems to have gone wrong: 
> > > refs/remotes/origin/HEAD is a symref. And the corresponding ref is 
> > > updated. Should git-push not just _not_ update symrefs?
> > 
> > I believe this actually have nothing to do with git-push; it's actually 
> > git-receive-pack and maybe git-send-pack. Probably git-receive-pack 
> > shouldn't list symrefs at all, or should somehow report them as links so 
> > that they can be compared as links. The only refs that git-push itself 
> > updates are tracking refs on the local side for refs on the remote side 
> > which were updated. In the report, the reporter had (obviously) not 
> > configured any local tracking refs for the remote's tracking refs.
> 
> Sorry, I think I did not make myself clear. The updates refs were _local_ 
> refs. And they _were_ symrefs.

No, no local refs were updated. This would have given the message "Also 
local refs/remotes/origin/HEAD", which wasn't there. What was updated was 
tracking refs on the remote (which were created as local tracking refs 
when somebody was running git commands local to the repository which, for 
the failing command, was remote). The logic for updating local refs on a 
push was not used at all in this case, according to the output in the 
message you linked to.

	-Daniel
*This .sig left intentionally blank*

^ permalink raw reply	[flat|nested] 12+ messages in thread

* Re: Update local tracking refs when pushing- no way to disable
  2007-07-06 19:20         ` Daniel Barkalow
@ 2007-07-06 19:46           ` Johannes Schindelin
  0 siblings, 0 replies; 12+ messages in thread
From: Johannes Schindelin @ 2007-07-06 19:46 UTC (permalink / raw)
  To: Daniel Barkalow; +Cc: Dan McGee, git

Hi,

On Fri, 6 Jul 2007, Daniel Barkalow wrote:

> On Fri, 6 Jul 2007, Johannes Schindelin wrote:
> 
> > On Fri, 6 Jul 2007, Daniel Barkalow wrote:
> > 
> > > On Fri, 6 Jul 2007, Johannes Schindelin wrote:
> > > 
> > > > Related, but not identical, is the problem illustrated in 
> > > > http://thread.gmane.org/gmane.comp.version-control.git/49888
> > > > 
> > > > IMHO there is a bug. IIUC git push first looks for common ref 
> > > > names on the local and remote side (yes, refs/remotes are excluded 
> > > > since v1.5.3-rc0~9, but the underlying problem is still there). 
> > > > Then it pushes them. But here, something seems to have gone wrong: 
> > > > refs/remotes/origin/HEAD is a symref. And the corresponding ref is 
> > > > updated. Should git-push not just _not_ update symrefs?
> > > 
> > > I believe this actually have nothing to do with git-push; it's 
> > > actually git-receive-pack and maybe git-send-pack. Probably 
> > > git-receive-pack shouldn't list symrefs at all, or should somehow 
> > > report them as links so that they can be compared as links. The only 
> > > refs that git-push itself updates are tracking refs on the local 
> > > side for refs on the remote side which were updated. In the report, 
> > > the reporter had (obviously) not configured any local tracking refs 
> > > for the remote's tracking refs.
> > 
> > Sorry, I think I did not make myself clear. The updates refs were 
> > _local_ refs. And they _were_ symrefs.
> 
> No, no local refs were updated. This would have given the message "Also 
> local refs/remotes/origin/HEAD", which wasn't there. What was updated 
> was tracking refs on the remote (which were created as local tracking 
> refs when somebody was running git commands local to the repository 
> which, for the failing command, was remote). The logic for updating 
> local refs on a push was not used at all in this case, according to the 
> output in the message you linked to.

Okay, I misunderstood, then.

Sorry for the noise,
Dscho

^ permalink raw reply	[flat|nested] 12+ messages in thread

end of thread, other threads:[~2007-07-06 19:53 UTC | newest]

Thread overview: 12+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2007-07-06  0:22 Update local tracking refs when pushing- no way to disable Dan McGee
2007-07-06  1:17 ` Johannes Schindelin
2007-07-06  1:31 ` Junio C Hamano
2007-07-06  3:37 ` Daniel Barkalow
2007-07-06  8:26   ` Marco Costalba
2007-07-06  8:42     ` Shawn O. Pearce
2007-07-06 12:46   ` Johannes Schindelin
2007-07-06 18:56     ` Daniel Barkalow
2007-07-06 18:59       ` Johannes Schindelin
2007-07-06 19:20         ` Daniel Barkalow
2007-07-06 19:46           ` Johannes Schindelin
2007-07-06 13:20   ` Dan McGee

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).