From: "Kristian Høgsberg" <krh@redhat.com>
To: Marco Costalba <mcostalba@gmail.com>
Cc: Junio C Hamano <gitster@pobox.com>,
Git Mailing List <git@vger.kernel.org>
Subject: Re: [PATCH 4/5] Use new compress helpers in http-push.c
Date: Fri, 11 Jan 2008 10:39:41 -0500 [thread overview]
Message-ID: <1200065981.18570.8.camel@gaara.boston.redhat.com> (raw)
In-Reply-To: <e5bfff550801102339o757eea62h40b5e00cd904f7e1@mail.gmail.com>
On Fri, 2008-01-11 at 08:39 +0100, Marco Costalba wrote:
> A multistep compress is required here, so
> we need the full arsenal of compress helpers.
>
> Signed-off-by: Marco Costalba <mcostalba@gmail.com>
> ---
> http-push.c | 22 ++++++++--------------
> 1 files changed, 8 insertions(+), 14 deletions(-)
>
> diff --git a/http-push.c b/http-push.c
> index 55d0c94..b7fe57f 100644
> --- a/http-push.c
> +++ b/http-push.c
> @@ -1,5 +1,6 @@
> #include "cache.h"
> #include "commit.h"
> +#include "compress.h"
> #include "pack.h"
> #include "tag.h"
> #include "blob.h"
> @@ -491,31 +492,24 @@ static void start_put(struct transfer_request
> hdrlen = sprintf(hdr, "%s %lu", typename(type), len) + 1;
>
> /* Set it up */
> - memset(&stream, 0, sizeof(stream));
> - deflateInit(&stream, zlib_compression_level);
> - size = deflateBound(&stream, len + hdrlen);
> + size = compress_alloc(&stream, zlib_compression_level, len + hdrlen);
> strbuf_init(&request->buffer.buf, size);
> request->buffer.posn = 0;
>
> /* Compress it */
> - stream.next_out = (unsigned char *)request->buffer.buf.buf;
> - stream.avail_out = size;
> + compress_start(&stream, (void *)hdr, hdrlen,
> + (unsigned char *)request->buffer.buf.buf, size);
>
> /* First header.. */
> - stream.next_in = (void *)hdr;
> - stream.avail_in = hdrlen;
> - while (deflate(&stream, 0) == Z_OK)
> - /* nothing */;
> + compress_next(&stream, Z_NO_FLUSH);
How about moving next_in and avail_in to be args of compress_next() so
the user doesn't have to deal with the z_stream object at all? For
example:
compress_next(&stream, hdr, hdrlen, Z_NO_FLUSH);
and of course remove them from the compress_start() function.
> /* Then the data itself.. */
> stream.next_in = unpacked;
> stream.avail_in = len;
> - while (deflate(&stream, Z_FINISH) == Z_OK)
> - /* nothing */;
> - deflateEnd(&stream);
> - free(unpacked);
> + compress_next(&stream, Z_FINISH);
This whole chunk just becomes
compress_next(&stream, unpacked, len, Z_FINISH);
cheers,
Kristian
prev parent reply other threads:[~2008-01-11 15:40 UTC|newest]
Thread overview: 2+ messages / expand[flat|nested] mbox.gz Atom feed top
2008-01-11 7:39 [PATCH 4/5] Use new compress helpers in http-push.c Marco Costalba
2008-01-11 15:39 ` Kristian Høgsberg [this message]
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=1200065981.18570.8.camel@gaara.boston.redhat.com \
--to=krh@redhat.com \
--cc=git@vger.kernel.org \
--cc=gitster@pobox.com \
--cc=mcostalba@gmail.com \
/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).