TTKMusicPlayer
4.1.3.0
TTKMusicPlayer imitates Kugou UI, the music player uses of qmmp core library based on Qt for windows and linux
Main Page
Related Pages
Namespaces
Classes
Files
File List
File Members
TTKThirdParty
Zlib
zlib
inflate.h
Go to the documentation of this file.
1
/* inflate.h -- internal inflate state definition
2
* Copyright (C) 1995-2019 Mark Adler
3
* For conditions of distribution and use, see copyright notice in zlib.h
4
*/
5
6
/* WARNING: this file should *not* be used by applications. It is
7
part of the implementation of the compression library and is
8
subject to change. Applications should only use zlib.h.
9
*/
10
11
/* define NO_GZIP when compiling if you want to disable gzip header and
12
trailer decoding by inflate(). NO_GZIP would be used to avoid linking in
13
the crc code when it is not needed. For shared libraries, gzip decoding
14
should be left enabled. */
15
#ifndef NO_GZIP
16
# define GUNZIP
17
#endif
18
19
/* Possible inflate modes between inflate() calls */
20
typedef
enum
{
21
HEAD
= 16180,
/* i: waiting for magic header */
22
FLAGS
,
/* i: waiting for method and flags (gzip) */
23
TIME
,
/* i: waiting for modification time (gzip) */
24
OS
,
/* i: waiting for extra flags and operating system (gzip) */
25
EXLEN
,
/* i: waiting for extra length (gzip) */
26
EXTRA
,
/* i: waiting for extra bytes (gzip) */
27
NAME
,
/* i: waiting for end of file name (gzip) */
28
COMMENT
,
/* i: waiting for end of comment (gzip) */
29
HCRC
,
/* i: waiting for header crc (gzip) */
30
DICTID
,
/* i: waiting for dictionary check value */
31
DICT
,
/* waiting for inflateSetDictionary() call */
32
TYPE
,
/* i: waiting for type bits, including last-flag bit */
33
TYPEDO
,
/* i: same, but skip check to exit inflate on new block */
34
STORED
,
/* i: waiting for stored size (length and complement) */
35
COPY_
,
/* i/o: same as COPY below, but only first time in */
36
COPY
,
/* i/o: waiting for input or output to copy stored block */
37
TABLE
,
/* i: waiting for dynamic block table lengths */
38
LENLENS
,
/* i: waiting for code length code lengths */
39
CODELENS
,
/* i: waiting for length/lit and distance code lengths */
40
LEN_
,
/* i: same as LEN below, but only first time in */
41
LEN
,
/* i: waiting for length/lit/eob code */
42
LENEXT
,
/* i: waiting for length extra bits */
43
DIST
,
/* i: waiting for distance code */
44
DISTEXT
,
/* i: waiting for distance extra bits */
45
MATCH
,
/* o: waiting for output space to copy string */
46
LIT
,
/* o: waiting for output space to write literal */
47
CHECK
,
/* i: waiting for 32-bit check value */
48
LENGTH
,
/* i: waiting for 32-bit length (gzip) */
49
DONE
,
/* finished check, done -- remain here until reset */
50
BAD
,
/* got a data error -- remain here until reset */
51
MEM
,
/* got an inflate() memory error -- remain here until reset */
52
SYNC
/* looking for synchronization bytes to restart inflate() */
53
}
inflate_mode
;
54
55
/*
56
State transitions between above modes -
57
58
(most modes can go to BAD or MEM on error -- not shown for clarity)
59
60
Process header:
61
HEAD -> (gzip) or (zlib) or (raw)
62
(gzip) -> FLAGS -> TIME -> OS -> EXLEN -> EXTRA -> NAME -> COMMENT ->
63
HCRC -> TYPE
64
(zlib) -> DICTID or TYPE
65
DICTID -> DICT -> TYPE
66
(raw) -> TYPEDO
67
Read deflate blocks:
68
TYPE -> TYPEDO -> STORED or TABLE or LEN_ or CHECK
69
STORED -> COPY_ -> COPY -> TYPE
70
TABLE -> LENLENS -> CODELENS -> LEN_
71
LEN_ -> LEN
72
Read deflate codes in fixed or dynamic block:
73
LEN -> LENEXT or LIT or TYPE
74
LENEXT -> DIST -> DISTEXT -> MATCH -> LEN
75
LIT -> LEN
76
Process trailer:
77
CHECK -> LENGTH -> DONE
78
*/
79
80
/* State maintained between inflate() calls -- approximately 7K bytes, not
81
including the allocated sliding window, which is up to 32K bytes. */
82
struct
inflate_state
{
83
z_streamp
strm
;
/* pointer back to this zlib stream */
84
inflate_mode
mode
;
/* current inflate mode */
85
int
last
;
/* true if processing last block */
86
int
wrap
;
/* bit 0 true for zlib, bit 1 true for gzip,
87
bit 2 true to validate check value */
88
int
havedict
;
/* true if dictionary provided */
89
int
flags
;
/* gzip header method and flags, 0 if zlib, or
90
-1 if raw or no header yet */
91
unsigned
dmax
;
/* zlib header max distance (INFLATE_STRICT) */
92
unsigned
long
check
;
/* protected copy of check value */
93
unsigned
long
total
;
/* protected copy of output count */
94
gz_headerp
head
;
/* where to save gzip header information */
95
/* sliding window */
96
unsigned
wbits
;
/* log base 2 of requested window size */
97
unsigned
wsize
;
/* window size or zero if not using window */
98
unsigned
whave
;
/* valid bytes in the window */
99
unsigned
wnext
;
/* window write index */
100
unsigned
char
FAR
*
window
;
/* allocated sliding window, if needed */
101
/* bit accumulator */
102
unsigned
long
hold
;
/* input bit accumulator */
103
unsigned
bits
;
/* number of bits in "in" */
104
/* for string and stored block copying */
105
unsigned
length
;
/* literal or length of data to copy */
106
unsigned
offset
;
/* distance back to copy string from */
107
/* for table and code decoding */
108
unsigned
extra
;
/* extra bits needed */
109
/* fixed and dynamic code tables */
110
code
const
FAR
*
lencode
;
/* starting table for length/literal codes */
111
code
const
FAR
*
distcode
;
/* starting table for distance codes */
112
unsigned
lenbits
;
/* index bits for lencode */
113
unsigned
distbits
;
/* index bits for distcode */
114
/* dynamic table building */
115
unsigned
ncode
;
/* number of code length code lengths */
116
unsigned
nlen
;
/* number of length code lengths */
117
unsigned
ndist
;
/* number of distance code lengths */
118
unsigned
have
;
/* number of code lengths in lens[] */
119
code
FAR
*
next
;
/* next available space in codes[] */
120
unsigned
short
lens
[320];
/* temporary storage for code lengths */
121
unsigned
short
work
[288];
/* work area for code table building */
122
code
codes
[
ENOUGH
];
/* space for code tables */
123
int
sane
;
/* if false, allow invalid distance too far */
124
int
back
;
/* bits back of last unprocessed length/lit */
125
unsigned
was
;
/* initial length of match */
126
};
COMMENT
Definition:
inflate.h:28
inflate_state::nlen
unsigned nlen
Definition:
inflate.h:116
COPY
Definition:
inflate.h:36
inflate_state
Definition:
inflate.h:82
inflate_state::havedict
int havedict
Definition:
inflate.h:88
STORED
Definition:
inflate.h:34
DISTEXT
Definition:
inflate.h:44
inflate_state::wnext
unsigned wnext
Definition:
inflate.h:99
inflate_state::ndist
unsigned ndist
Definition:
inflate.h:117
inflate_state::total
unsigned long total
Definition:
inflate.h:93
inflate_state::head
gz_headerp head
Definition:
inflate.h:94
inflate_state::strm
z_streamp strm
Definition:
inflate.h:83
inflate_state::wsize
unsigned wsize
Definition:
inflate.h:97
inflate_state::sane
int sane
Definition:
inflate.h:123
inflate_state::have
unsigned have
Definition:
inflate.h:118
inflate_state::distbits
unsigned distbits
Definition:
inflate.h:113
ENOUGH
#define ENOUGH
Definition:
inftrees.h:51
inflate_state::extra
unsigned extra
Definition:
inflate.h:108
inflate_state::distcode
code const FAR * distcode
Definition:
inflate.h:111
inflate_state::last
int last
Definition:
inflate.h:85
inflate_state::check
unsigned long check
Definition:
inflate.h:92
DONE
Definition:
inflate.h:49
NAME
Definition:
inflate.h:27
TYPE
Definition:
inflate.h:32
DICTID
Definition:
inflate.h:30
gz_headerp
gz_header FAR * gz_headerp
Definition:
zlib.h:131
OS
Definition:
inflate.h:24
inflate_state::lenbits
unsigned lenbits
Definition:
inflate.h:112
inflate_state::lens
unsigned short lens[320]
Definition:
inflate.h:120
LEN
Definition:
inflate.h:41
LENLENS
Definition:
inflate.h:38
inflate_state::ncode
unsigned ncode
Definition:
inflate.h:115
TABLE
Definition:
inflate.h:37
LENGTH
Definition:
inflate.h:48
inflate_state::next
code FAR * next
Definition:
inflate.h:119
SYNC
Definition:
inflate.h:52
EXTRA
Definition:
inflate.h:26
inflate_state::codes
code codes[ENOUGH]
Definition:
inflate.h:122
inflate_state::hold
unsigned long hold
Definition:
inflate.h:102
CHECK
Definition:
inflate.h:47
LENEXT
Definition:
inflate.h:42
LIT
Definition:
inflate.h:46
TIME
Definition:
inflate.h:23
DICT
Definition:
inflate.h:31
inflate_state::work
unsigned short work[288]
Definition:
inflate.h:121
HCRC
Definition:
inflate.h:29
HEAD
Definition:
inflate.h:21
code
Definition:
inftrees.h:24
inflate_state::dmax
unsigned dmax
Definition:
inflate.h:91
inflate_state::bits
unsigned bits
Definition:
inflate.h:103
MATCH
Definition:
inflate.h:45
TYPEDO
Definition:
inflate.h:33
inflate_mode
inflate_mode
Definition:
inflate.h:20
inflate_state::back
int back
Definition:
inflate.h:124
EXLEN
Definition:
inflate.h:25
inflate_state::window
unsigned char FAR * window
Definition:
inflate.h:100
inflate_state::mode
inflate_mode mode
Definition:
inflate.h:84
LEN_
Definition:
inflate.h:40
COPY_
Definition:
inflate.h:35
BAD
Definition:
inflate.h:50
CODELENS
Definition:
inflate.h:39
inflate_state::whave
unsigned whave
Definition:
inflate.h:98
FAR
#define FAR
Definition:
zconf.h:389
inflate_state::offset
unsigned offset
Definition:
inflate.h:106
z_streamp
z_stream FAR * z_streamp
Definition:
zlib.h:108
DIST
Definition:
inflate.h:43
inflate_state::was
unsigned was
Definition:
inflate.h:125
inflate_state::flags
int flags
Definition:
inflate.h:89
inflate_state::lencode
code const FAR * lencode
Definition:
inflate.h:110
FLAGS
Definition:
inflate.h:22
inflate_state::wbits
unsigned wbits
Definition:
inflate.h:96
inflate_state::wrap
int wrap
Definition:
inflate.h:86
MEM
Definition:
inflate.h:51
inflate_state::length
unsigned length
Definition:
inflate.h:105
Generated on Tue Jan 21 2025 21:07:15 for TTKMusicPlayer by
1.8.8