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: Mon, 30 Jan 2006 14:25:08 +0100 [thread overview]
Message-ID: <43DE13B4.8090403@hogyros.de> (raw)
In-Reply-To: <Pine.LNX.4.63.0601301305100.20228@wbgn013.biozentrum.uni-wuerzburg.de>
[-- Attachment #1: Type: text/plain, Size: 3278 bytes --]
Hi,
Johannes Schindelin wrote:
[config as a registry]
> It is becoming sort of a registry: it contains metadata about the current
> repository, easily available to scripts and programs.
Provided you have a parser that can handle it.
> I beg to differ on your personal opinion on the grounds that the
> robustness comes from testing, not from diversity. I much prefer to have a
> well tested config mechanism to having dozens of differently formatted
> files with less-than-well tested parsers.
Indeed. But we already have a method for associating data values with
keys in a hierarchical namespace, and that one is pretty well tested. :-)
>>Why? It's perfectly acceptable to pull from an incomplete repo, as long as you
>>don't care about the old history.
> Right. But should that be the default? I don't think so. Therefore:
> disable it, and if the user is absolutely sure to do dumb things, she'll
> have to enable it explicitely.
What harm is done if I have an incomplete repository? It would probably
make more sense to emit a warning on clone and explain things if the
user tries to go to a version she doesn't have.
>>Hrm, I think there should also be a way to shrink a repo and "forget" old
>>history occasionally (obviously, use of that feature would be highly
>>discouraged).
> Yes. And you need information about how shallow it used to be. My
> suggestion was to store that information at a place specific to that
> repository (see above).
Indeed, but you are keeping this information in two places, namely the
grafts file and the config file. This is asking for trouble if they ever
get out of sync.
>>>How about refs/tags/start_shallow?
>>No, as that would imply that cloning from such a repo is disallowed.
> See above.
Well, I can however see the use case of a developer hosting an
incomplete repo on a free web service and another developer wanting to
merge her changes into her (complete) repo. You would have to
specialcase this tag in the fetch operation to avoid copying it over.
What's probably worse: You can only have a single cutoff point that way.
You probably want multiple in case you want to cut off at a place where
development happened in multiple branches that got subsequently merged
inside the window of objects you keep.
> The functionality of cutoff objects is included in grafts functionality,
> so why should we spend time on reimplementing a subset of features?
I would ask for the grafts parser to add "fake" grafts when it
encounters the "shallow" file. Otherwise, it would be hard to
distinguish between grafts the user made when doing interesting merges,
and grafts that were created to build a shallow repo, because you would
need some heuristics to figure out the latter from the former if you
want to have a function in your porcelain to "pull more/all objects".
> I beg your pardon, you want to edit this information *by hand*? Wow.
Yes. That is actually the reason I like git so much: I can repair it by
hand if something breaks, and this can be done with simple commands. I
can remove an object id from a file with "grep -v" or perl. I would need
to fire up an editor or hack a longer script if I wanted to fix
something inside a complex file that does multiple things.
Simon
[-- Attachment #2: OpenPGP digital signature --]
[-- Type: application/pgp-signature, Size: 307 bytes --]
next prev parent reply other threads:[~2006-01-30 13:25 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 [this message]
2006-01-30 19:25 ` Junio C Hamano
2006-01-31 11:28 ` Johannes Schindelin
2006-01-31 13:05 ` Simon Richter
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=43DE13B4.8090403@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).