2 * zlib wrappers to make sure we don't silently miss errors
7 static const char *zerr_to_string(int status)
11 return "out of memory";
13 return "wrong version";
15 return "needs dictionary";
17 return "data stream error";
19 return "stream consistency error";
21 return "unknown error";
25 void git_inflate_init(z_streamp strm)
27 int status = inflateInit(strm);
31 die("inflateInit: %s (%s)", zerr_to_string(status),
32 strm->msg ? strm->msg : "no message");
35 void git_inflate_init_gzip_only(z_streamp strm)
38 * Use default 15 bits, +16 is to accept only gzip and to
39 * yield Z_DATA_ERROR when fed zlib format.
41 const int windowBits = 15 + 16;
42 int status = inflateInit2(strm, windowBits);
46 die("inflateInit2: %s (%s)", zerr_to_string(status),
47 strm->msg ? strm->msg : "no message");
50 void git_inflate_end(z_streamp strm)
52 int status = inflateEnd(strm);
56 error("inflateEnd: %s (%s)", zerr_to_string(status),
57 strm->msg ? strm->msg : "no message");
60 int git_inflate(z_streamp strm, int flush)
62 int status = inflate(strm, flush);
65 /* Z_BUF_ERROR: normal, needs more space in the output buffer */
72 die("inflate: out of memory");
76 error("inflate: %s (%s)", zerr_to_string(status),
77 strm->msg ? strm->msg : "no message");