MRPT
1.9.9
inflate.h
Go to the documentation of this file.
1
/* +------------------------------------------------------------------------+
2
| Mobile Robot Programming Toolkit (MRPT) |
3
| https://www.mrpt.org/ |
4
| |
5
| Copyright (c) 2005-2019, Individual contributors, see AUTHORS file |
6
| See: https://www.mrpt.org/Authors - All rights reserved. |
7
| Released under BSD License. See: https://www.mrpt.org/License |
8
+------------------------------------------------------------------------+ */
9
10
/* WARNING: this file should *not* be used by applications. It is
11
part of the implementation of the compression library and is
12
subject to change. Applications should only use zlib.h.
13
*/
14
15
/* define NO_GZIP when compiling if you want to disable gzip header and
16
trailer decoding by inflate(). NO_GZIP would be used to avoid linking in
17
the crc code when it is not needed. For shared libraries, gzip decoding
18
should be left enabled. */
19
#ifndef NO_GZIP
20
#define GUNZIP
21
#endif
22
23
/* Possible inflate modes between inflate() calls */
24
typedef
enum
25
{
26
HEAD
,
/* i: waiting for magic header */
27
FLAGS
,
/* i: waiting for method and flags (gzip) */
28
TIME
,
/* i: waiting for modification time (gzip) */
29
OS
,
/* i: waiting for extra flags and operating system (gzip) */
30
EXLEN
,
/* i: waiting for extra length (gzip) */
31
EXTRA
,
/* i: waiting for extra bytes (gzip) */
32
NAME
,
/* i: waiting for end of file name (gzip) */
33
COMMENT
,
/* i: waiting for end of comment (gzip) */
34
HCRC
,
/* i: waiting for header crc (gzip) */
35
DICTID
,
/* i: waiting for dictionary check value */
36
DICT
,
/* waiting for inflateSetDictionary() call */
37
TYPE
,
/* i: waiting for type bits, including last-flag bit */
38
TYPEDO
,
/* i: same, but skip check to exit inflate on new block */
39
STORED
,
/* i: waiting for stored size (length and complement) */
40
COPY
,
/* i/o: waiting for input or output to copy stored block */
41
TABLE
,
/* i: waiting for dynamic block table lengths */
42
LENLENS
,
/* i: waiting for code length code lengths */
43
CODELENS
,
/* i: waiting for length/lit and distance code lengths */
44
LEN
,
/* i: waiting for length/lit code */
45
LENEXT
,
/* i: waiting for length extra bits */
46
DIST
,
/* i: waiting for distance code */
47
DISTEXT
,
/* i: waiting for distance extra bits */
48
MATCH
,
/* o: waiting for output space to copy string */
49
LIT
,
/* o: waiting for output space to write literal */
50
CHECK
,
/* i: waiting for 32-bit check value */
51
LENGTH
,
/* i: waiting for 32-bit length (gzip) */
52
DONE
,
/* finished check, done -- remain here until reset */
53
BAD
,
/* got a data error -- remain here until reset */
54
MEM
,
/* got an inflate() memory error -- remain here until reset */
55
SYNC
/* looking for synchronization bytes to restart inflate() */
56
}
inflate_mode
;
57
58
/*
59
State transitions between above modes -
60
61
(most modes can go to the BAD or MEM mode -- not shown for clarity)
62
63
Process header:
64
HEAD -> (gzip) or (zlib)
65
(gzip) -> FLAGS -> TIME -> OS -> EXLEN -> EXTRA -> NAME
66
NAME -> COMMENT -> HCRC -> TYPE
67
(zlib) -> DICTID or TYPE
68
DICTID -> DICT -> TYPE
69
Read deflate blocks:
70
TYPE -> STORED or TABLE or LEN or CHECK
71
STORED -> COPY -> TYPE
72
TABLE -> LENLENS -> CODELENS -> LEN
73
Read deflate codes:
74
LEN -> LENEXT or LIT or TYPE
75
LENEXT -> DIST -> DISTEXT -> MATCH -> LEN
76
LIT -> LEN
77
Process trailer:
78
CHECK -> LENGTH -> DONE
79
*/
80
81
/* state maintained between inflate() calls. Approximately 7K bytes. */
82
struct
inflate_state
83
{
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
int
havedict
;
/* true if dictionary provided */
88
int
flags
;
/* gzip header method and flags (0 if zlib) */
89
unsigned
dmax
;
/* zlib header max distance (INFLATE_STRICT) */
90
unsigned
long
check
;
/* protected copy of check value */
91
unsigned
long
total
;
/* protected copy of output count */
92
gz_headerp
head
;
/* where to save gzip header information */
93
/* sliding window */
94
unsigned
wbits
;
/* log base 2 of requested window size */
95
unsigned
wsize
;
/* window size or zero if not using window */
96
unsigned
whave
;
/* valid bytes in the window */
97
unsigned
write
;
/* window write index */
98
unsigned
char
FAR
*
window
;
/* allocated sliding window, if needed */
99
/* bit accumulator */
100
unsigned
long
hold
;
/* input bit accumulator */
101
unsigned
bits
;
/* number of bits in "in" */
102
/* for string and stored block copying */
103
unsigned
length
;
/* literal or length of data to copy */
104
unsigned
offset
;
/* distance back to copy string from */
105
/* for table and code decoding */
106
unsigned
extra
;
/* extra bits needed */
107
/* fixed and dynamic code tables */
108
code
const
FAR
*
lencode
;
/* starting table for length/literal codes */
109
code
const
FAR
*
distcode
;
/* starting table for distance codes */
110
unsigned
lenbits
;
/* index bits for lencode */
111
unsigned
distbits
;
/* index bits for distcode */
112
/* dynamic table building */
113
unsigned
ncode
;
/* number of code length code lengths */
114
unsigned
nlen
;
/* number of length code lengths */
115
unsigned
ndist
;
/* number of distance code lengths */
116
unsigned
have
;
/* number of code lengths in lens[] */
117
code
FAR
*
next
;
/* next available space in codes[] */
118
unsigned
short
lens
[320];
/* temporary storage for code lengths */
119
unsigned
short
work
[288];
/* work area for code table building */
120
code
codes
[
ENOUGH
];
/* space for code tables */
121
};
COMMENT
Definition:
inflate.h:33
inflate_state::nlen
unsigned nlen
Definition:
inflate.h:114
COPY
Definition:
inflate.h:40
inflate_state
Definition:
inflate.h:82
inflate_state::havedict
int havedict
Definition:
inflate.h:87
STORED
Definition:
inflate.h:39
DISTEXT
Definition:
inflate.h:47
inflate_state::ndist
unsigned ndist
Definition:
inflate.h:115
inflate_state::total
unsigned long total
Definition:
inflate.h:91
inflate_state::head
gz_headerp head
Definition:
inflate.h:92
inflate_state::wsize
unsigned wsize
Definition:
inflate.h:95
inflate_state::have
unsigned have
Definition:
inflate.h:116
inflate_state::distbits
unsigned distbits
Definition:
inflate.h:111
ENOUGH
#define ENOUGH
Definition:
inftrees.h:48
inflate_state::extra
unsigned extra
Definition:
inflate.h:106
inflate_state::distcode
code const FAR * distcode
Definition:
inflate.h:109
inflate_state::last
int last
Definition:
inflate.h:85
inflate_state::check
unsigned long check
Definition:
inflate.h:90
DONE
Definition:
inflate.h:52
NAME
Definition:
inflate.h:32
TYPE
Definition:
inflate.h:37
DICTID
Definition:
inflate.h:35
gz_headerp
gz_header FAR * gz_headerp
Definition:
zlib.h:110
OS
Definition:
inflate.h:29
inflate_state::lenbits
unsigned lenbits
Definition:
inflate.h:110
inflate_state::lens
unsigned short lens[320]
Definition:
inflate.h:118
LEN
Definition:
inflate.h:44
LENLENS
Definition:
inflate.h:42
inflate_state::ncode
unsigned ncode
Definition:
inflate.h:113
TABLE
Definition:
inflate.h:41
LENGTH
Definition:
inflate.h:51
inflate_state::next
code FAR * next
Definition:
inflate.h:117
SYNC
Definition:
inflate.h:55
EXTRA
Definition:
inflate.h:31
inflate_state::codes
code codes[ENOUGH]
Definition:
inflate.h:120
inflate_state::hold
unsigned long hold
Definition:
inflate.h:100
CHECK
Definition:
inflate.h:50
LENEXT
Definition:
inflate.h:45
LIT
Definition:
inflate.h:49
TIME
Definition:
inflate.h:28
DICT
Definition:
inflate.h:36
inflate_state::work
unsigned short work[288]
Definition:
inflate.h:119
HCRC
Definition:
inflate.h:34
HEAD
Definition:
inflate.h:26
inflate_state::write
unsigned write
Definition:
inflate.h:97
code
Definition:
inftrees.h:28
inflate_state::dmax
unsigned dmax
Definition:
inflate.h:89
inflate_state::bits
unsigned bits
Definition:
inflate.h:101
MATCH
Definition:
inflate.h:48
TYPEDO
Definition:
inflate.h:38
inflate_mode
inflate_mode
Definition:
inflate.h:24
EXLEN
Definition:
inflate.h:30
inflate_state::window
unsigned char FAR * window
Definition:
inflate.h:98
inflate_state::mode
inflate_mode mode
Definition:
inflate.h:84
BAD
Definition:
inflate.h:53
CODELENS
Definition:
inflate.h:43
inflate_state::whave
unsigned whave
Definition:
inflate.h:96
FAR
#define FAR
Definition:
zconf.h:261
inflate_state::offset
unsigned offset
Definition:
inflate.h:104
DIST
Definition:
inflate.h:46
inflate_state::flags
int flags
Definition:
inflate.h:88
inflate_state::lencode
code const FAR * lencode
Definition:
inflate.h:108
FLAGS
Definition:
inflate.h:27
inflate_state::wbits
unsigned wbits
Definition:
inflate.h:94
inflate_state::wrap
int wrap
Definition:
inflate.h:86
MEM
Definition:
inflate.h:54
inflate_state::length
unsigned length
Definition:
inflate.h:103
Page generated by
Doxygen 1.8.14
for MRPT 1.9.9 Git: 8fe78517f Sun Jul 14 19:43:28 2019 +0200 at lun oct 28 02:10:00 CET 2019