zstdlib 0.11.0-x64-mingw-ucrt → 0.12.0-x64-mingw-ucrt

Sign up to get free protection for your applications and to get access to all the features.
Files changed (34) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGES.md +9 -0
  3. data/ext/zstdlib_c/extconf.rb +8 -3
  4. data/ext/zstdlib_c/ruby/zlib-3.3/zstdlib.c +5090 -0
  5. data/ext/zstdlib_c/{zlib-1.2.12 → zlib-1.3.1}/adler32.c +5 -27
  6. data/ext/zstdlib_c/{zlib-1.2.12 → zlib-1.3.1}/compress.c +5 -16
  7. data/ext/zstdlib_c/{zlib-1.2.12 → zlib-1.3.1}/crc32.c +94 -161
  8. data/ext/zstdlib_c/{zlib-1.2.12 → zlib-1.3.1}/deflate.c +362 -434
  9. data/ext/zstdlib_c/{zlib-1.2.12 → zlib-1.3.1}/deflate.h +43 -12
  10. data/ext/zstdlib_c/{zlib-1.2.12 → zlib-1.3.1}/gzclose.c +1 -3
  11. data/ext/zstdlib_c/{zlib-1.2.12 → zlib-1.3.1}/gzguts.h +13 -18
  12. data/ext/zstdlib_c/{zlib-1.2.12 → zlib-1.3.1}/gzlib.c +28 -85
  13. data/ext/zstdlib_c/{zlib-1.2.12 → zlib-1.3.1}/gzread.c +23 -73
  14. data/ext/zstdlib_c/{zlib-1.2.12 → zlib-1.3.1}/gzwrite.c +19 -65
  15. data/ext/zstdlib_c/{zlib-1.2.12 → zlib-1.3.1}/infback.c +17 -30
  16. data/ext/zstdlib_c/{zlib-1.2.12 → zlib-1.3.1}/inffast.c +1 -4
  17. data/ext/zstdlib_c/{zlib-1.2.12 → zlib-1.3.1}/inffast.h +1 -1
  18. data/ext/zstdlib_c/{zlib-1.2.12 → zlib-1.3.1}/inflate.c +36 -102
  19. data/ext/zstdlib_c/{zlib-1.2.12 → zlib-1.3.1}/inftrees.c +6 -11
  20. data/ext/zstdlib_c/{zlib-1.2.12 → zlib-1.3.1}/inftrees.h +6 -6
  21. data/ext/zstdlib_c/{zlib-1.2.12 → zlib-1.3.1}/trees.c +290 -355
  22. data/ext/zstdlib_c/{zlib-1.2.12 → zlib-1.3.1}/uncompr.c +4 -12
  23. data/ext/zstdlib_c/{zlib-1.2.12 → zlib-1.3.1}/zconf.h +23 -14
  24. data/ext/zstdlib_c/{zlib-1.2.12 → zlib-1.3.1}/zlib.h +202 -199
  25. data/ext/zstdlib_c/{zlib-1.2.12 → zlib-1.3.1}/zutil.c +18 -44
  26. data/ext/zstdlib_c/{zlib-1.2.12 → zlib-1.3.1}/zutil.h +13 -33
  27. data/lib/3.1/zstdlib_c.so +0 -0
  28. data/lib/3.2/zstdlib_c.so +0 -0
  29. data/lib/3.3/zstdlib_c.so +0 -0
  30. metadata +34 -32
  31. /data/ext/zstdlib_c/{zlib-1.2.12 → zlib-1.3.1}/crc32.h +0 -0
  32. /data/ext/zstdlib_c/{zlib-1.2.12 → zlib-1.3.1}/inffixed.h +0 -0
  33. /data/ext/zstdlib_c/{zlib-1.2.12 → zlib-1.3.1}/inflate.h +0 -0
  34. /data/ext/zstdlib_c/{zlib-1.2.12 → zlib-1.3.1}/trees.h +0 -0
@@ -1,5 +1,5 @@
1
1
  /* trees.c -- output deflated data using Huffman coding
2
- * Copyright (C) 1995-2021 Jean-loup Gailly
2
+ * Copyright (C) 1995-2024 Jean-loup Gailly
3
3
  * detect_data_type() function provided freely by Cosmin Truta, 2006
4
4
  * For conditions of distribution and use, see copyright notice in zlib.h
5
5
  */
@@ -122,39 +122,116 @@ struct static_tree_desc_s {
122
122
  int max_length; /* max bit length for the codes */
123
123
  };
124
124
 
125
- local const static_tree_desc static_l_desc =
125
+ #ifdef NO_INIT_GLOBAL_POINTERS
126
+ # define TCONST
127
+ #else
128
+ # define TCONST const
129
+ #endif
130
+
131
+ local TCONST static_tree_desc static_l_desc =
126
132
  {static_ltree, extra_lbits, LITERALS+1, L_CODES, MAX_BITS};
127
133
 
128
- local const static_tree_desc static_d_desc =
134
+ local TCONST static_tree_desc static_d_desc =
129
135
  {static_dtree, extra_dbits, 0, D_CODES, MAX_BITS};
130
136
 
131
- local const static_tree_desc static_bl_desc =
137
+ local TCONST static_tree_desc static_bl_desc =
132
138
  {(const ct_data *)0, extra_blbits, 0, BL_CODES, MAX_BL_BITS};
133
139
 
134
140
  /* ===========================================================================
135
- * Local (static) routines in this file.
141
+ * Output a short LSB first on the stream.
142
+ * IN assertion: there is enough room in pendingBuf.
143
+ */
144
+ #define put_short(s, w) { \
145
+ put_byte(s, (uch)((w) & 0xff)); \
146
+ put_byte(s, (uch)((ush)(w) >> 8)); \
147
+ }
148
+
149
+ /* ===========================================================================
150
+ * Reverse the first len bits of a code, using straightforward code (a faster
151
+ * method would use a table)
152
+ * IN assertion: 1 <= len <= 15
153
+ */
154
+ local unsigned bi_reverse(unsigned code, int len) {
155
+ register unsigned res = 0;
156
+ do {
157
+ res |= code & 1;
158
+ code >>= 1, res <<= 1;
159
+ } while (--len > 0);
160
+ return res >> 1;
161
+ }
162
+
163
+ /* ===========================================================================
164
+ * Flush the bit buffer, keeping at most 7 bits in it.
165
+ */
166
+ local void bi_flush(deflate_state *s) {
167
+ if (s->bi_valid == 16) {
168
+ put_short(s, s->bi_buf);
169
+ s->bi_buf = 0;
170
+ s->bi_valid = 0;
171
+ } else if (s->bi_valid >= 8) {
172
+ put_byte(s, (Byte)s->bi_buf);
173
+ s->bi_buf >>= 8;
174
+ s->bi_valid -= 8;
175
+ }
176
+ }
177
+
178
+ /* ===========================================================================
179
+ * Flush the bit buffer and align the output on a byte boundary
180
+ */
181
+ local void bi_windup(deflate_state *s) {
182
+ if (s->bi_valid > 8) {
183
+ put_short(s, s->bi_buf);
184
+ } else if (s->bi_valid > 0) {
185
+ put_byte(s, (Byte)s->bi_buf);
186
+ }
187
+ s->bi_buf = 0;
188
+ s->bi_valid = 0;
189
+ #ifdef ZLIB_DEBUG
190
+ s->bits_sent = (s->bits_sent + 7) & ~7;
191
+ #endif
192
+ }
193
+
194
+ /* ===========================================================================
195
+ * Generate the codes for a given tree and bit counts (which need not be
196
+ * optimal).
197
+ * IN assertion: the array bl_count contains the bit length statistics for
198
+ * the given tree and the field len is set for all tree elements.
199
+ * OUT assertion: the field code is set for all tree elements of non
200
+ * zero code length.
136
201
  */
202
+ local void gen_codes(ct_data *tree, int max_code, ushf *bl_count) {
203
+ ush next_code[MAX_BITS+1]; /* next code value for each bit length */
204
+ unsigned code = 0; /* running code value */
205
+ int bits; /* bit index */
206
+ int n; /* code index */
137
207
 
138
- local void tr_static_init OF((void));
139
- local void init_block OF((deflate_state *s));
140
- local void pqdownheap OF((deflate_state *s, ct_data *tree, int k));
141
- local void gen_bitlen OF((deflate_state *s, tree_desc *desc));
142
- local void gen_codes OF((ct_data *tree, int max_code, ushf *bl_count));
143
- local void build_tree OF((deflate_state *s, tree_desc *desc));
144
- local void scan_tree OF((deflate_state *s, ct_data *tree, int max_code));
145
- local void send_tree OF((deflate_state *s, ct_data *tree, int max_code));
146
- local int build_bl_tree OF((deflate_state *s));
147
- local void send_all_trees OF((deflate_state *s, int lcodes, int dcodes,
148
- int blcodes));
149
- local void compress_block OF((deflate_state *s, const ct_data *ltree,
150
- const ct_data *dtree));
151
- local int detect_data_type OF((deflate_state *s));
152
- local unsigned bi_reverse OF((unsigned code, int len));
153
- local void bi_windup OF((deflate_state *s));
154
- local void bi_flush OF((deflate_state *s));
208
+ /* The distribution counts are first used to generate the code values
209
+ * without bit reversal.
210
+ */
211
+ for (bits = 1; bits <= MAX_BITS; bits++) {
212
+ code = (code + bl_count[bits - 1]) << 1;
213
+ next_code[bits] = (ush)code;
214
+ }
215
+ /* Check that the bit counts in bl_count are consistent. The last code
216
+ * must be all ones.
217
+ */
218
+ Assert (code + bl_count[MAX_BITS] - 1 == (1 << MAX_BITS) - 1,
219
+ "inconsistent bit counts");
220
+ Tracev((stderr,"\ngen_codes: max_code %d ", max_code));
221
+
222
+ for (n = 0; n <= max_code; n++) {
223
+ int len = tree[n].Len;
224
+ if (len == 0) continue;
225
+ /* Now reverse the bits */
226
+ tree[n].Code = (ush)bi_reverse(next_code[len]++, len);
227
+
228
+ Tracecv(tree != static_ltree, (stderr,"\nn %3d %c l %2d c %4x (%x) ",
229
+ n, (isgraph(n) ? n : ' '), len, tree[n].Code, next_code[len] - 1));
230
+ }
231
+ }
155
232
 
156
233
  #ifdef GEN_TREES_H
157
- local void gen_trees_header OF((void));
234
+ local void gen_trees_header(void);
158
235
  #endif
159
236
 
160
237
  #ifndef ZLIB_DEBUG
@@ -167,33 +244,18 @@ local void gen_trees_header OF((void));
167
244
  send_bits(s, tree[c].Code, tree[c].Len); }
168
245
  #endif
169
246
 
170
- /* ===========================================================================
171
- * Output a short LSB first on the stream.
172
- * IN assertion: there is enough room in pendingBuf.
173
- */
174
- #define put_short(s, w) { \
175
- put_byte(s, (uch)((w) & 0xff)); \
176
- put_byte(s, (uch)((ush)(w) >> 8)); \
177
- }
178
-
179
247
  /* ===========================================================================
180
248
  * Send a value on a given number of bits.
181
249
  * IN assertion: length <= 16 and value fits in length bits.
182
250
  */
183
251
  #ifdef ZLIB_DEBUG
184
- local void send_bits OF((deflate_state *s, int value, int length));
185
-
186
- local void send_bits(s, value, length)
187
- deflate_state *s;
188
- int value; /* value to send */
189
- int length; /* number of bits */
190
- {
252
+ local void send_bits(deflate_state *s, int value, int length) {
191
253
  Tracevv((stderr," l %2d v %4x ", length, value));
192
254
  Assert(length > 0 && length <= 15, "invalid length");
193
255
  s->bits_sent += (ulg)length;
194
256
 
195
257
  /* If not enough room in bi_buf, use (valid) bits from bi_buf and
196
- * (16 - bi_valid) bits from value, leaving (width - (16-bi_valid))
258
+ * (16 - bi_valid) bits from value, leaving (width - (16 - bi_valid))
197
259
  * unused bits in value.
198
260
  */
199
261
  if (s->bi_valid > (int)Buf_size - length) {
@@ -229,8 +291,7 @@ local void send_bits(s, value, length)
229
291
  /* ===========================================================================
230
292
  * Initialize the various 'constant' tables.
231
293
  */
232
- local void tr_static_init()
233
- {
294
+ local void tr_static_init(void) {
234
295
  #if defined(GEN_TREES_H) || !defined(STDC)
235
296
  static int static_init_done = 0;
236
297
  int n; /* iterates over tree elements */
@@ -256,7 +317,7 @@ local void tr_static_init()
256
317
  length = 0;
257
318
  for (code = 0; code < LENGTH_CODES-1; code++) {
258
319
  base_length[code] = length;
259
- for (n = 0; n < (1<<extra_lbits[code]); n++) {
320
+ for (n = 0; n < (1 << extra_lbits[code]); n++) {
260
321
  _length_code[length++] = (uch)code;
261
322
  }
262
323
  }
@@ -265,13 +326,13 @@ local void tr_static_init()
265
326
  * in two different ways: code 284 + 5 bits or code 285, so we
266
327
  * overwrite length_code[255] to use the best encoding:
267
328
  */
268
- _length_code[length-1] = (uch)code;
329
+ _length_code[length - 1] = (uch)code;
269
330
 
270
331
  /* Initialize the mapping dist (0..32K) -> dist code (0..29) */
271
332
  dist = 0;
272
333
  for (code = 0 ; code < 16; code++) {
273
334
  base_dist[code] = dist;
274
- for (n = 0; n < (1<<extra_dbits[code]); n++) {
335
+ for (n = 0; n < (1 << extra_dbits[code]); n++) {
275
336
  _dist_code[dist++] = (uch)code;
276
337
  }
277
338
  }
@@ -279,11 +340,11 @@ local void tr_static_init()
279
340
  dist >>= 7; /* from now on, all distances are divided by 128 */
280
341
  for ( ; code < D_CODES; code++) {
281
342
  base_dist[code] = dist << 7;
282
- for (n = 0; n < (1<<(extra_dbits[code]-7)); n++) {
343
+ for (n = 0; n < (1 << (extra_dbits[code] - 7)); n++) {
283
344
  _dist_code[256 + dist++] = (uch)code;
284
345
  }
285
346
  }
286
- Assert (dist == 256, "tr_static_init: 256+dist != 512");
347
+ Assert (dist == 256, "tr_static_init: 256 + dist != 512");
287
348
 
288
349
  /* Construct the codes of the static literal tree */
289
350
  for (bits = 0; bits <= MAX_BITS; bits++) bl_count[bits] = 0;
@@ -312,7 +373,7 @@ local void tr_static_init()
312
373
  }
313
374
 
314
375
  /* ===========================================================================
315
- * Genererate the file trees.h describing the static trees.
376
+ * Generate the file trees.h describing the static trees.
316
377
  */
317
378
  #ifdef GEN_TREES_H
318
379
  # ifndef ZLIB_DEBUG
@@ -321,10 +382,9 @@ local void tr_static_init()
321
382
 
322
383
  # define SEPARATOR(i, last, width) \
323
384
  ((i) == (last)? "\n};\n\n" : \
324
- ((i) % (width) == (width)-1 ? ",\n" : ", "))
385
+ ((i) % (width) == (width) - 1 ? ",\n" : ", "))
325
386
 
326
- void gen_trees_header()
327
- {
387
+ void gen_trees_header(void) {
328
388
  FILE *header = fopen("trees.h", "w");
329
389
  int i;
330
390
 
@@ -373,12 +433,26 @@ void gen_trees_header()
373
433
  }
374
434
  #endif /* GEN_TREES_H */
375
435
 
436
+ /* ===========================================================================
437
+ * Initialize a new block.
438
+ */
439
+ local void init_block(deflate_state *s) {
440
+ int n; /* iterates over tree elements */
441
+
442
+ /* Initialize the trees. */
443
+ for (n = 0; n < L_CODES; n++) s->dyn_ltree[n].Freq = 0;
444
+ for (n = 0; n < D_CODES; n++) s->dyn_dtree[n].Freq = 0;
445
+ for (n = 0; n < BL_CODES; n++) s->bl_tree[n].Freq = 0;
446
+
447
+ s->dyn_ltree[END_BLOCK].Freq = 1;
448
+ s->opt_len = s->static_len = 0L;
449
+ s->sym_next = s->matches = 0;
450
+ }
451
+
376
452
  /* ===========================================================================
377
453
  * Initialize the tree data structures for a new zlib stream.
378
454
  */
379
- void ZLIB_INTERNAL _tr_init(s)
380
- deflate_state *s;
381
- {
455
+ void ZLIB_INTERNAL _tr_init(deflate_state *s) {
382
456
  tr_static_init();
383
457
 
384
458
  s->l_desc.dyn_tree = s->dyn_ltree;
@@ -401,24 +475,6 @@ void ZLIB_INTERNAL _tr_init(s)
401
475
  init_block(s);
402
476
  }
403
477
 
404
- /* ===========================================================================
405
- * Initialize a new block.
406
- */
407
- local void init_block(s)
408
- deflate_state *s;
409
- {
410
- int n; /* iterates over tree elements */
411
-
412
- /* Initialize the trees. */
413
- for (n = 0; n < L_CODES; n++) s->dyn_ltree[n].Freq = 0;
414
- for (n = 0; n < D_CODES; n++) s->dyn_dtree[n].Freq = 0;
415
- for (n = 0; n < BL_CODES; n++) s->bl_tree[n].Freq = 0;
416
-
417
- s->dyn_ltree[END_BLOCK].Freq = 1;
418
- s->opt_len = s->static_len = 0L;
419
- s->sym_next = s->matches = 0;
420
- }
421
-
422
478
  #define SMALLEST 1
423
479
  /* Index within the heap array of least frequent node in the Huffman tree */
424
480
 
@@ -448,17 +504,13 @@ local void init_block(s)
448
504
  * when the heap property is re-established (each father smaller than its
449
505
  * two sons).
450
506
  */
451
- local void pqdownheap(s, tree, k)
452
- deflate_state *s;
453
- ct_data *tree; /* the tree to restore */
454
- int k; /* node to move down */
455
- {
507
+ local void pqdownheap(deflate_state *s, ct_data *tree, int k) {
456
508
  int v = s->heap[k];
457
509
  int j = k << 1; /* left son of k */
458
510
  while (j <= s->heap_len) {
459
511
  /* Set j to the smallest of the two sons: */
460
512
  if (j < s->heap_len &&
461
- smaller(tree, s->heap[j+1], s->heap[j], s->depth)) {
513
+ smaller(tree, s->heap[j + 1], s->heap[j], s->depth)) {
462
514
  j++;
463
515
  }
464
516
  /* Exit if v is smaller than both sons */
@@ -483,10 +535,7 @@ local void pqdownheap(s, tree, k)
483
535
  * The length opt_len is updated; static_len is also updated if stree is
484
536
  * not null.
485
537
  */
486
- local void gen_bitlen(s, desc)
487
- deflate_state *s;
488
- tree_desc *desc; /* the tree descriptor */
489
- {
538
+ local void gen_bitlen(deflate_state *s, tree_desc *desc) {
490
539
  ct_data *tree = desc->dyn_tree;
491
540
  int max_code = desc->max_code;
492
541
  const ct_data *stree = desc->stat_desc->static_tree;
@@ -507,7 +556,7 @@ local void gen_bitlen(s, desc)
507
556
  */
508
557
  tree[s->heap[s->heap_max]].Len = 0; /* root of the heap */
509
558
 
510
- for (h = s->heap_max+1; h < HEAP_SIZE; h++) {
559
+ for (h = s->heap_max + 1; h < HEAP_SIZE; h++) {
511
560
  n = s->heap[h];
512
561
  bits = tree[tree[n].Dad].Len + 1;
513
562
  if (bits > max_length) bits = max_length, overflow++;
@@ -518,7 +567,7 @@ local void gen_bitlen(s, desc)
518
567
 
519
568
  s->bl_count[bits]++;
520
569
  xbits = 0;
521
- if (n >= base) xbits = extra[n-base];
570
+ if (n >= base) xbits = extra[n - base];
522
571
  f = tree[n].Freq;
523
572
  s->opt_len += (ulg)f * (unsigned)(bits + xbits);
524
573
  if (stree) s->static_len += (ulg)f * (unsigned)(stree[n].Len + xbits);
@@ -530,10 +579,10 @@ local void gen_bitlen(s, desc)
530
579
 
531
580
  /* Find the first bit length which could increase: */
532
581
  do {
533
- bits = max_length-1;
582
+ bits = max_length - 1;
534
583
  while (s->bl_count[bits] == 0) bits--;
535
- s->bl_count[bits]--; /* move one leaf down the tree */
536
- s->bl_count[bits+1] += 2; /* move one overflow item as its brother */
584
+ s->bl_count[bits]--; /* move one leaf down the tree */
585
+ s->bl_count[bits + 1] += 2; /* move one overflow item as its brother */
537
586
  s->bl_count[max_length]--;
538
587
  /* The brother of the overflow item also moves one step up,
539
588
  * but this does not affect bl_count[max_length]
@@ -561,48 +610,9 @@ local void gen_bitlen(s, desc)
561
610
  }
562
611
  }
563
612
 
564
- /* ===========================================================================
565
- * Generate the codes for a given tree and bit counts (which need not be
566
- * optimal).
567
- * IN assertion: the array bl_count contains the bit length statistics for
568
- * the given tree and the field len is set for all tree elements.
569
- * OUT assertion: the field code is set for all tree elements of non
570
- * zero code length.
571
- */
572
- local void gen_codes (tree, max_code, bl_count)
573
- ct_data *tree; /* the tree to decorate */
574
- int max_code; /* largest code with non zero frequency */
575
- ushf *bl_count; /* number of codes at each bit length */
576
- {
577
- ush next_code[MAX_BITS+1]; /* next code value for each bit length */
578
- unsigned code = 0; /* running code value */
579
- int bits; /* bit index */
580
- int n; /* code index */
581
-
582
- /* The distribution counts are first used to generate the code values
583
- * without bit reversal.
584
- */
585
- for (bits = 1; bits <= MAX_BITS; bits++) {
586
- code = (code + bl_count[bits-1]) << 1;
587
- next_code[bits] = (ush)code;
588
- }
589
- /* Check that the bit counts in bl_count are consistent. The last code
590
- * must be all ones.
591
- */
592
- Assert (code + bl_count[MAX_BITS]-1 == (1<<MAX_BITS)-1,
593
- "inconsistent bit counts");
594
- Tracev((stderr,"\ngen_codes: max_code %d ", max_code));
595
-
596
- for (n = 0; n <= max_code; n++) {
597
- int len = tree[n].Len;
598
- if (len == 0) continue;
599
- /* Now reverse the bits */
600
- tree[n].Code = (ush)bi_reverse(next_code[len]++, len);
601
-
602
- Tracecv(tree != static_ltree, (stderr,"\nn %3d %c l %2d c %4x (%x) ",
603
- n, (isgraph(n) ? n : ' '), len, tree[n].Code, next_code[len]-1));
604
- }
605
- }
613
+ #ifdef DUMP_BL_TREE
614
+ # include <stdio.h>
615
+ #endif
606
616
 
607
617
  /* ===========================================================================
608
618
  * Construct one Huffman tree and assigns the code bit strings and lengths.
@@ -612,10 +622,7 @@ local void gen_codes (tree, max_code, bl_count)
612
622
  * and corresponding code. The length opt_len is updated; static_len is
613
623
  * also updated if stree is not null. The field max_code is set.
614
624
  */
615
- local void build_tree(s, desc)
616
- deflate_state *s;
617
- tree_desc *desc; /* the tree descriptor */
618
- {
625
+ local void build_tree(deflate_state *s, tree_desc *desc) {
619
626
  ct_data *tree = desc->dyn_tree;
620
627
  const ct_data *stree = desc->stat_desc->static_tree;
621
628
  int elems = desc->stat_desc->elems;
@@ -624,7 +631,7 @@ local void build_tree(s, desc)
624
631
  int node; /* new node being created */
625
632
 
626
633
  /* Construct the initial heap, with least frequent element in
627
- * heap[SMALLEST]. The sons of heap[n] are heap[2*n] and heap[2*n+1].
634
+ * heap[SMALLEST]. The sons of heap[n] are heap[2*n] and heap[2*n + 1].
628
635
  * heap[0] is not used.
629
636
  */
630
637
  s->heap_len = 0, s->heap_max = HEAP_SIZE;
@@ -652,7 +659,7 @@ local void build_tree(s, desc)
652
659
  }
653
660
  desc->max_code = max_code;
654
661
 
655
- /* The elements heap[heap_len/2+1 .. heap_len] are leaves of the tree,
662
+ /* The elements heap[heap_len/2 + 1 .. heap_len] are leaves of the tree,
656
663
  * establish sub-heaps of increasing lengths:
657
664
  */
658
665
  for (n = s->heap_len/2; n >= 1; n--) pqdownheap(s, tree, n);
@@ -700,11 +707,7 @@ local void build_tree(s, desc)
700
707
  * Scan a literal or distance tree to determine the frequencies of the codes
701
708
  * in the bit length tree.
702
709
  */
703
- local void scan_tree (s, tree, max_code)
704
- deflate_state *s;
705
- ct_data *tree; /* the tree to be scanned */
706
- int max_code; /* and its largest code of non zero frequency */
707
- {
710
+ local void scan_tree(deflate_state *s, ct_data *tree, int max_code) {
708
711
  int n; /* iterates over all tree elements */
709
712
  int prevlen = -1; /* last emitted length */
710
713
  int curlen; /* length of current code */
@@ -714,10 +717,10 @@ local void scan_tree (s, tree, max_code)
714
717
  int min_count = 4; /* min repeat count */
715
718
 
716
719
  if (nextlen == 0) max_count = 138, min_count = 3;
717
- tree[max_code+1].Len = (ush)0xffff; /* guard */
720
+ tree[max_code + 1].Len = (ush)0xffff; /* guard */
718
721
 
719
722
  for (n = 0; n <= max_code; n++) {
720
- curlen = nextlen; nextlen = tree[n+1].Len;
723
+ curlen = nextlen; nextlen = tree[n + 1].Len;
721
724
  if (++count < max_count && curlen == nextlen) {
722
725
  continue;
723
726
  } else if (count < min_count) {
@@ -745,11 +748,7 @@ local void scan_tree (s, tree, max_code)
745
748
  * Send a literal or distance tree in compressed form, using the codes in
746
749
  * bl_tree.
747
750
  */
748
- local void send_tree (s, tree, max_code)
749
- deflate_state *s;
750
- ct_data *tree; /* the tree to be scanned */
751
- int max_code; /* and its largest code of non zero frequency */
752
- {
751
+ local void send_tree(deflate_state *s, ct_data *tree, int max_code) {
753
752
  int n; /* iterates over all tree elements */
754
753
  int prevlen = -1; /* last emitted length */
755
754
  int curlen; /* length of current code */
@@ -758,11 +757,11 @@ local void send_tree (s, tree, max_code)
758
757
  int max_count = 7; /* max repeat count */
759
758
  int min_count = 4; /* min repeat count */
760
759
 
761
- /* tree[max_code+1].Len = -1; */ /* guard already set */
760
+ /* tree[max_code + 1].Len = -1; */ /* guard already set */
762
761
  if (nextlen == 0) max_count = 138, min_count = 3;
763
762
 
764
763
  for (n = 0; n <= max_code; n++) {
765
- curlen = nextlen; nextlen = tree[n+1].Len;
764
+ curlen = nextlen; nextlen = tree[n + 1].Len;
766
765
  if (++count < max_count && curlen == nextlen) {
767
766
  continue;
768
767
  } else if (count < min_count) {
@@ -773,13 +772,13 @@ local void send_tree (s, tree, max_code)
773
772
  send_code(s, curlen, s->bl_tree); count--;
774
773
  }
775
774
  Assert(count >= 3 && count <= 6, " 3_6?");
776
- send_code(s, REP_3_6, s->bl_tree); send_bits(s, count-3, 2);
775
+ send_code(s, REP_3_6, s->bl_tree); send_bits(s, count - 3, 2);
777
776
 
778
777
  } else if (count <= 10) {
779
- send_code(s, REPZ_3_10, s->bl_tree); send_bits(s, count-3, 3);
778
+ send_code(s, REPZ_3_10, s->bl_tree); send_bits(s, count - 3, 3);
780
779
 
781
780
  } else {
782
- send_code(s, REPZ_11_138, s->bl_tree); send_bits(s, count-11, 7);
781
+ send_code(s, REPZ_11_138, s->bl_tree); send_bits(s, count - 11, 7);
783
782
  }
784
783
  count = 0; prevlen = curlen;
785
784
  if (nextlen == 0) {
@@ -796,9 +795,7 @@ local void send_tree (s, tree, max_code)
796
795
  * Construct the Huffman tree for the bit lengths and return the index in
797
796
  * bl_order of the last bit length code to send.
798
797
  */
799
- local int build_bl_tree(s)
800
- deflate_state *s;
801
- {
798
+ local int build_bl_tree(deflate_state *s) {
802
799
  int max_blindex; /* index of last bit length code of non zero freq */
803
800
 
804
801
  /* Determine the bit length frequencies for literal and distance trees */
@@ -807,8 +804,8 @@ local int build_bl_tree(s)
807
804
 
808
805
  /* Build the bit length tree: */
809
806
  build_tree(s, (tree_desc *)(&(s->bl_desc)));
810
- /* opt_len now includes the length of the tree representations, except
811
- * the lengths of the bit lengths codes and the 5+5+4 bits for the counts.
807
+ /* opt_len now includes the length of the tree representations, except the
808
+ * lengths of the bit lengths codes and the 5 + 5 + 4 bits for the counts.
812
809
  */
813
810
 
814
811
  /* Determine the number of bit length codes to send. The pkzip format
@@ -819,7 +816,7 @@ local int build_bl_tree(s)
819
816
  if (s->bl_tree[bl_order[max_blindex]].Len != 0) break;
820
817
  }
821
818
  /* Update opt_len to include the bit length tree and counts */
822
- s->opt_len += 3*((ulg)max_blindex+1) + 5+5+4;
819
+ s->opt_len += 3*((ulg)max_blindex + 1) + 5 + 5 + 4;
823
820
  Tracev((stderr, "\ndyn trees: dyn %ld, stat %ld",
824
821
  s->opt_len, s->static_len));
825
822
 
@@ -831,42 +828,36 @@ local int build_bl_tree(s)
831
828
  * lengths of the bit length codes, the literal tree and the distance tree.
832
829
  * IN assertion: lcodes >= 257, dcodes >= 1, blcodes >= 4.
833
830
  */
834
- local void send_all_trees(s, lcodes, dcodes, blcodes)
835
- deflate_state *s;
836
- int lcodes, dcodes, blcodes; /* number of codes for each tree */
837
- {
831
+ local void send_all_trees(deflate_state *s, int lcodes, int dcodes,
832
+ int blcodes) {
838
833
  int rank; /* index in bl_order */
839
834
 
840
835
  Assert (lcodes >= 257 && dcodes >= 1 && blcodes >= 4, "not enough codes");
841
836
  Assert (lcodes <= L_CODES && dcodes <= D_CODES && blcodes <= BL_CODES,
842
837
  "too many codes");
843
838
  Tracev((stderr, "\nbl counts: "));
844
- send_bits(s, lcodes-257, 5); /* not +255 as stated in appnote.txt */
845
- send_bits(s, dcodes-1, 5);
846
- send_bits(s, blcodes-4, 4); /* not -3 as stated in appnote.txt */
839
+ send_bits(s, lcodes - 257, 5); /* not +255 as stated in appnote.txt */
840
+ send_bits(s, dcodes - 1, 5);
841
+ send_bits(s, blcodes - 4, 4); /* not -3 as stated in appnote.txt */
847
842
  for (rank = 0; rank < blcodes; rank++) {
848
843
  Tracev((stderr, "\nbl code %2d ", bl_order[rank]));
849
844
  send_bits(s, s->bl_tree[bl_order[rank]].Len, 3);
850
845
  }
851
846
  Tracev((stderr, "\nbl tree: sent %ld", s->bits_sent));
852
847
 
853
- send_tree(s, (ct_data *)s->dyn_ltree, lcodes-1); /* literal tree */
848
+ send_tree(s, (ct_data *)s->dyn_ltree, lcodes - 1); /* literal tree */
854
849
  Tracev((stderr, "\nlit tree: sent %ld", s->bits_sent));
855
850
 
856
- send_tree(s, (ct_data *)s->dyn_dtree, dcodes-1); /* distance tree */
851
+ send_tree(s, (ct_data *)s->dyn_dtree, dcodes - 1); /* distance tree */
857
852
  Tracev((stderr, "\ndist tree: sent %ld", s->bits_sent));
858
853
  }
859
854
 
860
855
  /* ===========================================================================
861
856
  * Send a stored block
862
857
  */
863
- void ZLIB_INTERNAL _tr_stored_block(s, buf, stored_len, last)
864
- deflate_state *s;
865
- charf *buf; /* input block */
866
- ulg stored_len; /* length of input block */
867
- int last; /* one if this is the last block for a file */
868
- {
869
- send_bits(s, (STORED_BLOCK<<1)+last, 3); /* send block type */
858
+ void ZLIB_INTERNAL _tr_stored_block(deflate_state *s, charf *buf,
859
+ ulg stored_len, int last) {
860
+ send_bits(s, (STORED_BLOCK<<1) + last, 3); /* send block type */
870
861
  bi_windup(s); /* align on byte boundary */
871
862
  put_short(s, (ush)stored_len);
872
863
  put_short(s, (ush)~stored_len);
@@ -877,16 +868,14 @@ void ZLIB_INTERNAL _tr_stored_block(s, buf, stored_len, last)
877
868
  s->compressed_len = (s->compressed_len + 3 + 7) & (ulg)~7L;
878
869
  s->compressed_len += (stored_len + 4) << 3;
879
870
  s->bits_sent += 2*16;
880
- s->bits_sent += stored_len<<3;
871
+ s->bits_sent += stored_len << 3;
881
872
  #endif
882
873
  }
883
874
 
884
875
  /* ===========================================================================
885
876
  * Flush the bits in the bit buffer to pending output (leaves at most 7 bits)
886
877
  */
887
- void ZLIB_INTERNAL _tr_flush_bits(s)
888
- deflate_state *s;
889
- {
878
+ void ZLIB_INTERNAL _tr_flush_bits(deflate_state *s) {
890
879
  bi_flush(s);
891
880
  }
892
881
 
@@ -894,9 +883,7 @@ void ZLIB_INTERNAL _tr_flush_bits(s)
894
883
  * Send one empty static block to give enough lookahead for inflate.
895
884
  * This takes 10 bits, of which 7 may remain in the bit buffer.
896
885
  */
897
- void ZLIB_INTERNAL _tr_align(s)
898
- deflate_state *s;
899
- {
886
+ void ZLIB_INTERNAL _tr_align(deflate_state *s) {
900
887
  send_bits(s, STATIC_TREES<<1, 3);
901
888
  send_code(s, END_BLOCK, static_ltree);
902
889
  #ifdef ZLIB_DEBUG
@@ -905,16 +892,108 @@ void ZLIB_INTERNAL _tr_align(s)
905
892
  bi_flush(s);
906
893
  }
907
894
 
895
+ /* ===========================================================================
896
+ * Send the block data compressed using the given Huffman trees
897
+ */
898
+ local void compress_block(deflate_state *s, const ct_data *ltree,
899
+ const ct_data *dtree) {
900
+ unsigned dist; /* distance of matched string */
901
+ int lc; /* match length or unmatched char (if dist == 0) */
902
+ unsigned sx = 0; /* running index in symbol buffers */
903
+ unsigned code; /* the code to send */
904
+ int extra; /* number of extra bits to send */
905
+
906
+ if (s->sym_next != 0) do {
907
+ #ifdef LIT_MEM
908
+ dist = s->d_buf[sx];
909
+ lc = s->l_buf[sx++];
910
+ #else
911
+ dist = s->sym_buf[sx++] & 0xff;
912
+ dist += (unsigned)(s->sym_buf[sx++] & 0xff) << 8;
913
+ lc = s->sym_buf[sx++];
914
+ #endif
915
+ if (dist == 0) {
916
+ send_code(s, lc, ltree); /* send a literal byte */
917
+ Tracecv(isgraph(lc), (stderr," '%c' ", lc));
918
+ } else {
919
+ /* Here, lc is the match length - MIN_MATCH */
920
+ code = _length_code[lc];
921
+ send_code(s, code + LITERALS + 1, ltree); /* send length code */
922
+ extra = extra_lbits[code];
923
+ if (extra != 0) {
924
+ lc -= base_length[code];
925
+ send_bits(s, lc, extra); /* send the extra length bits */
926
+ }
927
+ dist--; /* dist is now the match distance - 1 */
928
+ code = d_code(dist);
929
+ Assert (code < D_CODES, "bad d_code");
930
+
931
+ send_code(s, code, dtree); /* send the distance code */
932
+ extra = extra_dbits[code];
933
+ if (extra != 0) {
934
+ dist -= (unsigned)base_dist[code];
935
+ send_bits(s, dist, extra); /* send the extra distance bits */
936
+ }
937
+ } /* literal or match pair ? */
938
+
939
+ /* Check for no overlay of pending_buf on needed symbols */
940
+ #ifdef LIT_MEM
941
+ Assert(s->pending < 2 * (s->lit_bufsize + sx), "pendingBuf overflow");
942
+ #else
943
+ Assert(s->pending < s->lit_bufsize + sx, "pendingBuf overflow");
944
+ #endif
945
+
946
+ } while (sx < s->sym_next);
947
+
948
+ send_code(s, END_BLOCK, ltree);
949
+ }
950
+
951
+ /* ===========================================================================
952
+ * Check if the data type is TEXT or BINARY, using the following algorithm:
953
+ * - TEXT if the two conditions below are satisfied:
954
+ * a) There are no non-portable control characters belonging to the
955
+ * "block list" (0..6, 14..25, 28..31).
956
+ * b) There is at least one printable character belonging to the
957
+ * "allow list" (9 {TAB}, 10 {LF}, 13 {CR}, 32..255).
958
+ * - BINARY otherwise.
959
+ * - The following partially-portable control characters form a
960
+ * "gray list" that is ignored in this detection algorithm:
961
+ * (7 {BEL}, 8 {BS}, 11 {VT}, 12 {FF}, 26 {SUB}, 27 {ESC}).
962
+ * IN assertion: the fields Freq of dyn_ltree are set.
963
+ */
964
+ local int detect_data_type(deflate_state *s) {
965
+ /* block_mask is the bit mask of block-listed bytes
966
+ * set bits 0..6, 14..25, and 28..31
967
+ * 0xf3ffc07f = binary 11110011111111111100000001111111
968
+ */
969
+ unsigned long block_mask = 0xf3ffc07fUL;
970
+ int n;
971
+
972
+ /* Check for non-textual ("block-listed") bytes. */
973
+ for (n = 0; n <= 31; n++, block_mask >>= 1)
974
+ if ((block_mask & 1) && (s->dyn_ltree[n].Freq != 0))
975
+ return Z_BINARY;
976
+
977
+ /* Check for textual ("allow-listed") bytes. */
978
+ if (s->dyn_ltree[9].Freq != 0 || s->dyn_ltree[10].Freq != 0
979
+ || s->dyn_ltree[13].Freq != 0)
980
+ return Z_TEXT;
981
+ for (n = 32; n < LITERALS; n++)
982
+ if (s->dyn_ltree[n].Freq != 0)
983
+ return Z_TEXT;
984
+
985
+ /* There are no "block-listed" or "allow-listed" bytes:
986
+ * this stream either is empty or has tolerated ("gray-listed") bytes only.
987
+ */
988
+ return Z_BINARY;
989
+ }
990
+
908
991
  /* ===========================================================================
909
992
  * Determine the best encoding for the current block: dynamic trees, static
910
993
  * trees or store, and write out the encoded block.
911
994
  */
912
- void ZLIB_INTERNAL _tr_flush_block(s, buf, stored_len, last)
913
- deflate_state *s;
914
- charf *buf; /* input block, or NULL if too old */
915
- ulg stored_len; /* length of input block */
916
- int last; /* one if this is the last block for a file */
917
- {
995
+ void ZLIB_INTERNAL _tr_flush_block(deflate_state *s, charf *buf,
996
+ ulg stored_len, int last) {
918
997
  ulg opt_lenb, static_lenb; /* opt_len and static_len in bytes */
919
998
  int max_blindex = 0; /* index of last bit length code of non zero freq */
920
999
 
@@ -943,14 +1022,17 @@ void ZLIB_INTERNAL _tr_flush_block(s, buf, stored_len, last)
943
1022
  max_blindex = build_bl_tree(s);
944
1023
 
945
1024
  /* Determine the best encoding. Compute the block lengths in bytes. */
946
- opt_lenb = (s->opt_len+3+7)>>3;
947
- static_lenb = (s->static_len+3+7)>>3;
1025
+ opt_lenb = (s->opt_len + 3 + 7) >> 3;
1026
+ static_lenb = (s->static_len + 3 + 7) >> 3;
948
1027
 
949
1028
  Tracev((stderr, "\nopt %lu(%lu) stat %lu(%lu) stored %lu lit %u ",
950
1029
  opt_lenb, s->opt_len, static_lenb, s->static_len, stored_len,
951
1030
  s->sym_next / 3));
952
1031
 
953
- if (static_lenb <= opt_lenb) opt_lenb = static_lenb;
1032
+ #ifndef FORCE_STATIC
1033
+ if (static_lenb <= opt_lenb || s->strategy == Z_FIXED)
1034
+ #endif
1035
+ opt_lenb = static_lenb;
954
1036
 
955
1037
  } else {
956
1038
  Assert(buf != (char*)0, "lost buf");
@@ -960,7 +1042,7 @@ void ZLIB_INTERNAL _tr_flush_block(s, buf, stored_len, last)
960
1042
  #ifdef FORCE_STORED
961
1043
  if (buf != (char*)0) { /* force stored block */
962
1044
  #else
963
- if (stored_len+4 <= opt_lenb && buf != (char*)0) {
1045
+ if (stored_len + 4 <= opt_lenb && buf != (char*)0) {
964
1046
  /* 4: two words for the lengths */
965
1047
  #endif
966
1048
  /* The test buf != NULL is only necessary if LIT_BUFSIZE > WSIZE.
@@ -971,21 +1053,17 @@ void ZLIB_INTERNAL _tr_flush_block(s, buf, stored_len, last)
971
1053
  */
972
1054
  _tr_stored_block(s, buf, stored_len, last);
973
1055
 
974
- #ifdef FORCE_STATIC
975
- } else if (static_lenb >= 0) { /* force static trees */
976
- #else
977
- } else if (s->strategy == Z_FIXED || static_lenb == opt_lenb) {
978
- #endif
979
- send_bits(s, (STATIC_TREES<<1)+last, 3);
1056
+ } else if (static_lenb == opt_lenb) {
1057
+ send_bits(s, (STATIC_TREES<<1) + last, 3);
980
1058
  compress_block(s, (const ct_data *)static_ltree,
981
1059
  (const ct_data *)static_dtree);
982
1060
  #ifdef ZLIB_DEBUG
983
1061
  s->compressed_len += 3 + s->static_len;
984
1062
  #endif
985
1063
  } else {
986
- send_bits(s, (DYN_TREES<<1)+last, 3);
987
- send_all_trees(s, s->l_desc.max_code+1, s->d_desc.max_code+1,
988
- max_blindex+1);
1064
+ send_bits(s, (DYN_TREES<<1) + last, 3);
1065
+ send_all_trees(s, s->l_desc.max_code + 1, s->d_desc.max_code + 1,
1066
+ max_blindex + 1);
989
1067
  compress_block(s, (const ct_data *)s->dyn_ltree,
990
1068
  (const ct_data *)s->dyn_dtree);
991
1069
  #ifdef ZLIB_DEBUG
@@ -1004,22 +1082,23 @@ void ZLIB_INTERNAL _tr_flush_block(s, buf, stored_len, last)
1004
1082
  s->compressed_len += 7; /* align on byte boundary */
1005
1083
  #endif
1006
1084
  }
1007
- Tracev((stderr,"\ncomprlen %lu(%lu) ", s->compressed_len>>3,
1008
- s->compressed_len-7*last));
1085
+ Tracev((stderr,"\ncomprlen %lu(%lu) ", s->compressed_len >> 3,
1086
+ s->compressed_len - 7*last));
1009
1087
  }
1010
1088
 
1011
1089
  /* ===========================================================================
1012
1090
  * Save the match info and tally the frequency counts. Return true if
1013
1091
  * the current block must be flushed.
1014
1092
  */
1015
- int ZLIB_INTERNAL _tr_tally (s, dist, lc)
1016
- deflate_state *s;
1017
- unsigned dist; /* distance of matched string */
1018
- unsigned lc; /* match length-MIN_MATCH or unmatched char (if dist==0) */
1019
- {
1020
- s->sym_buf[s->sym_next++] = dist;
1021
- s->sym_buf[s->sym_next++] = dist >> 8;
1022
- s->sym_buf[s->sym_next++] = lc;
1093
+ int ZLIB_INTERNAL _tr_tally(deflate_state *s, unsigned dist, unsigned lc) {
1094
+ #ifdef LIT_MEM
1095
+ s->d_buf[s->sym_next] = (ush)dist;
1096
+ s->l_buf[s->sym_next++] = (uch)lc;
1097
+ #else
1098
+ s->sym_buf[s->sym_next++] = (uch)dist;
1099
+ s->sym_buf[s->sym_next++] = (uch)(dist >> 8);
1100
+ s->sym_buf[s->sym_next++] = (uch)lc;
1101
+ #endif
1023
1102
  if (dist == 0) {
1024
1103
  /* lc is the unmatched char */
1025
1104
  s->dyn_ltree[lc].Freq++;
@@ -1031,152 +1110,8 @@ int ZLIB_INTERNAL _tr_tally (s, dist, lc)
1031
1110
  (ush)lc <= (ush)(MAX_MATCH-MIN_MATCH) &&
1032
1111
  (ush)d_code(dist) < (ush)D_CODES, "_tr_tally: bad match");
1033
1112
 
1034
- s->dyn_ltree[_length_code[lc]+LITERALS+1].Freq++;
1113
+ s->dyn_ltree[_length_code[lc] + LITERALS + 1].Freq++;
1035
1114
  s->dyn_dtree[d_code(dist)].Freq++;
1036
1115
  }
1037
1116
  return (s->sym_next == s->sym_end);
1038
1117
  }
1039
-
1040
- /* ===========================================================================
1041
- * Send the block data compressed using the given Huffman trees
1042
- */
1043
- local void compress_block(s, ltree, dtree)
1044
- deflate_state *s;
1045
- const ct_data *ltree; /* literal tree */
1046
- const ct_data *dtree; /* distance tree */
1047
- {
1048
- unsigned dist; /* distance of matched string */
1049
- int lc; /* match length or unmatched char (if dist == 0) */
1050
- unsigned sx = 0; /* running index in sym_buf */
1051
- unsigned code; /* the code to send */
1052
- int extra; /* number of extra bits to send */
1053
-
1054
- if (s->sym_next != 0) do {
1055
- dist = s->sym_buf[sx++] & 0xff;
1056
- dist += (unsigned)(s->sym_buf[sx++] & 0xff) << 8;
1057
- lc = s->sym_buf[sx++];
1058
- if (dist == 0) {
1059
- send_code(s, lc, ltree); /* send a literal byte */
1060
- Tracecv(isgraph(lc), (stderr," '%c' ", lc));
1061
- } else {
1062
- /* Here, lc is the match length - MIN_MATCH */
1063
- code = _length_code[lc];
1064
- send_code(s, code+LITERALS+1, ltree); /* send the length code */
1065
- extra = extra_lbits[code];
1066
- if (extra != 0) {
1067
- lc -= base_length[code];
1068
- send_bits(s, lc, extra); /* send the extra length bits */
1069
- }
1070
- dist--; /* dist is now the match distance - 1 */
1071
- code = d_code(dist);
1072
- Assert (code < D_CODES, "bad d_code");
1073
-
1074
- send_code(s, code, dtree); /* send the distance code */
1075
- extra = extra_dbits[code];
1076
- if (extra != 0) {
1077
- dist -= (unsigned)base_dist[code];
1078
- send_bits(s, dist, extra); /* send the extra distance bits */
1079
- }
1080
- } /* literal or match pair ? */
1081
-
1082
- /* Check that the overlay between pending_buf and sym_buf is ok: */
1083
- Assert(s->pending < s->lit_bufsize + sx, "pendingBuf overflow");
1084
-
1085
- } while (sx < s->sym_next);
1086
-
1087
- send_code(s, END_BLOCK, ltree);
1088
- }
1089
-
1090
- /* ===========================================================================
1091
- * Check if the data type is TEXT or BINARY, using the following algorithm:
1092
- * - TEXT if the two conditions below are satisfied:
1093
- * a) There are no non-portable control characters belonging to the
1094
- * "block list" (0..6, 14..25, 28..31).
1095
- * b) There is at least one printable character belonging to the
1096
- * "allow list" (9 {TAB}, 10 {LF}, 13 {CR}, 32..255).
1097
- * - BINARY otherwise.
1098
- * - The following partially-portable control characters form a
1099
- * "gray list" that is ignored in this detection algorithm:
1100
- * (7 {BEL}, 8 {BS}, 11 {VT}, 12 {FF}, 26 {SUB}, 27 {ESC}).
1101
- * IN assertion: the fields Freq of dyn_ltree are set.
1102
- */
1103
- local int detect_data_type(s)
1104
- deflate_state *s;
1105
- {
1106
- /* block_mask is the bit mask of block-listed bytes
1107
- * set bits 0..6, 14..25, and 28..31
1108
- * 0xf3ffc07f = binary 11110011111111111100000001111111
1109
- */
1110
- unsigned long block_mask = 0xf3ffc07fUL;
1111
- int n;
1112
-
1113
- /* Check for non-textual ("block-listed") bytes. */
1114
- for (n = 0; n <= 31; n++, block_mask >>= 1)
1115
- if ((block_mask & 1) && (s->dyn_ltree[n].Freq != 0))
1116
- return Z_BINARY;
1117
-
1118
- /* Check for textual ("allow-listed") bytes. */
1119
- if (s->dyn_ltree[9].Freq != 0 || s->dyn_ltree[10].Freq != 0
1120
- || s->dyn_ltree[13].Freq != 0)
1121
- return Z_TEXT;
1122
- for (n = 32; n < LITERALS; n++)
1123
- if (s->dyn_ltree[n].Freq != 0)
1124
- return Z_TEXT;
1125
-
1126
- /* There are no "block-listed" or "allow-listed" bytes:
1127
- * this stream either is empty or has tolerated ("gray-listed") bytes only.
1128
- */
1129
- return Z_BINARY;
1130
- }
1131
-
1132
- /* ===========================================================================
1133
- * Reverse the first len bits of a code, using straightforward code (a faster
1134
- * method would use a table)
1135
- * IN assertion: 1 <= len <= 15
1136
- */
1137
- local unsigned bi_reverse(code, len)
1138
- unsigned code; /* the value to invert */
1139
- int len; /* its bit length */
1140
- {
1141
- register unsigned res = 0;
1142
- do {
1143
- res |= code & 1;
1144
- code >>= 1, res <<= 1;
1145
- } while (--len > 0);
1146
- return res >> 1;
1147
- }
1148
-
1149
- /* ===========================================================================
1150
- * Flush the bit buffer, keeping at most 7 bits in it.
1151
- */
1152
- local void bi_flush(s)
1153
- deflate_state *s;
1154
- {
1155
- if (s->bi_valid == 16) {
1156
- put_short(s, s->bi_buf);
1157
- s->bi_buf = 0;
1158
- s->bi_valid = 0;
1159
- } else if (s->bi_valid >= 8) {
1160
- put_byte(s, (Byte)s->bi_buf);
1161
- s->bi_buf >>= 8;
1162
- s->bi_valid -= 8;
1163
- }
1164
- }
1165
-
1166
- /* ===========================================================================
1167
- * Flush the bit buffer and align the output on a byte boundary
1168
- */
1169
- local void bi_windup(s)
1170
- deflate_state *s;
1171
- {
1172
- if (s->bi_valid > 8) {
1173
- put_short(s, s->bi_buf);
1174
- } else if (s->bi_valid > 0) {
1175
- put_byte(s, (Byte)s->bi_buf);
1176
- }
1177
- s->bi_buf = 0;
1178
- s->bi_valid = 0;
1179
- #ifdef ZLIB_DEBUG
1180
- s->bits_sent = (s->bits_sent+7) & ~7;
1181
- #endif
1182
- }