Coverage Report

Created: 2025-06-04 06:23

/rust/registry/src/index.crates.io-6f17d22bba15001f/bzip2-sys-0.1.13+1.0.8/bzip2-1.0.8/compress.c
Line
Count
Source (jump to first uncovered line)
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.88k
{
39
3.88k
   s->bsLive = 0;
40
3.88k
   s->bsBuff = 0;
41
3.88k
}
42
43
44
/*---------------------------------------------------*/
45
static
46
void bsFinishWrite ( EState* s )
47
3.88k
{
48
11.0k
   while (s->bsLive > 0) {
49
7.16k
      s->zbits[s->numZ] = (UChar)(s->bsBuff >> 24);
50
7.16k
      s->numZ++;
51
7.16k
      s->bsBuff <<= 8;
52
7.16k
      s->bsLive -= 8;
53
7.16k
   }
54
3.88k
}
55
56
57
/*---------------------------------------------------*/
58
2.28M
#define bsNEEDW(nz)                           \
59
2.28M
{                                             \
60
2.97M
   while (s->bsLive >= 8) {                   \
61
688k
      s->zbits[s->numZ]                       \
62
688k
         = (UChar)(s->bsBuff >> 24);          \
63
688k
      s->numZ++;                              \
64
688k
      s->bsBuff <<= 8;                        \
65
688k
      s->bsLive -= 8;                         \
66
688k
   }                                          \
67
2.28M
}
68
69
70
/*---------------------------------------------------*/
71
static
72
__inline__
73
void bsW ( EState* s, Int32 n, UInt32 v )
74
2.28M
{
75
2.28M
   bsNEEDW ( n );
76
2.28M
   s->bsBuff |= (v << (32 - s->bsLive - n));
77
2.28M
   s->bsLive += n;
78
2.28M
}
79
80
81
/*---------------------------------------------------*/
82
static
83
void bsPutUInt32 ( EState* s, UInt32 u )
84
7.79k
{
85
7.79k
   bsW ( s, 8, (u >> 24) & 0xffL );
86
7.79k
   bsW ( s, 8, (u >> 16) & 0xffL );
87
7.79k
   bsW ( s, 8, (u >>  8) & 0xffL );
88
7.79k
   bsW ( s, 8,  u        & 0xffL );
89
7.79k
}
90
91
92
/*---------------------------------------------------*/
93
static
94
void bsPutUChar ( EState* s, UChar c )
95
62.2k
{
96
62.2k
   bsW( s, 8, (UInt32)c );
97
62.2k
}
98
99
100
/*---------------------------------------------------*/
101
/*--- The back end proper                         ---*/
102
/*---------------------------------------------------*/
103
104
/*---------------------------------------------------*/
105
static
106
void makeMaps_e ( EState* s )
107
3.90k
{
108
3.90k
   Int32 i;
109
3.90k
   s->nInUse = 0;
110
1.00M
   for (i = 0; i < 256; i++)
111
1.00M
      if (s->inUse[i]) {
112
91.8k
         s->unseqToSeq[i] = s->nInUse;
113
91.8k
         s->nInUse++;
114
91.8k
      }
115
3.90k
}
116
117
118
/*---------------------------------------------------*/
119
static
120
void generateMTFValues ( EState* s )
121
3.90k
{
122
3.90k
   UChar   yy[256];
123
3.90k
   Int32   i, j;
124
3.90k
   Int32   zPend;
125
3.90k
   Int32   wr;
126
3.90k
   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.90k
   UInt32* ptr   = s->ptr;
151
3.90k
   UChar* block  = s->block;
152
3.90k
   UInt16* mtfv  = s->mtfv;
153
154
3.90k
   makeMaps_e ( s );
155
3.90k
   EOB = s->nInUse+1;
156
157
103k
   for (i = 0; i <= EOB; i++) s->mtfFreq[i] = 0;
158
159
3.90k
   wr = 0;
160
3.90k
   zPend = 0;
161
95.7k
   for (i = 0; i < s->nInUse; i++) yy[i] = (UChar) i;
162
163
15.5M
   for (i = 0; i < s->nblock; i++) {
164
15.5M
      UChar ll_i;
165
15.5M
      AssertD ( wr <= i, "generateMTFValues(1)" );
166
15.5M
      j = ptr[i]-1; if (j < 0) j += s->nblock;
167
15.5M
      ll_i = s->unseqToSeq[block[j]];
168
15.5M
      AssertD ( ll_i < s->nInUse, "generateMTFValues(2a)" );
169
170
15.5M
      if (yy[0] == ll_i) { 
171
15.1M
         zPend++;
172
15.1M
      } else {
173
174
388k
         if (zPend > 0) {
175
233k
            zPend--;
176
738k
            while (True) {
177
738k
               if (zPend & 1) {
178
316k
                  mtfv[wr] = BZ_RUNB; wr++; 
179
316k
                  s->mtfFreq[BZ_RUNB]++; 
180
421k
               } else {
181
421k
                  mtfv[wr] = BZ_RUNA; wr++; 
182
421k
                  s->mtfFreq[BZ_RUNA]++; 
183
421k
               }
184
738k
               if (zPend < 2) break;
185
505k
               zPend = (zPend - 2) / 2;
186
505k
            };
187
233k
            zPend = 0;
188
233k
         }
189
388k
         {
190
388k
            register UChar  rtmp;
191
388k
            register UChar* ryy_j;
192
388k
            register UChar  rll_i;
193
388k
            rtmp  = yy[1];
194
388k
            yy[1] = yy[0];
195
388k
            ryy_j = &(yy[1]);
196
388k
            rll_i = ll_i;
197
5.39M
            while ( rll_i != rtmp ) {
198
5.00M
               register UChar rtmp2;
199
5.00M
               ryy_j++;
200
5.00M
               rtmp2  = rtmp;
201
5.00M
               rtmp   = *ryy_j;
202
5.00M
               *ryy_j = rtmp2;
203
5.00M
            };
204
388k
            yy[0] = rtmp;
205
388k
            j = ryy_j - &(yy[0]);
206
388k
            mtfv[wr] = j+1; wr++; s->mtfFreq[j+1]++;
207
388k
         }
208
209
388k
      }
210
15.5M
   }
211
212
3.90k
   if (zPend > 0) {
213
1.11k
      zPend--;
214
2.14k
      while (True) {
215
2.14k
         if (zPend & 1) {
216
860
            mtfv[wr] = BZ_RUNB; wr++; 
217
860
            s->mtfFreq[BZ_RUNB]++; 
218
1.28k
         } else {
219
1.28k
            mtfv[wr] = BZ_RUNA; wr++; 
220
1.28k
            s->mtfFreq[BZ_RUNA]++; 
221
1.28k
         }
222
2.14k
         if (zPend < 2) break;
223
1.03k
         zPend = (zPend - 2) / 2;
224
1.03k
      };
225
1.11k
      zPend = 0;
226
1.11k
   }
227
228
3.90k
   mtfv[wr] = EOB; wr++; s->mtfFreq[EOB]++;
229
230
3.90k
   s->nMTF = wr;
231
3.90k
}
232
233
234
/*---------------------------------------------------*/
235
99.6k
#define BZ_LESSER_ICOST  0
236
816k
#define BZ_GREATER_ICOST 15
237
238
static
239
void sendMTFValues ( EState* s )
240
3.90k
{
241
3.90k
   Int32 v, t, i, j, gs, ge, totc, bt, bc, iter;
242
3.90k
   Int32 nSelectors, alphaSize, minLen, maxLen, selCtr;
243
3.90k
   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.90k
   UInt16 cost[BZ_N_GROUPS];
257
3.90k
   Int32  fave[BZ_N_GROUPS];
258
259
3.90k
   UInt16* mtfv = s->mtfv;
260
261
3.90k
   if (s->verbosity >= 3)
262
0
      VPrintf3( "      %d in block, %d after MTF & 1-2 coding, "
263
3.90k
                "%d+2 syms in use\n", 
264
3.90k
                s->nblock, s->nMTF, s->nInUse );
265
266
3.90k
   alphaSize = s->nInUse+2;
267
27.3k
   for (t = 0; t < BZ_N_GROUPS; t++)
268
621k
      for (v = 0; v < alphaSize; v++)
269
597k
         s->len[t][v] = BZ_GREATER_ICOST;
270
271
   /*--- Decide how many coding tables to use ---*/
272
3.90k
   AssertH ( s->nMTF > 0, 3001 );
273
3.90k
   if (s->nMTF < 200)  nGroups = 2; else
274
980
   if (s->nMTF < 600)  nGroups = 3; else
275
480
   if (s->nMTF < 1200) nGroups = 4; else
276
293
   if (s->nMTF < 2400) nGroups = 5; else
277
167
                       nGroups = 6;
278
279
   /*--- Generate an initial set of coding tables ---*/
280
3.90k
   { 
281
3.90k
      Int32 nPart, remF, tFreq, aFreq;
282
283
3.90k
      nPart = nGroups;
284
3.90k
      remF  = s->nMTF;
285
3.90k
      gs = 0;
286
13.6k
      while (nPart > 0) {
287
9.73k
         tFreq = remF / nPart;
288
9.73k
         ge = gs-1;
289
9.73k
         aFreq = 0;
290
110k
         while (aFreq < tFreq && ge < alphaSize-1) {
291
100k
            ge++;
292
100k
            aFreq += s->mtfFreq[ge];
293
100k
         }
294
295
9.73k
         if (ge > gs 
296
9.73k
             && nPart != nGroups && nPart != 1 
297
9.73k
             && ((nGroups-nPart) % 2 == 1)) {
298
659
            aFreq -= s->mtfFreq[ge];
299
659
            ge--;
300
659
         }
301
302
9.73k
         if (s->verbosity >= 3)
303
0
            VPrintf5( "      initial group %d, [%d .. %d], "
304
9.73k
                      "has %d syms (%4.1f%%)\n",
305
9.73k
                      nPart, gs, ge, aFreq, 
306
9.73k
                      (100.0 * (float)aFreq) / (float)(s->nMTF) );
307
 
308
327k
         for (v = 0; v < alphaSize; v++)
309
317k
            if (v >= gs && v <= ge) 
310
99.6k
               s->len[nPart-1][v] = BZ_LESSER_ICOST; else
311
218k
               s->len[nPart-1][v] = BZ_GREATER_ICOST;
312
 
313
9.73k
         nPart--;
314
9.73k
         gs = ge+1;
315
9.73k
         remF -= aFreq;
316
9.73k
      }
317
3.90k
   }
318
319
   /*--- 
320
      Iterate up to BZ_N_ITERS times to improve the tables.
321
   ---*/
322
19.5k
   for (iter = 0; iter < BZ_N_ITERS; iter++) {
323
324
54.5k
      for (t = 0; t < nGroups; t++) fave[t] = 0;
325
326
54.5k
      for (t = 0; t < nGroups; t++)
327
1.30M
         for (v = 0; v < alphaSize; v++)
328
1.27M
            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.6k
      if (nGroups == 6) {
335
55.4k
         for (v = 0; v < alphaSize; v++) {
336
54.7k
            s->len_pack[v][0] = (s->len[1][v] << 16) | s->len[0][v];
337
54.7k
            s->len_pack[v][1] = (s->len[3][v] << 16) | s->len[2][v];
338
54.7k
            s->len_pack[v][2] = (s->len[5][v] << 16) | s->len[4][v];
339
54.7k
   }
340
668
      }
341
342
15.6k
      nSelectors = 0;
343
15.6k
      totc = 0;
344
15.6k
      gs = 0;
345
115k
      while (True) {
346
347
         /*--- Set group start & end marks. --*/
348
115k
         if (gs >= s->nMTF) break;
349
99.9k
         ge = gs + BZ_G_SIZE - 1; 
350
99.9k
         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
538k
         for (t = 0; t < nGroups; t++) cost[t] = 0;
357
358
99.9k
         if (nGroups == 6 && 50 == ge-gs+1) {
359
            /*--- fast track the common case ---*/
360
36.1k
            register UInt32 cost01, cost23, cost45;
361
36.1k
            register UInt16 icv;
362
36.1k
            cost01 = cost23 = cost45 = 0;
363
364
36.1k
#           define BZ_ITER(nn)                \
365
1.80M
               icv = mtfv[gs+(nn)];           \
366
1.80M
               cost01 += s->len_pack[icv][0]; \
367
1.80M
               cost23 += s->len_pack[icv][1]; \
368
1.80M
               cost45 += s->len_pack[icv][2]; \
369
36.1k
370
36.1k
            BZ_ITER(0);  BZ_ITER(1);  BZ_ITER(2);  BZ_ITER(3);  BZ_ITER(4);
371
36.1k
            BZ_ITER(5);  BZ_ITER(6);  BZ_ITER(7);  BZ_ITER(8);  BZ_ITER(9);
372
36.1k
            BZ_ITER(10); BZ_ITER(11); BZ_ITER(12); BZ_ITER(13); BZ_ITER(14);
373
36.1k
            BZ_ITER(15); BZ_ITER(16); BZ_ITER(17); BZ_ITER(18); BZ_ITER(19);
374
36.1k
            BZ_ITER(20); BZ_ITER(21); BZ_ITER(22); BZ_ITER(23); BZ_ITER(24);
375
36.1k
            BZ_ITER(25); BZ_ITER(26); BZ_ITER(27); BZ_ITER(28); BZ_ITER(29);
376
36.1k
            BZ_ITER(30); BZ_ITER(31); BZ_ITER(32); BZ_ITER(33); BZ_ITER(34);
377
36.1k
            BZ_ITER(35); BZ_ITER(36); BZ_ITER(37); BZ_ITER(38); BZ_ITER(39);
378
36.1k
            BZ_ITER(40); BZ_ITER(41); BZ_ITER(42); BZ_ITER(43); BZ_ITER(44);
379
36.1k
            BZ_ITER(45); BZ_ITER(46); BZ_ITER(47); BZ_ITER(48); BZ_ITER(49);
380
381
36.1k
#           undef BZ_ITER
382
383
36.1k
            cost[0] = cost01 & 0xffff; cost[1] = cost01 >> 16;
384
36.1k
            cost[2] = cost23 & 0xffff; cost[3] = cost23 >> 16;
385
36.1k
            cost[4] = cost45 & 0xffff; cost[5] = cost45 >> 16;
386
387
63.7k
         } else {
388
      /*--- slow version which correctly handles all situations ---*/
389
2.78M
            for (i = gs; i <= ge; i++) { 
390
2.72M
               UInt16 icv = mtfv[i];
391
12.6M
               for (t = 0; t < nGroups; t++) cost[t] += s->len[t][icv];
392
2.72M
            }
393
63.7k
         }
394
 
395
         /*-- 
396
            Find the coding table which is best for this group,
397
            and record its identity in the selector table.
398
         --*/
399
99.9k
         bc = 999999999; bt = -1;
400
538k
         for (t = 0; t < nGroups; t++)
401
438k
            if (cost[t] < bc) { bc = cost[t]; bt = t; };
402
99.9k
         totc += bc;
403
99.9k
         fave[bt]++;
404
99.9k
         s->selector[nSelectors] = bt;
405
99.9k
         nSelectors++;
406
407
         /*-- 
408
            Increment the symbol frequencies for the selected table.
409
          --*/
410
99.9k
         if (nGroups == 6 && 50 == ge-gs+1) {
411
            /*--- fast track the common case ---*/
412
413
1.80M
#           define BZ_ITUR(nn) s->rfreq[bt][ mtfv[gs+(nn)] ]++
414
415
36.1k
            BZ_ITUR(0);  BZ_ITUR(1);  BZ_ITUR(2);  BZ_ITUR(3);  BZ_ITUR(4);
416
36.1k
            BZ_ITUR(5);  BZ_ITUR(6);  BZ_ITUR(7);  BZ_ITUR(8);  BZ_ITUR(9);
417
36.1k
            BZ_ITUR(10); BZ_ITUR(11); BZ_ITUR(12); BZ_ITUR(13); BZ_ITUR(14);
418
36.1k
            BZ_ITUR(15); BZ_ITUR(16); BZ_ITUR(17); BZ_ITUR(18); BZ_ITUR(19);
419
36.1k
            BZ_ITUR(20); BZ_ITUR(21); BZ_ITUR(22); BZ_ITUR(23); BZ_ITUR(24);
420
36.1k
            BZ_ITUR(25); BZ_ITUR(26); BZ_ITUR(27); BZ_ITUR(28); BZ_ITUR(29);
421
36.1k
            BZ_ITUR(30); BZ_ITUR(31); BZ_ITUR(32); BZ_ITUR(33); BZ_ITUR(34);
422
36.1k
            BZ_ITUR(35); BZ_ITUR(36); BZ_ITUR(37); BZ_ITUR(38); BZ_ITUR(39);
423
36.1k
            BZ_ITUR(40); BZ_ITUR(41); BZ_ITUR(42); BZ_ITUR(43); BZ_ITUR(44);
424
36.1k
            BZ_ITUR(45); BZ_ITUR(46); BZ_ITUR(47); BZ_ITUR(48); BZ_ITUR(49);
425
426
36.1k
#           undef BZ_ITUR
427
428
63.7k
         } else {
429
      /*--- slow version which correctly handles all situations ---*/
430
2.78M
            for (i = gs; i <= ge; i++)
431
2.72M
               s->rfreq[bt][ mtfv[i] ]++;
432
63.7k
         }
433
434
99.9k
         gs = ge+1;
435
99.9k
      }
436
15.6k
      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
54.5k
      for (t = 0; t < nGroups; t++)
450
38.9k
         BZ2_hbMakeCodeLengths ( &(s->len[t][0]), &(s->rfreq[t][0]), 
451
38.9k
                                 alphaSize, 17 /*20*/ );
452
15.6k
   }
453
454
455
3.90k
   AssertH( nGroups < 8, 3002 );
456
3.90k
   AssertH( nSelectors < 32768 &&
457
3.90k
            nSelectors <= BZ_MAX_SELECTORS,
458
3.90k
            3003 );
459
460
461
   /*--- Compute MTF values for the selectors. ---*/
462
3.90k
   {
463
3.90k
      UChar pos[BZ_N_GROUPS], ll_i, tmp2, tmp;
464
13.6k
      for (i = 0; i < nGroups; i++) pos[i] = i;
465
28.8k
      for (i = 0; i < nSelectors; i++) {
466
24.9k
         ll_i = s->selector[i];
467
24.9k
         j = 0;
468
24.9k
         tmp = pos[j];
469
38.1k
         while ( ll_i != tmp ) {
470
13.1k
            j++;
471
13.1k
            tmp2 = tmp;
472
13.1k
            tmp = pos[j];
473
13.1k
            pos[j] = tmp2;
474
13.1k
         };
475
24.9k
         pos[0] = tmp;
476
24.9k
         s->selectorMtf[i] = j;
477
24.9k
      }
478
3.90k
   };
479
480
   /*--- Assign actual codes for the tables. --*/
481
13.6k
   for (t = 0; t < nGroups; t++) {
482
9.73k
      minLen = 32;
483
9.73k
      maxLen = 0;
484
327k
      for (i = 0; i < alphaSize; i++) {
485
317k
         if (s->len[t][i] > maxLen) maxLen = s->len[t][i];
486
317k
         if (s->len[t][i] < minLen) minLen = s->len[t][i];
487
317k
      }
488
9.73k
      AssertH ( !(maxLen > 17 /*20*/ ), 3004 );
489
9.73k
      AssertH ( !(minLen < 1),  3005 );
490
9.73k
      BZ2_hbAssignCodes ( &(s->code[t][0]), &(s->len[t][0]), 
491
9.73k
                          minLen, maxLen, alphaSize );
492
9.73k
   }
493
494
   /*--- Transmit the mapping table. ---*/
495
3.90k
   { 
496
3.90k
      Bool inUse16[16];
497
66.4k
      for (i = 0; i < 16; i++) {
498
62.5k
          inUse16[i] = False;
499
1.06M
          for (j = 0; j < 16; j++)
500
1.00M
             if (s->inUse[i * 16 + j]) inUse16[i] = True;
501
62.5k
      }
502
     
503
3.90k
      nBytes = s->numZ;
504
66.4k
      for (i = 0; i < 16; i++)
505
62.5k
         if (inUse16[i]) bsW(s,1,1); else bsW(s,1,0);
506
507
66.4k
      for (i = 0; i < 16; i++)
508
62.5k
         if (inUse16[i])
509
500k
            for (j = 0; j < 16; j++) {
510
471k
               if (s->inUse[i * 16 + j]) bsW(s,1,1); else bsW(s,1,0);
511
471k
            }
512
513
3.90k
      if (s->verbosity >= 3) 
514
0
         VPrintf1( "      bytes: mapping %d, ", s->numZ-nBytes );
515
3.90k
   }
516
517
   /*--- Now the selectors. ---*/
518
3.90k
   nBytes = s->numZ;
519
3.90k
   bsW ( s, 3, nGroups );
520
3.90k
   bsW ( s, 15, nSelectors );
521
28.8k
   for (i = 0; i < nSelectors; i++) { 
522
38.1k
      for (j = 0; j < s->selectorMtf[i]; j++) bsW(s,1,1);
523
24.9k
      bsW(s,1,0);
524
24.9k
   }
525
3.90k
   if (s->verbosity >= 3)
526
0
      VPrintf1( "selectors %d, ", s->numZ-nBytes );
527
528
   /*--- Now the coding tables. ---*/
529
3.90k
   nBytes = s->numZ;
530
531
13.6k
   for (t = 0; t < nGroups; t++) {
532
9.73k
      Int32 curr = s->len[t][0];
533
9.73k
      bsW ( s, 5, curr );
534
327k
      for (i = 0; i < alphaSize; i++) {
535
400k
         while (curr < s->len[t][i]) { bsW(s,2,2); curr++; /* 10 */ };
536
382k
         while (curr > s->len[t][i]) { bsW(s,2,3); curr--; /* 11 */ };
537
317k
         bsW ( s, 1, 0 );
538
317k
      }
539
9.73k
   }
540
541
3.90k
   if (s->verbosity >= 3)
542
0
      VPrintf1 ( "code lengths %d, ", s->numZ-nBytes );
543
544
   /*--- And finally, the block data proper ---*/
545
3.90k
   nBytes = s->numZ;
546
3.90k
   selCtr = 0;
547
3.90k
   gs = 0;
548
28.8k
   while (True) {
549
28.8k
      if (gs >= s->nMTF) break;
550
24.9k
      ge = gs + BZ_G_SIZE - 1; 
551
24.9k
      if (ge >= s->nMTF) ge = s->nMTF-1;
552
24.9k
      AssertH ( s->selector[selCtr] < nGroups, 3006 );
553
554
24.9k
      if (nGroups == 6 && 50 == ge-gs+1) {
555
            /*--- fast track the common case ---*/
556
9.04k
            UInt16 mtfv_i;
557
9.04k
            UChar* s_len_sel_selCtr 
558
9.04k
               = &(s->len[s->selector[selCtr]][0]);
559
9.04k
            Int32* s_code_sel_selCtr
560
9.04k
               = &(s->code[s->selector[selCtr]][0]);
561
562
9.04k
#           define BZ_ITAH(nn)                      \
563
452k
               mtfv_i = mtfv[gs+(nn)];              \
564
452k
               bsW ( s,                             \
565
452k
                     s_len_sel_selCtr[mtfv_i],      \
566
452k
                     s_code_sel_selCtr[mtfv_i] )
567
568
9.04k
            BZ_ITAH(0);  BZ_ITAH(1);  BZ_ITAH(2);  BZ_ITAH(3);  BZ_ITAH(4);
569
9.04k
            BZ_ITAH(5);  BZ_ITAH(6);  BZ_ITAH(7);  BZ_ITAH(8);  BZ_ITAH(9);
570
9.04k
            BZ_ITAH(10); BZ_ITAH(11); BZ_ITAH(12); BZ_ITAH(13); BZ_ITAH(14);
571
9.04k
            BZ_ITAH(15); BZ_ITAH(16); BZ_ITAH(17); BZ_ITAH(18); BZ_ITAH(19);
572
9.04k
            BZ_ITAH(20); BZ_ITAH(21); BZ_ITAH(22); BZ_ITAH(23); BZ_ITAH(24);
573
9.04k
            BZ_ITAH(25); BZ_ITAH(26); BZ_ITAH(27); BZ_ITAH(28); BZ_ITAH(29);
574
9.04k
            BZ_ITAH(30); BZ_ITAH(31); BZ_ITAH(32); BZ_ITAH(33); BZ_ITAH(34);
575
9.04k
            BZ_ITAH(35); BZ_ITAH(36); BZ_ITAH(37); BZ_ITAH(38); BZ_ITAH(39);
576
9.04k
            BZ_ITAH(40); BZ_ITAH(41); BZ_ITAH(42); BZ_ITAH(43); BZ_ITAH(44);
577
9.04k
            BZ_ITAH(45); BZ_ITAH(46); BZ_ITAH(47); BZ_ITAH(48); BZ_ITAH(49);
578
579
9.04k
#           undef BZ_ITAH
580
581
15.9k
      } else {
582
   /*--- slow version which correctly handles all situations ---*/
583
696k
         for (i = gs; i <= ge; i++) {
584
681k
            bsW ( s, 
585
681k
                  s->len  [s->selector[selCtr]] [mtfv[i]],
586
681k
                  s->code [s->selector[selCtr]] [mtfv[i]] );
587
681k
         }
588
15.9k
      }
589
590
591
24.9k
      gs = ge+1;
592
24.9k
      selCtr++;
593
24.9k
   }
594
3.90k
   AssertH( selCtr == nSelectors, 3007 );
595
596
3.90k
   if (s->verbosity >= 3)
597
0
      VPrintf1( "codes %d\n", s->numZ-nBytes );
598
3.90k
}
599
600
601
/*---------------------------------------------------*/
602
void BZ2_compressBlock ( EState* s, Bool is_last_block )
603
3.90k
{
604
3.90k
   if (s->nblock > 0) {
605
606
3.90k
      BZ_FINALISE_CRC ( s->blockCRC );
607
3.90k
      s->combinedCRC = (s->combinedCRC << 1) | (s->combinedCRC >> 31);
608
3.90k
      s->combinedCRC ^= s->blockCRC;
609
3.90k
      if (s->blockNo > 1) s->numZ = 0;
610
611
3.90k
      if (s->verbosity >= 2)
612
0
         VPrintf4( "    block %d: crc = 0x%08x, "
613
3.90k
                   "combined CRC = 0x%08x, size = %d\n",
614
3.90k
                   s->blockNo, s->blockCRC, s->combinedCRC, s->nblock );
615
616
3.90k
      BZ2_blockSort ( s );
617
3.90k
   }
618
619
3.90k
   s->zbits = (UChar*) (&((UChar*)s->arr2)[s->nblock]);
620
621
   /*-- If this is the first block, create the stream header. --*/
622
3.90k
   if (s->blockNo == 1) {
623
3.88k
      BZ2_bsInitWrite ( s );
624
3.88k
      bsPutUChar ( s, BZ_HDR_B );
625
3.88k
      bsPutUChar ( s, BZ_HDR_Z );
626
3.88k
      bsPutUChar ( s, BZ_HDR_h );
627
3.88k
      bsPutUChar ( s, (UChar)(BZ_HDR_0 + s->blockSize100k) );
628
3.88k
   }
629
630
3.90k
   if (s->nblock > 0) {
631
632
3.90k
      bsPutUChar ( s, 0x31 ); bsPutUChar ( s, 0x41 );
633
3.90k
      bsPutUChar ( s, 0x59 ); bsPutUChar ( s, 0x26 );
634
3.90k
      bsPutUChar ( s, 0x53 ); bsPutUChar ( s, 0x59 );
635
636
      /*-- Now the block's CRC, so it is in a known place. --*/
637
3.90k
      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.90k
      bsW(s,1,0);
649
650
3.90k
      bsW ( s, 24, s->origPtr );
651
3.90k
      generateMTFValues ( s );
652
3.90k
      sendMTFValues ( s );
653
3.90k
   }
654
655
656
   /*-- If this is the last block, add the stream trailer. --*/
657
3.90k
   if (is_last_block) {
658
659
3.88k
      bsPutUChar ( s, 0x17 ); bsPutUChar ( s, 0x72 );
660
3.88k
      bsPutUChar ( s, 0x45 ); bsPutUChar ( s, 0x38 );
661
3.88k
      bsPutUChar ( s, 0x50 ); bsPutUChar ( s, 0x90 );
662
3.88k
      bsPutUInt32 ( s, s->combinedCRC );
663
3.88k
      if (s->verbosity >= 2)
664
0
         VPrintf1( "    final combined CRC = 0x%08x\n   ", s->combinedCRC );
665
3.88k
      bsFinishWrite ( s );
666
3.88k
   }
667
3.90k
}
668
669
670
/*-------------------------------------------------------------*/
671
/*--- end                                        compress.c ---*/
672
/*-------------------------------------------------------------*/