From: Junio C Hamano <junkio@cox.net>
To: "Dana How" <danahow@gmail.com>
Cc: "Junio C Hamano" <junkio@cox.net>, git@vger.kernel.org
Subject: Re: [PATCH 10/13] update delta handling in write_object() for --pack-limit
Date: Thu, 05 Apr 2007 16:18:21 -0700 [thread overview]
Message-ID: <7v3b3emmv6.fsf@assigned-by-dhcp.cox.net> (raw)
In-Reply-To: <56b7f5510704051538na4393d7k5e51ed2a511cc86e@mail.gmail.com> (Dana How's message of "Thu, 5 Apr 2007 15:38:22 -0700")
"Dana How" <danahow@gmail.com> writes:
> Subject: [PATCH 10/13] update delta handling in write_object() for --pack-limit
>
> ---
> builtin-pack-objects.c | 6 +++++-
> 1 files changed, 5 insertions(+), 1 deletions(-)
>
> diff --git a/builtin-pack-objects.c b/builtin-pack-objects.c
> index ccc2d15..a243eed 100644
> --- a/builtin-pack-objects.c
> +++ b/builtin-pack-objects.c
> @@ -419,13 +419,17 @@ static off_t write_object(struct sha1file *f,
> }
>
> if (!to_reuse) {
> + int usable_delta = !entry->delta ? 0 :
> + !offset_limit ? 1 :
> + entry->delta->no_write ? 0 :
> + entry->delta->offset ? 1 : 0;
> buf = read_sha1_file(entry->sha1, &type, &size);
> if (!buf)
> die("unable to read %s", sha1_to_hex(entry->sha1));
> if (size != entry->size)
> die("object %s size inconsistency (%lu vs %lu)",
> sha1_to_hex(entry->sha1), size, entry->size);
> - if (entry->delta) {
> + if (usable_delta) {
> buf = delta_against(buf, size, entry);
> size = entry->delta_size;
> obj_type = (allow_ofs_delta && entry->delta->offset) ?
This really needs explanation on *why*, at least in the commit
log, and perhaps also in the code as comment.
Here is my attempt to understand that logic (please make
necessary corrections).
(1) When there is no delta base found by the earlier
find_deltas()/try_delta() loop, obviously we cannot write
deltified so we write plain.
(2) Otherwise if we are not offset limited, then we keep the
old way of using that delta base.
(3) If the delta base is not in this pack (because of
offset-limit chomping the pack into two or more), then we
cannot use it as the base.
(4) If the delta has already been written, we can use it as the
base for this object, but otherwise we cannot.
(3) makes me wonder if we can still allow it in the thin-pack
case by just loosening the condition here.
Also I need explanation to understand why (4) is needed --
doesn't write_one() always write base object out before writing
a deltified object that depends on it?
next prev parent reply other threads:[~2007-04-05 23:18 UTC|newest]
Thread overview: 4+ messages / expand[flat|nested] mbox.gz Atom feed top
2007-04-05 22:38 [PATCH 10/13] update delta handling in write_object() for --pack-limit Dana How
2007-04-05 23:18 ` Junio C Hamano [this message]
2007-04-05 23:41 ` Dana How
2007-04-06 0:43 ` Nicolas Pitre
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=7v3b3emmv6.fsf@assigned-by-dhcp.cox.net \
--to=junkio@cox.net \
--cc=danahow@gmail.com \
--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).