Coverage Report

Created: 2026-03-31 11:00

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.36k
                        z_size_t sourceLen, int level) {
26
4.36k
    z_stream stream;
27
4.36k
    int err;
28
4.36k
    const uInt max = (uInt)-1;
29
4.36k
    z_size_t left;
30
31
4.36k
    if ((sourceLen > 0 && source == NULL) ||
32
4.36k
        destLen == NULL || (*destLen > 0 && dest == NULL))
33
0
        return Z_STREAM_ERROR;
34
35
4.36k
    left = *destLen;
36
4.36k
    *destLen = 0;
37
38
4.36k
    stream.zalloc = (alloc_func)0;
39
4.36k
    stream.zfree = (free_func)0;
40
4.36k
    stream.opaque = (voidpf)0;
41
42
4.36k
    err = deflateInit(&stream, level);
43
4.36k
    if (err != Z_OK) return err;
44
45
4.36k
    stream.next_out = dest;
46
4.36k
    stream.avail_out = 0;
47
4.36k
    stream.next_in = (z_const Bytef *)source;
48
4.36k
    stream.avail_in = 0;
49
50
4.36k
    do {
51
4.36k
        if (stream.avail_out == 0) {
52
4.36k
            stream.avail_out = left > (z_size_t)max ? max : (uInt)left;
53
4.36k
            left -= stream.avail_out;
54
4.36k
        }
55
4.36k
        if (stream.avail_in == 0) {
56
4.36k
            stream.avail_in = sourceLen > (z_size_t)max ? max :
57
4.36k
                                                          (uInt)sourceLen;
58
4.36k
            sourceLen -= stream.avail_in;
59
4.36k
        }
60
4.36k
        err = deflate(&stream, sourceLen ? Z_NO_FLUSH : Z_FINISH);
61
4.36k
    } while (err == Z_OK);
62
63
4.36k
    *destLen = (z_size_t)(stream.next_out - dest);
64
4.36k
    deflateEnd(&stream);
65
4.36k
    return err == Z_STREAM_END ? Z_OK : err;
66
4.36k
}
67
int ZEXPORT compress2(Bytef *dest, uLongf *destLen, const Bytef *source,
68
4.36k
                      uLong sourceLen, int level) {
69
4.36k
    int ret;
70
4.36k
    z_size_t got = *destLen;
71
4.36k
    ret = compress2_z(dest, &got, source, sourceLen, level);
72
4.36k
    *destLen = (uLong)got;
73
4.36k
    return ret;
74
4.36k
}
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.36k
                     uLong sourceLen) {
84
4.36k
    return compress2(dest, destLen, source, sourceLen, Z_DEFAULT_COMPRESSION);
85
4.36k
}
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
}