From: Andreas Gruenbacher <agruen@suse.de>
To: Michael J Gruber <git@drmicha.warpmail.net>
Cc: git@vger.kernel.org
Subject: Re: [PATCH 2/3] Different views on a repository
Date: Thu, 25 Feb 2010 15:35:03 +0100 [thread overview]
Message-ID: <201002251535.03334.agruen@suse.de> (raw)
In-Reply-To: <4B866D60.6040306@drmicha.warpmail.net>
On Thursday 25 February 2010 13:30:24 Michael J Gruber wrote:
> Andreas Gruenbacher venit, vidit, dixit 25.02.2010 10:25:
> > On Thursday 25 February 2010 10:01:43 Michael J Gruber wrote:
> >> Andreas Gruenbacher venit, vidit, dixit 24.02.2010 16:57:
> >>> Add --view options in upload-pack and receive-pack so that a repository
> >>> on the server side can be made to look like several independent
> >>> repositories on the client side.
> >>>
> >>> This is implemented by transforming ref names: for example, with
> >>> --view=one/, refs/heads/one/master on the server will look like
> >>> refs/heads/master to the client, refs/tags/one/v1 will look like
> >>> refs/tags/v1, etc.
> >>>
> >>> This allows to transparently share repositories on the server which
> >>> have a lot of objects in common without complicating things for the
> >>> client, and without breaking garbage collection.
> >>
> >> Just from this description, I can't see why the same can't be done with
> >> appropriate refspecs. (A helper for doing that would be more welcome, of
> >> course.)
> >
> > You mean on the client side? The problem then is that a simple "git
> > clone" would not do the right thing anymore; you would still expose
> > server-side implementation details to clients. Clients shouldn't have to
> > bother with this added complexity. (They might not even have access to
> > some of the views.) When you do the mapping server-side, you can split or
> > merge repositories as needed without the clients even noticing.
>
> But the client has to request a specific view, doesn't it?
No, it's a server side thing. The git commands affected are upload-pack and
receice-pack, and those run on the remote end of a fetch. For example, the
client would ask the server for repository /foo/one or /foo/two, and the
server would map that to different views of /bar/shared: when the client asks
the server to run "git-upload-pack /foo/one", the server runs "git-upload-pack
--view=one/ /bar/shared" instead.
This is relatively easy to set up over ssh using a simple script; for direct
git access, a small wrapper daemon would be needed. I'm not sure how this
could be hacked into http access, but it doesn't seem all that hard, either.
> I just can't help the impression that this is a use case which does not
> need a new feature, at least not upload/receive-pack wise.
Still, even with the additional explanation above?
> It's more a matter of ensuring that all clients use a specific configuration
> (which you would have to with your patch as well, AFAICT), and this more
> general issue is creeping up again and again, with no agreeable solution
> so far.
Well that's another problem which we indeed also have for enabling things like
local consistency checks and merge drivers. I don't have a good answer here :)
Thanks,
Andreas
next prev parent reply other threads:[~2010-02-25 14:36 UTC|newest]
Thread overview: 16+ messages / expand[flat|nested] mbox.gz Atom feed top
2010-02-24 16:41 [RFC][PATCH 0/3] Different views on a repository Andreas Gruenbacher
2010-02-24 15:33 ` [PATCH 1/3] receive-pack: Two small code cleanups Andreas Gruenbacher
2010-02-24 15:57 ` [PATCH 2/3] Different views on a repository Andreas Gruenbacher
2010-02-24 16:14 ` [PATCH 3/3] Different views on a repository: HEAD mapping Andreas Gruenbacher
2010-02-24 17:42 ` [PATCH 2/3] Different views on a repository Shawn O. Pearce
2010-02-25 9:01 ` Michael J Gruber
2010-02-25 9:25 ` Andreas Gruenbacher
2010-02-25 12:30 ` Michael J Gruber
2010-02-25 14:35 ` Andreas Gruenbacher [this message]
2010-02-25 17:28 ` Junio C Hamano
2010-02-26 0:45 ` Andreas Gruenbacher
2010-02-26 21:35 ` Andreas Gruenbacher
2010-02-24 17:29 ` [PATCH 1/3] receive-pack: Two small code cleanups Shawn O. Pearce
2010-02-25 20:13 ` [RFC][PATCH 0/3] Different views on a repository James Pickens
2010-02-26 4:30 ` Adam Brewster
[not found] ` <c376da901002252012s507a6921q922e606bdce4b4fa@mail.gmail.com>
2010-02-26 12:01 ` Andreas Gruenbacher
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=201002251535.03334.agruen@suse.de \
--to=agruen@suse.de \
--cc=git@drmicha.warpmail.net \
--cc=git@vger.kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
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).