Coverage Report

Created: 2025-11-16 07:22

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