From: Simon Richter <Simon.Richter@hogyros.de>
To: Johannes Schindelin <Johannes.Schindelin@gmx.de>
Cc: Junio C Hamano <junkio@cox.net>, git@vger.kernel.org
Subject: Re: [RFC] shallow clone
Date: Tue, 31 Jan 2006 14:05:16 +0100 [thread overview]
Message-ID: <43DF608C.1060201@hogyros.de> (raw)
In-Reply-To: <Pine.LNX.4.63.0601311127490.25248@wbgn013.biozentrum.uni-wuerzburg.de>
[-- Attachment #1: Type: text/plain, Size: 2733 bytes --]
Hi,
Johannes Schindelin wrote:
>>If the downstream person wants to have a shallow history of post
>>X.org X server core to further hack on it, I do not think of a
>>reason why we would want to refuse her from cloning a repository
>>of a fellow developer who has already done such a shallow copy.
> Okay. But in their case, they'll probably do what was done with Linux:
> start afresh. If you want to have the old history, you can import it and
> merge it via a graft.
Well, in the Linux case the problem was not knowing what the SHA1 sum of
the entire Linux history was. In the shallow repo case we know it, so
there is no point in throwing away that information.
>>If such a clone is done without telling the downstream that the
>>result is a shallow one, it is "dumb". I would agree it should
>>not be done.
> That was my point. As long as you don't make sure the client handles the
> shallow upstream gracefully, it is dangerous. At the moment, there are too
> many code parts relying on the completeness of the repository (local and
> remote).
Well, the important thing would be that commands that can work (a merge
only needs to find the most recent common ancestor, etc) do work, and
commands that cannot ("log") emit sensible diagnostics.
> Just imagine this: Alice starts a project, Bob makes a shallow copy from
> it when Alice just reverted an experimental feature. Then, Alice decides
> the experimental feature was not bad at all and reverts the revert. Bob
> pulls from Alice: Alice's upload-pack assumes Bob already has the original
> files (now re-reverted), and Bob ends up with a broken repository.
I know far too little about the internal workings for that, but I'd
assume that in this case Bob's copy starts at the commit that was never
in question (and he never saw the reverted commit), and Alice's contains
a commit on top of that. That one should work. But the other way 'round
is problematic, when Bob starts with a commit that has been reverted in
Alice's repository. The solution is for Bob to ask Alice's repo for the
common ancestor of his shallow base and Alice's HEAD. Alice's repo can,
however, fail to deliver these if there has been a purge since, in that
case, stuff needs to be merged by hand (but you already have a problem
if someone clones your repo before you revert changes, so no regression
here).
> If you now rely on the grafts file to determine what was a cutoff, you may
> well end up with bogus cutoffs.
Exactly that was my concern earlier; my database design gut feeling
tells me that information duplication is not good either, hence my
suggestion to split off these grafts into a separate file in order to
mark them as cutoff points.
Simon
[-- Attachment #2: OpenPGP digital signature --]
[-- Type: application/pgp-signature, Size: 307 bytes --]
next prev parent reply other threads:[~2006-01-31 13:05 UTC|newest]
Thread overview: 30+ messages / expand[flat|nested] mbox.gz Atom feed top
2006-01-30 7:18 [RFC] shallow clone Junio C Hamano
2006-01-30 11:39 ` Johannes Schindelin
2006-01-30 11:58 ` Simon Richter
2006-01-30 12:13 ` Johannes Schindelin
2006-01-30 13:25 ` Simon Richter
2006-01-30 19:25 ` Junio C Hamano
2006-01-31 11:28 ` Johannes Schindelin
2006-01-31 13:05 ` Simon Richter [this message]
2006-01-31 13:31 ` Johannes Schindelin
2006-01-31 14:23 ` Simon Richter
2006-01-30 19:25 ` Junio C Hamano
2006-01-31 8:37 ` Franck
2006-01-31 8:51 ` Junio C Hamano
2006-01-31 11:11 ` Franck
2006-01-30 18:46 ` Junio C Hamano
2006-01-31 11:02 ` [PATCH] Shallow clone: low level machinery Junio C Hamano
2006-01-31 13:58 ` Johannes Schindelin
2006-01-31 17:49 ` Junio C Hamano
2006-01-31 18:06 ` Johannes Schindelin
2006-01-31 18:22 ` Junio C Hamano
2006-02-01 14:33 ` Johannes Schindelin
2006-02-01 20:27 ` Junio C Hamano
2006-02-02 0:48 ` Johannes Schindelin
2006-02-02 1:17 ` Junio C Hamano
2006-02-02 18:44 ` Johannes Schindelin
2006-02-02 19:31 ` Junio C Hamano
2006-01-31 14:20 ` [RFC] shallow clone Johannes Schindelin
2006-01-31 20:59 ` Junio C Hamano
2006-02-01 14:47 ` Johannes Schindelin
[not found] ` <43DF1F1D.1060704@innova-card.com>
2006-01-31 9:00 ` Franck
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=43DF608C.1060201@hogyros.de \
--to=simon.richter@hogyros.de \
--cc=Johannes.Schindelin@gmx.de \
--cc=git@vger.kernel.org \
--cc=junkio@cox.net \
/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).