Coverage Report

Created: 2026-06-30 11:14

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/work/workdir/UnpackedTarball/zlib/compress.c
Line
Count
Source
1
/* compress.c -- compress a memory buffer
2
 * Copyright (C) 1995-2026 Jean-loup Gailly, Mark Adler
3
 * For conditions of distribution and use, see copyright notice in zlib.h
4
 */
5
6
/* @(#) $Id$ */
7
8
#define ZLIB_INTERNAL
9
#include "zlib.h"
10
11
/* ===========================================================================
12
     Compresses the source buffer into the destination buffer. The level
13
   parameter has the same meaning as in deflateInit.  sourceLen is the byte
14
   length of the source buffer. Upon entry, destLen is the total size of the
15
   destination buffer, which must be at least 0.1% larger than sourceLen plus
16
   12 bytes. Upon exit, destLen is the actual size of the compressed buffer.
17
18
     compress2 returns Z_OK if success, Z_MEM_ERROR if there was not enough
19
   memory, Z_BUF_ERROR if there was not enough room in the output buffer,
20
   Z_STREAM_ERROR if the level parameter is invalid.
21
22
     The _z versions of the functions take size_t length arguments.
23
*/
24
int ZEXPORT compress2_z(Bytef *dest, z_size_t *destLen, const Bytef *source,
25
4.20k
                        z_size_t sourceLen, int level) {
26
4.20k
    z_stream stream;
27
4.20k
    int err;
28
4.20k
    const uInt max = (uInt)-1;
29
4.20k
    z_size_t left;
30
31
4.20k
    if ((sourceLen > 0 && source == NULL) ||
32
4.20k
        destLen == NULL || (*destLen > 0 && dest == NULL))
33
0
        return Z_STREAM_ERROR;
34
35
4.20k
    left = *destLen;
36
4.20k
    *destLen = 0;
37
38
4.20k
    stream.zalloc = (alloc_func)0;
39
4.20k
    stream.zfree = (free_func)0;
40
4.20k
    stream.opaque = (voidpf)0;
41
42
4.20k
    err = deflateInit(&stream, level);
43
4.20k
    if (err != Z_OK) return err;
44
45
4.20k
    stream.next_out = dest;
46
4.20k
    stream.avail_out = 0;
47
4.20k
    stream.next_in = (z_const Bytef *)source;
48
4.20k
    stream.avail_in = 0;
49
50
4.20k
    do {
51
4.20k
        if (stream.avail_out == 0) {
52
4.20k
            stream.avail_out = left > (z_size_t)max ? max : (uInt)left;
53
4.20k
            left -= stream.avail_out;
54
4.20k
        }
55
4.20k
        if (stream.avail_in == 0) {
56
4.20k
            stream.avail_in = sourceLen > (z_size_t)max ? max :
57
4.20k
                                                          (uInt)sourceLen;
58
4.20k
            sourceLen -= stream.avail_in;
59
4.20k
        }
60
4.20k
        err = deflate(&stream, sourceLen ? Z_NO_FLUSH : Z_FINISH);
61
4.20k
    } while (err == Z_OK);
62
63
4.20k
    *destLen = (z_size_t)(stream.next_out - dest);
64
4.20k
    deflateEnd(&stream);
65
4.20k
    return err == Z_STREAM_END ? Z_OK : err;
66
4.20k
}
67
int ZEXPORT compress2(Bytef *dest, uLongf *destLen, const Bytef *source,
68
4.20k
                      uLong sourceLen, int level) {
69
4.20k
    int ret;
70
4.20k
    z_size_t got = *destLen;
71
4.20k
    ret = compress2_z(dest, &got, source, sourceLen, level);
72
4.20k
    *destLen = (uLong)got;
73
4.20k
    return ret;
74
4.20k
}
75
/* ===========================================================================
76
 */
77
int ZEXPORT compress_z(Bytef *dest, z_size_t *destLen, const Bytef *source,
78
0
                       z_size_t sourceLen) {
79
0
    return compress2_z(dest, destLen, source, sourceLen,
80
0
                       Z_DEFAULT_COMPRESSION);
81
0
}
82
int ZEXPORT compress(Bytef *dest, uLongf *destLen, const Bytef *source,
83
4.20k
                     uLong sourceLen) {
84
4.20k
    return compress2(dest, destLen, source, sourceLen, Z_DEFAULT_COMPRESSION);
85
4.20k
}
86
87
/* ===========================================================================
88
     If the default memLevel or windowBits for deflateInit() is changed, then
89
   this function needs to be updated.
90
 */
91
0
z_size_t ZEXPORT compressBound_z(z_size_t sourceLen) {
92
0
    z_size_t bound = sourceLen + (sourceLen >> 12) + (sourceLen >> 14) +
93
0
                     (sourceLen >> 25) + 13;
94
0
    return bound < sourceLen ? (z_size_t)-1 : bound;
95
0
}
96
0
uLong ZEXPORT compressBound(uLong sourceLen) {
97
0
    z_size_t bound = compressBound_z(sourceLen);
98
0
    return (uLong)bound != bound ? (uLong)-1 : (uLong)bound;
99
0
}