Coverage Report

Created: 2026-05-16 06:53

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/rust/registry/src/index.crates.io-1949cf8c6b5b557f/bzip2-sys-0.1.13+1.0.8/bzip2-1.0.8/compress.c
Line
Count
Source
1
2
/*-------------------------------------------------------------*/
3
/*--- Compression machinery (not incl block sorting)        ---*/
4
/*---                                            compress.c ---*/
5
/*-------------------------------------------------------------*/
6
7
/* ------------------------------------------------------------------
8
   This file is part of bzip2/libbzip2, a program and library for
9
   lossless, block-sorting data compression.
10
11
   bzip2/libbzip2 version 1.0.8 of 13 July 2019
12
   Copyright (C) 1996-2019 Julian Seward <jseward@acm.org>
13
14
   Please read the WARNING, DISCLAIMER and PATENTS sections in the 
15
   README file.
16
17
   This program is released under the terms of the license contained
18
   in the file LICENSE.
19
   ------------------------------------------------------------------ */
20
21
22
/* CHANGES
23
    0.9.0    -- original version.
24
    0.9.0a/b -- no changes in this file.
25
    0.9.0c   -- changed setting of nGroups in sendMTFValues() 
26
                so as to do a bit better on small files
27
*/
28
29
#include "bzlib_private.h"
30
31
32
/*---------------------------------------------------*/
33
/*--- Bit stream I/O                              ---*/
34
/*---------------------------------------------------*/
35
36
/*---------------------------------------------------*/
37
void BZ2_bsInitWrite ( EState* s )
38
3.76k
{
39
3.76k
   s->bsLive = 0;
40
3.76k
   s->bsBuff = 0;
41
3.76k
}
42
43
44
/*---------------------------------------------------*/
45
static
46
void bsFinishWrite ( EState* s )
47
3.76k
{
48
10.7k
   while (s->bsLive > 0) {
49
6.99k
      s->zbits[s->numZ] = (UChar)(s->bsBuff >> 24);
50
6.99k
      s->numZ++;
51
6.99k
      s->bsBuff <<= 8;
52
6.99k
      s->bsLive -= 8;
53
6.99k
   }
54
3.76k
}
55
56
57
/*---------------------------------------------------*/
58
2.15M
#define bsNEEDW(nz)                           \
59
2.15M
{                                             \
60
2.79M
   while (s->bsLive >= 8) {                   \
61
644k
      s->zbits[s->numZ]                       \
62
644k
         = (UChar)(s->bsBuff >> 24);          \
63
644k
      s->numZ++;                              \
64
644k
      s->bsBuff <<= 8;                        \
65
644k
      s->bsLive -= 8;                         \
66
644k
   }                                          \
67
2.15M
}
68
69
70
/*---------------------------------------------------*/
71
static
72
__inline__
73
void bsW ( EState* s, Int32 n, UInt32 v )
74
2.15M
{
75
2.15M
   bsNEEDW ( n );
76
2.15M
   s->bsBuff |= (v << (32 - s->bsLive - n));
77
2.15M
   s->bsLive += n;
78
2.15M
}
79
80
81
/*---------------------------------------------------*/
82
static
83
void bsPutUInt32 ( EState* s, UInt32 u )
84
7.55k
{
85
7.55k
   bsW ( s, 8, (u >> 24) & 0xffL );
86
7.55k
   bsW ( s, 8, (u >> 16) & 0xffL );
87
7.55k
   bsW ( s, 8, (u >>  8) & 0xffL );
88
7.55k
   bsW ( s, 8,  u        & 0xffL );
89
7.55k
}
90
91
92
/*---------------------------------------------------*/
93
static
94
void bsPutUChar ( EState* s, UChar c )
95
60.4k
{
96
60.4k
   bsW( s, 8, (UInt32)c );
97
60.4k
}
98
99
100
/*---------------------------------------------------*/
101
/*--- The back end proper                         ---*/
102
/*---------------------------------------------------*/
103
104
/*---------------------------------------------------*/
105
static
106
void makeMaps_e ( EState* s )
107
3.79k
{
108
3.79k
   Int32 i;
109
3.79k
   s->nInUse = 0;
110
975k
   for (i = 0; i < 256; i++)
111
971k
      if (s->inUse[i]) {
112
86.2k
         s->unseqToSeq[i] = s->nInUse;
113
86.2k
         s->nInUse++;
114
86.2k
      }
115
3.79k
}
116
117
118
/*---------------------------------------------------*/
119
static
120
void generateMTFValues ( EState* s )
121
3.79k
{
122
3.79k
   UChar   yy[256];
123
3.79k
   Int32   i, j;
124
3.79k
   Int32   zPend;
125
3.79k
   Int32   wr;
126
3.79k
   Int32   EOB;
127
128
   /* 
129
      After sorting (eg, here),
130
         s->arr1 [ 0 .. s->nblock-1 ] holds sorted order,
131
         and
132
         ((UChar*)s->arr2) [ 0 .. s->nblock-1 ] 
133
         holds the original block data.
134
135
      The first thing to do is generate the MTF values,
136
      and put them in
137
         ((UInt16*)s->arr1) [ 0 .. s->nblock-1 ].
138
      Because there are strictly fewer or equal MTF values
139
      than block values, ptr values in this area are overwritten
140
      with MTF values only when they are no longer needed.
141
142
      The final compressed bitstream is generated into the
143
      area starting at
144
         (UChar*) (&((UChar*)s->arr2)[s->nblock])
145
146
      These storage aliases are set up in bzCompressInit(),
147
      except for the last one, which is arranged in 
148
      compressBlock().
149
   */
150
3.79k
   UInt32* ptr   = s->ptr;
151
3.79k
   UChar* block  = s->block;
152
3.79k
   UInt16* mtfv  = s->mtfv;
153
154
3.79k
   makeMaps_e ( s );
155
3.79k
   EOB = s->nInUse+1;
156
157
97.6k
   for (i = 0; i <= EOB; i++) s->mtfFreq[i] = 0;
158
159
3.79k
   wr = 0;
160
3.79k
   zPend = 0;
161
90.0k
   for (i = 0; i < s->nInUse; i++) yy[i] = (UChar) i;
162
163
14.9M
   for (i = 0; i < s->nblock; i++) {
164
14.9M
      UChar ll_i;
165
14.9M
      AssertD ( wr <= i, "generateMTFValues(1)" );
166
14.9M
      j = ptr[i]-1; if (j < 0) j += s->nblock;
167
14.9M
      ll_i = s->unseqToSeq[block[j]];
168
14.9M
      AssertD ( ll_i < s->nInUse, "generateMTFValues(2a)" );
169
170
14.9M
      if (yy[0] == ll_i) { 
171
14.5M
         zPend++;
172
14.5M
      } else {
173
174
360k
         if (zPend > 0) {
175
214k
            zPend--;
176
686k
            while (True) {
177
686k
               if (zPend & 1) {
178
295k
                  mtfv[wr] = BZ_RUNB; wr++; 
179
295k
                  s->mtfFreq[BZ_RUNB]++; 
180
390k
               } else {
181
390k
                  mtfv[wr] = BZ_RUNA; wr++; 
182
390k
                  s->mtfFreq[BZ_RUNA]++; 
183
390k
               }
184
686k
               if (zPend < 2) break;
185
471k
               zPend = (zPend - 2) / 2;
186
471k
            };
187
214k
            zPend = 0;
188
214k
         }
189
360k
         {
190
360k
            register UChar  rtmp;
191
360k
            register UChar* ryy_j;
192
360k
            register UChar  rll_i;
193
360k
            rtmp  = yy[1];
194
360k
            yy[1] = yy[0];
195
360k
            ryy_j = &(yy[1]);
196
360k
            rll_i = ll_i;
197
4.91M
            while ( rll_i != rtmp ) {
198
4.55M
               register UChar rtmp2;
199
4.55M
               ryy_j++;
200
4.55M
               rtmp2  = rtmp;
201
4.55M
               rtmp   = *ryy_j;
202
4.55M
               *ryy_j = rtmp2;
203
4.55M
            };
204
360k
            yy[0] = rtmp;
205
360k
            j = ryy_j - &(yy[0]);
206
360k
            mtfv[wr] = j+1; wr++; s->mtfFreq[j+1]++;
207
360k
         }
208
209
360k
      }
210
14.9M
   }
211
212
3.79k
   if (zPend > 0) {
213
1.05k
      zPend--;
214
1.98k
      while (True) {
215
1.98k
         if (zPend & 1) {
216
769
            mtfv[wr] = BZ_RUNB; wr++; 
217
769
            s->mtfFreq[BZ_RUNB]++; 
218
1.21k
         } else {
219
1.21k
            mtfv[wr] = BZ_RUNA; wr++; 
220
1.21k
            s->mtfFreq[BZ_RUNA]++; 
221
1.21k
         }
222
1.98k
         if (zPend < 2) break;
223
927
         zPend = (zPend - 2) / 2;
224
927
      };
225
1.05k
      zPend = 0;
226
1.05k
   }
227
228
3.79k
   mtfv[wr] = EOB; wr++; s->mtfFreq[EOB]++;
229
230
3.79k
   s->nMTF = wr;
231
3.79k
}
232
233
234
/*---------------------------------------------------*/
235
93.8k
#define BZ_LESSER_ICOST  0
236
764k
#define BZ_GREATER_ICOST 15
237
238
static
239
void sendMTFValues ( EState* s )
240
3.79k
{
241
3.79k
   Int32 v, t, i, j, gs, ge, totc, bt, bc, iter;
242
3.79k
   Int32 nSelectors, alphaSize, minLen, maxLen, selCtr;
243
3.79k
   Int32 nGroups, nBytes;
244
245
   /*--
246
   UChar  len [BZ_N_GROUPS][BZ_MAX_ALPHA_SIZE];
247
   is a global since the decoder also needs it.
248
249
   Int32  code[BZ_N_GROUPS][BZ_MAX_ALPHA_SIZE];
250
   Int32  rfreq[BZ_N_GROUPS][BZ_MAX_ALPHA_SIZE];
251
   are also globals only used in this proc.
252
   Made global to keep stack frame size small.
253
   --*/
254
255
256
3.79k
   UInt16 cost[BZ_N_GROUPS];
257
3.79k
   Int32  fave[BZ_N_GROUPS];
258
259
3.79k
   UInt16* mtfv = s->mtfv;
260
261
3.79k
   if (s->verbosity >= 3)
262
0
      VPrintf3( "      %d in block, %d after MTF & 1-2 coding, "
263
3.79k
                "%d+2 syms in use\n", 
264
3.79k
                s->nblock, s->nMTF, s->nInUse );
265
266
3.79k
   alphaSize = s->nInUse+2;
267
26.5k
   for (t = 0; t < BZ_N_GROUPS; t++)
268
586k
      for (v = 0; v < alphaSize; v++)
269
563k
         s->len[t][v] = BZ_GREATER_ICOST;
270
271
   /*--- Decide how many coding tables to use ---*/
272
3.79k
   AssertH ( s->nMTF > 0, 3001 );
273
3.79k
   if (s->nMTF < 200)  nGroups = 2; else
274
879
   if (s->nMTF < 600)  nGroups = 3; else
275
443
   if (s->nMTF < 1200) nGroups = 4; else
276
264
   if (s->nMTF < 2400) nGroups = 5; else
277
156
                       nGroups = 6;
278
279
   /*--- Generate an initial set of coding tables ---*/
280
3.79k
   { 
281
3.79k
      Int32 nPart, remF, tFreq, aFreq;
282
283
3.79k
      nPart = nGroups;
284
3.79k
      remF  = s->nMTF;
285
3.79k
      gs = 0;
286
13.1k
      while (nPart > 0) {
287
9.33k
         tFreq = remF / nPart;
288
9.33k
         ge = gs-1;
289
9.33k
         aFreq = 0;
290
103k
         while (aFreq < tFreq && ge < alphaSize-1) {
291
94.4k
            ge++;
292
94.4k
            aFreq += s->mtfFreq[ge];
293
94.4k
         }
294
295
9.33k
         if (ge > gs 
296
7.65k
             && nPart != nGroups && nPart != 1 
297
1.01k
             && ((nGroups-nPart) % 2 == 1)) {
298
584
            aFreq -= s->mtfFreq[ge];
299
584
            ge--;
300
584
         }
301
302
9.33k
         if (s->verbosity >= 3)
303
0
            VPrintf5( "      initial group %d, [%d .. %d], "
304
9.33k
                      "has %d syms (%4.1f%%)\n",
305
9.33k
                      nPart, gs, ge, aFreq, 
306
9.33k
                      (100.0 * (float)aFreq) / (float)(s->nMTF) );
307
 
308
304k
         for (v = 0; v < alphaSize; v++)
309
294k
            if (v >= gs && v <= ge) 
310
93.8k
               s->len[nPart-1][v] = BZ_LESSER_ICOST; else
311
200k
               s->len[nPart-1][v] = BZ_GREATER_ICOST;
312
 
313
9.33k
         nPart--;
314
9.33k
         gs = ge+1;
315
9.33k
         remF -= aFreq;
316
9.33k
      }
317
3.79k
   }
318
319
   /*--- 
320
      Iterate up to BZ_N_ITERS times to improve the tables.
321
   ---*/
322
18.9k
   for (iter = 0; iter < BZ_N_ITERS; iter++) {
323
324
52.5k
      for (t = 0; t < nGroups; t++) fave[t] = 0;
325
326
52.5k
      for (t = 0; t < nGroups; t++)
327
1.21M
         for (v = 0; v < alphaSize; v++)
328
1.17M
            s->rfreq[t][v] = 0;
329
330
      /*---
331
        Set up an auxiliary length table which is used to fast-track
332
  the common case (nGroups == 6). 
333
      ---*/
334
15.1k
      if (nGroups == 6) {
335
51.6k
         for (v = 0; v < alphaSize; v++) {
336
51.0k
            s->len_pack[v][0] = (s->len[1][v] << 16) | s->len[0][v];
337
51.0k
            s->len_pack[v][1] = (s->len[3][v] << 16) | s->len[2][v];
338
51.0k
            s->len_pack[v][2] = (s->len[5][v] << 16) | s->len[4][v];
339
51.0k
   }
340
624
      }
341
342
15.1k
      nSelectors = 0;
343
15.1k
      totc = 0;
344
15.1k
      gs = 0;
345
108k
      while (True) {
346
347
         /*--- Set group start & end marks. --*/
348
108k
         if (gs >= s->nMTF) break;
349
93.1k
         ge = gs + BZ_G_SIZE - 1; 
350
93.1k
         if (ge >= s->nMTF) ge = s->nMTF-1;
351
352
         /*-- 
353
            Calculate the cost of this group as coded
354
            by each of the coding tables.
355
         --*/
356
500k
         for (t = 0; t < nGroups; t++) cost[t] = 0;
357
358
93.1k
         if (nGroups == 6 && 50 == ge-gs+1) {
359
            /*--- fast track the common case ---*/
360
34.7k
            register UInt32 cost01, cost23, cost45;
361
34.7k
            register UInt16 icv;
362
34.7k
            cost01 = cost23 = cost45 = 0;
363
364
34.7k
#           define BZ_ITER(nn)                \
365
1.73M
               icv = mtfv[gs+(nn)];           \
366
1.73M
               cost01 += s->len_pack[icv][0]; \
367
1.73M
               cost23 += s->len_pack[icv][1]; \
368
1.73M
               cost45 += s->len_pack[icv][2]; \
369
34.7k
370
34.7k
            BZ_ITER(0);  BZ_ITER(1);  BZ_ITER(2);  BZ_ITER(3);  BZ_ITER(4);
371
34.7k
            BZ_ITER(5);  BZ_ITER(6);  BZ_ITER(7);  BZ_ITER(8);  BZ_ITER(9);
372
34.7k
            BZ_ITER(10); BZ_ITER(11); BZ_ITER(12); BZ_ITER(13); BZ_ITER(14);
373
34.7k
            BZ_ITER(15); BZ_ITER(16); BZ_ITER(17); BZ_ITER(18); BZ_ITER(19);
374
34.7k
            BZ_ITER(20); BZ_ITER(21); BZ_ITER(22); BZ_ITER(23); BZ_ITER(24);
375
34.7k
            BZ_ITER(25); BZ_ITER(26); BZ_ITER(27); BZ_ITER(28); BZ_ITER(29);
376
34.7k
            BZ_ITER(30); BZ_ITER(31); BZ_ITER(32); BZ_ITER(33); BZ_ITER(34);
377
34.7k
            BZ_ITER(35); BZ_ITER(36); BZ_ITER(37); BZ_ITER(38); BZ_ITER(39);
378
34.7k
            BZ_ITER(40); BZ_ITER(41); BZ_ITER(42); BZ_ITER(43); BZ_ITER(44);
379
34.7k
            BZ_ITER(45); BZ_ITER(46); BZ_ITER(47); BZ_ITER(48); BZ_ITER(49);
380
381
34.7k
#           undef BZ_ITER
382
383
34.7k
            cost[0] = cost01 & 0xffff; cost[1] = cost01 >> 16;
384
34.7k
            cost[2] = cost23 & 0xffff; cost[3] = cost23 >> 16;
385
34.7k
            cost[4] = cost45 & 0xffff; cost[5] = cost45 >> 16;
386
387
58.3k
         } else {
388
      /*--- slow version which correctly handles all situations ---*/
389
2.52M
            for (i = gs; i <= ge; i++) { 
390
2.47M
               UInt16 icv = mtfv[i];
391
11.3M
               for (t = 0; t < nGroups; t++) cost[t] += s->len[t][icv];
392
2.47M
            }
393
58.3k
         }
394
 
395
         /*-- 
396
            Find the coding table which is best for this group,
397
            and record its identity in the selector table.
398
         --*/
399
93.1k
         bc = 999999999; bt = -1;
400
500k
         for (t = 0; t < nGroups; t++)
401
407k
            if (cost[t] < bc) { bc = cost[t]; bt = t; };
402
93.1k
         totc += bc;
403
93.1k
         fave[bt]++;
404
93.1k
         s->selector[nSelectors] = bt;
405
93.1k
         nSelectors++;
406
407
         /*-- 
408
            Increment the symbol frequencies for the selected table.
409
          --*/
410
93.1k
         if (nGroups == 6 && 50 == ge-gs+1) {
411
            /*--- fast track the common case ---*/
412
413
1.73M
#           define BZ_ITUR(nn) s->rfreq[bt][ mtfv[gs+(nn)] ]++
414
415
34.7k
            BZ_ITUR(0);  BZ_ITUR(1);  BZ_ITUR(2);  BZ_ITUR(3);  BZ_ITUR(4);
416
34.7k
            BZ_ITUR(5);  BZ_ITUR(6);  BZ_ITUR(7);  BZ_ITUR(8);  BZ_ITUR(9);
417
34.7k
            BZ_ITUR(10); BZ_ITUR(11); BZ_ITUR(12); BZ_ITUR(13); BZ_ITUR(14);
418
34.7k
            BZ_ITUR(15); BZ_ITUR(16); BZ_ITUR(17); BZ_ITUR(18); BZ_ITUR(19);
419
34.7k
            BZ_ITUR(20); BZ_ITUR(21); BZ_ITUR(22); BZ_ITUR(23); BZ_ITUR(24);
420
34.7k
            BZ_ITUR(25); BZ_ITUR(26); BZ_ITUR(27); BZ_ITUR(28); BZ_ITUR(29);
421
34.7k
            BZ_ITUR(30); BZ_ITUR(31); BZ_ITUR(32); BZ_ITUR(33); BZ_ITUR(34);
422
34.7k
            BZ_ITUR(35); BZ_ITUR(36); BZ_ITUR(37); BZ_ITUR(38); BZ_ITUR(39);
423
34.7k
            BZ_ITUR(40); BZ_ITUR(41); BZ_ITUR(42); BZ_ITUR(43); BZ_ITUR(44);
424
34.7k
            BZ_ITUR(45); BZ_ITUR(46); BZ_ITUR(47); BZ_ITUR(48); BZ_ITUR(49);
425
426
34.7k
#           undef BZ_ITUR
427
428
58.3k
         } else {
429
      /*--- slow version which correctly handles all situations ---*/
430
2.52M
            for (i = gs; i <= ge; i++)
431
2.47M
               s->rfreq[bt][ mtfv[i] ]++;
432
58.3k
         }
433
434
93.1k
         gs = ge+1;
435
93.1k
      }
436
15.1k
      if (s->verbosity >= 3) {
437
0
         VPrintf2 ( "      pass %d: size is %d, grp uses are ", 
438
0
                   iter+1, totc/8 );
439
0
         for (t = 0; t < nGroups; t++)
440
0
            VPrintf1 ( "%d ", fave[t] );
441
0
         VPrintf0 ( "\n" );
442
0
      }
443
444
      /*--
445
        Recompute the tables based on the accumulated frequencies.
446
      --*/
447
      /* maxLen was changed from 20 to 17 in bzip2-1.0.3.  See 
448
         comment in huffman.c for details. */
449
52.5k
      for (t = 0; t < nGroups; t++)
450
37.3k
         BZ2_hbMakeCodeLengths ( &(s->len[t][0]), &(s->rfreq[t][0]), 
451
37.3k
                                 alphaSize, 17 /*20*/ );
452
15.1k
   }
453
454
455
3.79k
   AssertH( nGroups < 8, 3002 );
456
3.79k
   AssertH( nSelectors < 32768 &&
457
3.79k
            nSelectors <= BZ_MAX_SELECTORS,
458
3.79k
            3003 );
459
460
461
   /*--- Compute MTF values for the selectors. ---*/
462
3.79k
   {
463
3.79k
      UChar pos[BZ_N_GROUPS], ll_i, tmp2, tmp;
464
13.1k
      for (i = 0; i < nGroups; i++) pos[i] = i;
465
27.0k
      for (i = 0; i < nSelectors; i++) {
466
23.2k
         ll_i = s->selector[i];
467
23.2k
         j = 0;
468
23.2k
         tmp = pos[j];
469
35.8k
         while ( ll_i != tmp ) {
470
12.5k
            j++;
471
12.5k
            tmp2 = tmp;
472
12.5k
            tmp = pos[j];
473
12.5k
            pos[j] = tmp2;
474
12.5k
         };
475
23.2k
         pos[0] = tmp;
476
23.2k
         s->selectorMtf[i] = j;
477
23.2k
      }
478
3.79k
   };
479
480
   /*--- Assign actual codes for the tables. --*/
481
13.1k
   for (t = 0; t < nGroups; t++) {
482
9.33k
      minLen = 32;
483
9.33k
      maxLen = 0;
484
304k
      for (i = 0; i < alphaSize; i++) {
485
294k
         if (s->len[t][i] > maxLen) maxLen = s->len[t][i];
486
294k
         if (s->len[t][i] < minLen) minLen = s->len[t][i];
487
294k
      }
488
9.33k
      AssertH ( !(maxLen > 17 /*20*/ ), 3004 );
489
9.33k
      AssertH ( !(minLen < 1),  3005 );
490
9.33k
      BZ2_hbAssignCodes ( &(s->code[t][0]), &(s->len[t][0]), 
491
9.33k
                          minLen, maxLen, alphaSize );
492
9.33k
   }
493
494
   /*--- Transmit the mapping table. ---*/
495
3.79k
   { 
496
3.79k
      Bool inUse16[16];
497
64.5k
      for (i = 0; i < 16; i++) {
498
60.7k
          inUse16[i] = False;
499
1.03M
          for (j = 0; j < 16; j++)
500
971k
             if (s->inUse[i * 16 + j]) inUse16[i] = True;
501
60.7k
      }
502
     
503
3.79k
      nBytes = s->numZ;
504
64.5k
      for (i = 0; i < 16; i++)
505
60.7k
         if (inUse16[i]) bsW(s,1,1); else bsW(s,1,0);
506
507
64.5k
      for (i = 0; i < 16; i++)
508
60.7k
         if (inUse16[i])
509
486k
            for (j = 0; j < 16; j++) {
510
458k
               if (s->inUse[i * 16 + j]) bsW(s,1,1); else bsW(s,1,0);
511
458k
            }
512
513
3.79k
      if (s->verbosity >= 3) 
514
0
         VPrintf1( "      bytes: mapping %d, ", s->numZ-nBytes );
515
3.79k
   }
516
517
   /*--- Now the selectors. ---*/
518
3.79k
   nBytes = s->numZ;
519
3.79k
   bsW ( s, 3, nGroups );
520
3.79k
   bsW ( s, 15, nSelectors );
521
27.0k
   for (i = 0; i < nSelectors; i++) { 
522
35.8k
      for (j = 0; j < s->selectorMtf[i]; j++) bsW(s,1,1);
523
23.2k
      bsW(s,1,0);
524
23.2k
   }
525
3.79k
   if (s->verbosity >= 3)
526
0
      VPrintf1( "selectors %d, ", s->numZ-nBytes );
527
528
   /*--- Now the coding tables. ---*/
529
3.79k
   nBytes = s->numZ;
530
531
13.1k
   for (t = 0; t < nGroups; t++) {
532
9.33k
      Int32 curr = s->len[t][0];
533
9.33k
      bsW ( s, 5, curr );
534
304k
      for (i = 0; i < alphaSize; i++) {
535
370k
         while (curr < s->len[t][i]) { bsW(s,2,2); curr++; /* 10 */ };
536
354k
         while (curr > s->len[t][i]) { bsW(s,2,3); curr--; /* 11 */ };
537
294k
         bsW ( s, 1, 0 );
538
294k
      }
539
9.33k
   }
540
541
3.79k
   if (s->verbosity >= 3)
542
0
      VPrintf1 ( "code lengths %d, ", s->numZ-nBytes );
543
544
   /*--- And finally, the block data proper ---*/
545
3.79k
   nBytes = s->numZ;
546
3.79k
   selCtr = 0;
547
3.79k
   gs = 0;
548
27.0k
   while (True) {
549
27.0k
      if (gs >= s->nMTF) break;
550
23.2k
      ge = gs + BZ_G_SIZE - 1; 
551
23.2k
      if (ge >= s->nMTF) ge = s->nMTF-1;
552
23.2k
      AssertH ( s->selector[selCtr] < nGroups, 3006 );
553
554
23.2k
      if (nGroups == 6 && 50 == ge-gs+1) {
555
            /*--- fast track the common case ---*/
556
8.69k
            UInt16 mtfv_i;
557
8.69k
            UChar* s_len_sel_selCtr 
558
8.69k
               = &(s->len[s->selector[selCtr]][0]);
559
8.69k
            Int32* s_code_sel_selCtr
560
8.69k
               = &(s->code[s->selector[selCtr]][0]);
561
562
8.69k
#           define BZ_ITAH(nn)                      \
563
434k
               mtfv_i = mtfv[gs+(nn)];              \
564
434k
               bsW ( s,                             \
565
434k
                     s_len_sel_selCtr[mtfv_i],      \
566
434k
                     s_code_sel_selCtr[mtfv_i] )
567
568
8.69k
            BZ_ITAH(0);  BZ_ITAH(1);  BZ_ITAH(2);  BZ_ITAH(3);  BZ_ITAH(4);
569
8.69k
            BZ_ITAH(5);  BZ_ITAH(6);  BZ_ITAH(7);  BZ_ITAH(8);  BZ_ITAH(9);
570
8.69k
            BZ_ITAH(10); BZ_ITAH(11); BZ_ITAH(12); BZ_ITAH(13); BZ_ITAH(14);
571
8.69k
            BZ_ITAH(15); BZ_ITAH(16); BZ_ITAH(17); BZ_ITAH(18); BZ_ITAH(19);
572
8.69k
            BZ_ITAH(20); BZ_ITAH(21); BZ_ITAH(22); BZ_ITAH(23); BZ_ITAH(24);
573
8.69k
            BZ_ITAH(25); BZ_ITAH(26); BZ_ITAH(27); BZ_ITAH(28); BZ_ITAH(29);
574
8.69k
            BZ_ITAH(30); BZ_ITAH(31); BZ_ITAH(32); BZ_ITAH(33); BZ_ITAH(34);
575
8.69k
            BZ_ITAH(35); BZ_ITAH(36); BZ_ITAH(37); BZ_ITAH(38); BZ_ITAH(39);
576
8.69k
            BZ_ITAH(40); BZ_ITAH(41); BZ_ITAH(42); BZ_ITAH(43); BZ_ITAH(44);
577
8.69k
            BZ_ITAH(45); BZ_ITAH(46); BZ_ITAH(47); BZ_ITAH(48); BZ_ITAH(49);
578
579
8.69k
#           undef BZ_ITAH
580
581
14.5k
      } else {
582
   /*--- slow version which correctly handles all situations ---*/
583
632k
         for (i = gs; i <= ge; i++) {
584
617k
            bsW ( s, 
585
617k
                  s->len  [s->selector[selCtr]] [mtfv[i]],
586
617k
                  s->code [s->selector[selCtr]] [mtfv[i]] );
587
617k
         }
588
14.5k
      }
589
590
591
23.2k
      gs = ge+1;
592
23.2k
      selCtr++;
593
23.2k
   }
594
3.79k
   AssertH( selCtr == nSelectors, 3007 );
595
596
3.79k
   if (s->verbosity >= 3)
597
0
      VPrintf1( "codes %d\n", s->numZ-nBytes );
598
3.79k
}
599
600
601
/*---------------------------------------------------*/
602
void BZ2_compressBlock ( EState* s, Bool is_last_block )
603
3.79k
{
604
3.79k
   if (s->nblock > 0) {
605
606
3.79k
      BZ_FINALISE_CRC ( s->blockCRC );
607
3.79k
      s->combinedCRC = (s->combinedCRC << 1) | (s->combinedCRC >> 31);
608
3.79k
      s->combinedCRC ^= s->blockCRC;
609
3.79k
      if (s->blockNo > 1) s->numZ = 0;
610
611
3.79k
      if (s->verbosity >= 2)
612
0
         VPrintf4( "    block %d: crc = 0x%08x, "
613
3.79k
                   "combined CRC = 0x%08x, size = %d\n",
614
3.79k
                   s->blockNo, s->blockCRC, s->combinedCRC, s->nblock );
615
616
3.79k
      BZ2_blockSort ( s );
617
3.79k
   }
618
619
3.79k
   s->zbits = (UChar*) (&((UChar*)s->arr2)[s->nblock]);
620
621
   /*-- If this is the first block, create the stream header. --*/
622
3.79k
   if (s->blockNo == 1) {
623
3.76k
      BZ2_bsInitWrite ( s );
624
3.76k
      bsPutUChar ( s, BZ_HDR_B );
625
3.76k
      bsPutUChar ( s, BZ_HDR_Z );
626
3.76k
      bsPutUChar ( s, BZ_HDR_h );
627
3.76k
      bsPutUChar ( s, (UChar)(BZ_HDR_0 + s->blockSize100k) );
628
3.76k
   }
629
630
3.79k
   if (s->nblock > 0) {
631
632
3.79k
      bsPutUChar ( s, 0x31 ); bsPutUChar ( s, 0x41 );
633
3.79k
      bsPutUChar ( s, 0x59 ); bsPutUChar ( s, 0x26 );
634
3.79k
      bsPutUChar ( s, 0x53 ); bsPutUChar ( s, 0x59 );
635
636
      /*-- Now the block's CRC, so it is in a known place. --*/
637
3.79k
      bsPutUInt32 ( s, s->blockCRC );
638
639
      /*-- 
640
         Now a single bit indicating (non-)randomisation. 
641
         As of version 0.9.5, we use a better sorting algorithm
642
         which makes randomisation unnecessary.  So always set
643
         the randomised bit to 'no'.  Of course, the decoder
644
         still needs to be able to handle randomised blocks
645
         so as to maintain backwards compatibility with
646
         older versions of bzip2.
647
      --*/
648
3.79k
      bsW(s,1,0);
649
650
3.79k
      bsW ( s, 24, s->origPtr );
651
3.79k
      generateMTFValues ( s );
652
3.79k
      sendMTFValues ( s );
653
3.79k
   }
654
655
656
   /*-- If this is the last block, add the stream trailer. --*/
657
3.79k
   if (is_last_block) {
658
659
3.76k
      bsPutUChar ( s, 0x17 ); bsPutUChar ( s, 0x72 );
660
3.76k
      bsPutUChar ( s, 0x45 ); bsPutUChar ( s, 0x38 );
661
3.76k
      bsPutUChar ( s, 0x50 ); bsPutUChar ( s, 0x90 );
662
3.76k
      bsPutUInt32 ( s, s->combinedCRC );
663
3.76k
      if (s->verbosity >= 2)
664
0
         VPrintf1( "    final combined CRC = 0x%08x\n   ", s->combinedCRC );
665
3.76k
      bsFinishWrite ( s );
666
3.76k
   }
667
3.79k
}
668
669
670
/*-------------------------------------------------------------*/
671
/*--- end                                        compress.c ---*/
672
/*-------------------------------------------------------------*/