Coverage Report

Created: 2026-05-24 07:45

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