diff options
author | Patrick Latifi <pat@cvs.openbsd.org> | 2006-05-29 17:10:58 +0000 |
---|---|---|
committer | Patrick Latifi <pat@cvs.openbsd.org> | 2006-05-29 17:10:58 +0000 |
commit | e3327ac00759f19adfcdb42261ba471fc32b4e93 (patch) | |
tree | 1920eef55c4039391a9b9ebd3b42be88ad27103b /usr.bin/cvs/compress.c | |
parent | 5786ac2dc222f4a4b3ebfe563d1cd07e6ec9ebd6 (diff) |
Factor out common code for zlib's inflate and deflate operations; ok joris@ xsa@
Diffstat (limited to 'usr.bin/cvs/compress.c')
-rw-r--r-- | usr.bin/cvs/compress.c | 80 |
1 files changed, 44 insertions, 36 deletions
diff --git a/usr.bin/cvs/compress.c b/usr.bin/cvs/compress.c index db2f6882163..615b8f4a693 100644 --- a/usr.bin/cvs/compress.c +++ b/usr.bin/cvs/compress.c @@ -1,5 +1,6 @@ -/* $OpenBSD: compress.c,v 1.4 2006/04/14 02:45:35 deraadt Exp $ */ +/* $OpenBSD: compress.c,v 1.5 2006/05/29 17:10:57 pat Exp $ */ /* + * Copyright (c) 2006 Patrick Latifi <pat@openbsd.org> * Copyright (c) 2005 Jean-Francois Brousseau <jfb@openbsd.org> * All rights reserved. * @@ -38,6 +39,14 @@ struct cvs_zlib_ctx { z_stream z_destrm; }; +struct zlib_ioctx { + z_stream *stream; + int (*reset)(z_stream *); + int (*io)(z_stream *, int); + int ioflags; +}; + +static int cvs_zlib_io(struct zlib_ioctx *, BUF *, u_char *, size_t); /* * cvs_zlib_newctx() @@ -99,32 +108,14 @@ cvs_zlib_free(CVSZCTX *ctx) int cvs_zlib_inflate(CVSZCTX *ctx, BUF *dst, u_char *src, size_t slen) { - int bytes, ret; - u_char buf[CVS_ZLIB_BUFSIZE]; - - bytes = 0; - cvs_buf_empty(dst); - if (inflateReset(&(ctx->z_instrm)) == Z_STREAM_ERROR) - fatal("inflate error: %s", ctx->z_instrm.msg); - - ctx->z_instrm.next_in = src; - ctx->z_instrm.avail_in = slen; - - do { - ctx->z_instrm.next_out = buf; - ctx->z_instrm.avail_out = sizeof(buf); + struct zlib_ioctx zio; - ret = inflate(&(ctx->z_instrm), Z_FINISH); - if (ret == Z_MEM_ERROR || ret == Z_BUF_ERROR || - ret == Z_STREAM_ERROR || ret == Z_DATA_ERROR) - fatal("inflate error: %s", ctx->z_instrm.msg); + zio.stream = &ctx->z_instrm; + zio.reset = inflateReset; + zio.io = inflate; + zio.ioflags = Z_FINISH; - cvs_buf_append(dst, buf, ctx->z_instrm.avail_out); - bytes += sizeof(buf) - ctx->z_instrm.avail_out; - - } while (ret != Z_STREAM_END); - - return (bytes); + return cvs_zlib_io(&zio, dst, src, slen); } /* @@ -137,28 +128,45 @@ cvs_zlib_inflate(CVSZCTX *ctx, BUF *dst, u_char *src, size_t slen) int cvs_zlib_deflate(CVSZCTX *ctx, BUF *dst, u_char *src, size_t slen) { + struct zlib_ioctx zio; + + zio.stream = &ctx->z_destrm; + zio.reset = deflateReset; + zio.io = deflate; + zio.ioflags = Z_FINISH; + + return cvs_zlib_io(&zio, dst, src, slen); +} + +static int +cvs_zlib_io(struct zlib_ioctx *zio, BUF *dst, u_char *src, size_t slen) +{ int bytes, ret; u_char buf[CVS_ZLIB_BUFSIZE]; + z_stream *zstream = zio->stream; bytes = 0; cvs_buf_empty(dst); - if (deflateReset(&(ctx->z_destrm)) == Z_STREAM_ERROR) - fatal("deflate error: %s", ctx->z_destrm.msg); + if ((*zio->reset)(zstream) == Z_STREAM_ERROR) + fatal("%s error: %s", (zio->reset == inflateReset) ? + "inflate" : "deflate", zstream->msg); - ctx->z_destrm.next_in = src; - ctx->z_destrm.avail_in = slen; + zstream->next_in = src; + zstream->avail_in = slen; do { - ctx->z_destrm.next_out = buf; - ctx->z_destrm.avail_out = sizeof(buf); - ret = deflate(&(ctx->z_destrm), Z_FINISH); - if (ret == Z_STREAM_ERROR || ret == Z_BUF_ERROR) - fatal("deflate error: %s", ctx->z_destrm.msg); + zstream->next_out = buf; + zstream->avail_out = sizeof(buf); + ret = (*zio->io)(zstream, zio->ioflags); + if (ret == Z_MEM_ERROR || ret == Z_STREAM_ERROR || + ret == Z_BUF_ERROR || ret == Z_DATA_ERROR) + fatal("%s error: %s", (zio->reset == inflateReset) ? + "inflate" : "deflate", zstream->msg); if (cvs_buf_append(dst, buf, - sizeof(buf) - ctx->z_destrm.avail_out) < 0) + sizeof(buf) - zstream->avail_out) < 0) return (-1); - bytes += sizeof(buf) - ctx->z_destrm.avail_out; + bytes += sizeof(buf) - zstream->avail_out; } while (ret != Z_STREAM_END); return (bytes); |