CCITTG4Encoder.java

1
/*
2
 * Copyright 2005 by Paulo Soares.
3
 *
4
 * The contents of this file are subject to the Mozilla Public License Version 1.1
5
 * (the "License"); you may not use this file except in compliance with the License.
6
 * You may obtain a copy of the License at http://www.mozilla.org/MPL/
7
 *
8
 * Software distributed under the License is distributed on an "AS IS" basis,
9
 * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
10
 * for the specific language governing rights and limitations under the License.
11
 *
12
 * The Original Code is 'iText, a free JAVA-PDF library'.
13
 *
14
 * The Initial Developer of the Original Code is Bruno Lowagie. Portions created by
15
 * the Initial Developer are Copyright (C) 1999, 2000, 2001, 2002 by Bruno Lowagie.
16
 * All Rights Reserved.
17
 * Co-Developer of the code is Paulo Soares. Portions created by the Co-Developer
18
 * are Copyright (C) 2000, 2001, 2002 by Paulo Soares. All Rights Reserved.
19
 *
20
 * Contributor(s): all the names of the contributors are added in the source code
21
 * where applicable.
22
 *
23
 * Alternatively, the contents of this file may be used under the terms of the
24
 * LGPL license (the "GNU LIBRARY GENERAL PUBLIC LICENSE"), in which case the
25
 * provisions of LGPL are applicable instead of those above.  If you wish to
26
 * allow use of your version of this file only under the terms of the LGPL
27
 * License and not to allow others to use your version of this file under
28
 * the MPL, indicate your decision by deleting the provisions above and
29
 * replace them with the notice and other provisions required by the LGPL.
30
 * If you do not delete the provisions above, a recipient may use your version
31
 * of this file under either the MPL or the GNU LIBRARY GENERAL PUBLIC LICENSE.
32
 *
33
 * This library is free software; you can redistribute it and/or modify it
34
 * under the terms of the MPL as stated above or under the terms of the GNU
35
 * Library General Public License as published by the Free Software Foundation;
36
 * either version 2 of the License, or any later version.
37
 *
38
 * This library is distributed in the hope that it will be useful, but WITHOUT
39
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
40
 * FOR A PARTICULAR PURPOSE. See the GNU Library general Public License for more
41
 * details.
42
 *
43
 * If you didn't download this code from the following link, you should check if
44
 * you aren't using an obsolete version:
45
 * http://www.lowagie.com/iText/
46
 *
47
 * This code is base in the libtiff encoder
48
 */
49
package com.lowagie.text.pdf.codec;
50
51
import com.lowagie.text.pdf.ByteBuffer;
52
53
/**
54
 * Encodes data in the CCITT G4 FAX format.
55
 */
56
public class CCITTG4Encoder {
57
    private int rowbytes;
58
    private int rowpixels;
59
    private int bit = 8;
60
    private int data;
61
    private byte[] refline;
62
    private ByteBuffer outBuf = new ByteBuffer(1024);
63
    private byte[] dataBp;
64
    private int offsetData;
65
    private int sizeData;
66
    
67
    /**
68
     * Creates a new encoder.
69
     * @param width the line width
70
     */    
71
    public CCITTG4Encoder(int width) {
72
        rowpixels = width;
73 2 1. : Replaced integer addition with subtraction → NO_COVERAGE
2. : Replaced integer division with multiplication → NO_COVERAGE
        rowbytes = (rowpixels + 7) / 8;
74
        refline = new byte[rowbytes];
75
    }
76
    
77
    /**
78
     * Encodes a number of lines.
79
     * @param data the data to be encoded
80
     * @param offset the offset into the data
81
     * @param size the size of the data to be encoded
82
     */    
83
    public void fax4Encode(byte[] data, int offset, int size) {
84
        dataBp = data;
85
        offsetData = offset;
86
        sizeData = size;
87 2 1. fax4Encode : changed conditional boundary → NO_COVERAGE
2. fax4Encode : negated conditional → NO_COVERAGE
        while (sizeData > 0) {
88 1 1. fax4Encode : removed call to com/lowagie/text/pdf/codec/CCITTG4Encoder::Fax3Encode2DRow → NO_COVERAGE
            Fax3Encode2DRow();
89 1 1. fax4Encode : removed call to java/lang/System::arraycopy → NO_COVERAGE
            System.arraycopy(dataBp, offsetData, refline, 0, rowbytes);
90 1 1. fax4Encode : Replaced integer addition with subtraction → NO_COVERAGE
            offsetData += rowbytes;
91 1 1. fax4Encode : Replaced integer subtraction with addition → NO_COVERAGE
            sizeData -= rowbytes;
92
        }
93
    }
94
    
95
96
    /**
97
     * Encodes a full image.
98
     * @param data the data to encode
99
     * @param width the image width
100
     * @param height the image height
101
     * @return the encoded image
102
     */    
103
    public static byte[] compress(byte[] data, int width, int height) {
104
        CCITTG4Encoder g4 = new CCITTG4Encoder(width);
105 2 1. compress : Replaced integer multiplication with division → NO_COVERAGE
2. compress : removed call to com/lowagie/text/pdf/codec/CCITTG4Encoder::fax4Encode → NO_COVERAGE
        g4.fax4Encode(data, 0, g4.rowbytes * height);
106 1 1. compress : mutated return of Object value for com/lowagie/text/pdf/codec/CCITTG4Encoder::compress to ( if (x != null) null else throw new RuntimeException ) → NO_COVERAGE
        return g4.close();
107
    }
108
    
109
    /**
110
     * Encodes a number of lines.
111
     * @param data the data to be encoded
112
     * @param height the number of lines to encode
113
     */    
114
    public void fax4Encode(byte[] data, int height) {
115 2 1. fax4Encode : Replaced integer multiplication with division → NO_COVERAGE
2. fax4Encode : removed call to com/lowagie/text/pdf/codec/CCITTG4Encoder::fax4Encode → NO_COVERAGE
        fax4Encode(data, 0, rowbytes * height);
116
    }
117
118
    private void putcode(int[] table) {
119 1 1. putcode : removed call to com/lowagie/text/pdf/codec/CCITTG4Encoder::putBits → NO_COVERAGE
        putBits(table[CODE], table[LENGTH]);
120
    }
121
    
122
    private void putspan(int span, int[][] tab) {
123
        int code, length;
124
        
125 2 1. putspan : changed conditional boundary → NO_COVERAGE
2. putspan : negated conditional → NO_COVERAGE
        while (span >= 2624) {
126
            int[] te = tab[63 + (2560>>6)];
127
            code = te[CODE];
128
            length = te[LENGTH];
129 1 1. putspan : removed call to com/lowagie/text/pdf/codec/CCITTG4Encoder::putBits → NO_COVERAGE
            putBits(code, length);
130 1 1. putspan : Replaced integer subtraction with addition → NO_COVERAGE
            span -= te[RUNLEN];
131
        }
132 2 1. putspan : changed conditional boundary → NO_COVERAGE
2. putspan : negated conditional → NO_COVERAGE
        if (span >= 64) {
133 2 1. putspan : Replaced Shift Right with Shift Left → NO_COVERAGE
2. putspan : Replaced integer addition with subtraction → NO_COVERAGE
            int[] te = tab[63 + (span>>6)];
134
            code = te[CODE];
135
            length = te[LENGTH];
136 1 1. putspan : removed call to com/lowagie/text/pdf/codec/CCITTG4Encoder::putBits → NO_COVERAGE
            putBits(code, length);
137 1 1. putspan : Replaced integer subtraction with addition → NO_COVERAGE
            span -= te[RUNLEN];
138
        }
139
        code = tab[span][CODE];
140
        length = tab[span][LENGTH];
141 1 1. putspan : removed call to com/lowagie/text/pdf/codec/CCITTG4Encoder::putBits → NO_COVERAGE
        putBits(code, length);
142
    }
143
    
144
    private void putBits(int bits, int length) {
145 2 1. putBits : changed conditional boundary → NO_COVERAGE
2. putBits : negated conditional → NO_COVERAGE
        while (length > bit) {
146 3 1. putBits : Replaced integer subtraction with addition → NO_COVERAGE
2. putBits : Replaced Shift Right with Shift Left → NO_COVERAGE
3. putBits : Replaced bitwise OR with AND → NO_COVERAGE
            data |= bits >> (length - bit);
147 1 1. putBits : Replaced integer subtraction with addition → NO_COVERAGE
            length -= bit;
148
            outBuf.append((byte)data);
149
            data = 0;
150
            bit = 8;
151
        }
152 4 1. putBits : Replaced bitwise AND with OR → NO_COVERAGE
2. putBits : Replaced integer subtraction with addition → NO_COVERAGE
3. putBits : Replaced Shift Left with Shift Right → NO_COVERAGE
4. putBits : Replaced bitwise OR with AND → NO_COVERAGE
        data |= (bits & msbmask[length]) << (bit - length);
153 1 1. putBits : Replaced integer subtraction with addition → NO_COVERAGE
        bit -= length;
154 1 1. putBits : negated conditional → NO_COVERAGE
        if (bit == 0) {
155
            outBuf.append((byte)data);
156
            data = 0;
157
            bit = 8;
158
        }
159
    }
160
    
161
    private void Fax3Encode2DRow() {
162
        int a0 = 0;
163 1 1. Fax3Encode2DRow : negated conditional → NO_COVERAGE
        int a1 = (pixel(dataBp, offsetData, 0) != 0 ? 0 : finddiff(dataBp, offsetData, 0, rowpixels, 0));
164 1 1. Fax3Encode2DRow : negated conditional → NO_COVERAGE
        int b1 = (pixel(refline, 0, 0) != 0 ? 0 : finddiff(refline, 0, 0, rowpixels, 0));
165
        int a2, b2;
166
        
167
        for (;;) {
168
            b2 = finddiff2(refline, 0, b1, rowpixels, pixel(refline, 0,b1));
169 2 1. Fax3Encode2DRow : changed conditional boundary → NO_COVERAGE
2. Fax3Encode2DRow : negated conditional → NO_COVERAGE
            if (b2 >= a1) {
170 1 1. Fax3Encode2DRow : Replaced integer subtraction with addition → NO_COVERAGE
                int d = b1 - a1;
171 4 1. Fax3Encode2DRow : changed conditional boundary → NO_COVERAGE
2. Fax3Encode2DRow : changed conditional boundary → NO_COVERAGE
3. Fax3Encode2DRow : negated conditional → NO_COVERAGE
4. Fax3Encode2DRow : negated conditional → NO_COVERAGE
                if (!(-3 <= d && d <= 3)) {    /* horizontal mode */
172
                    a2 = finddiff2(dataBp, offsetData, a1, rowpixels, pixel(dataBp, offsetData,a1));
173 1 1. Fax3Encode2DRow : removed call to com/lowagie/text/pdf/codec/CCITTG4Encoder::putcode → NO_COVERAGE
                    putcode(horizcode);
174 3 1. Fax3Encode2DRow : Replaced integer addition with subtraction → NO_COVERAGE
2. Fax3Encode2DRow : negated conditional → NO_COVERAGE
3. Fax3Encode2DRow : negated conditional → NO_COVERAGE
                    if (a0+a1 == 0 || pixel(dataBp, offsetData, a0) == 0) {
175 2 1. Fax3Encode2DRow : Replaced integer subtraction with addition → NO_COVERAGE
2. Fax3Encode2DRow : removed call to com/lowagie/text/pdf/codec/CCITTG4Encoder::putspan → NO_COVERAGE
                        putspan(a1-a0, TIFFFaxWhiteCodes);
176 2 1. Fax3Encode2DRow : Replaced integer subtraction with addition → NO_COVERAGE
2. Fax3Encode2DRow : removed call to com/lowagie/text/pdf/codec/CCITTG4Encoder::putspan → NO_COVERAGE
                        putspan(a2-a1, TIFFFaxBlackCodes);
177
                    } else {
178 2 1. Fax3Encode2DRow : Replaced integer subtraction with addition → NO_COVERAGE
2. Fax3Encode2DRow : removed call to com/lowagie/text/pdf/codec/CCITTG4Encoder::putspan → NO_COVERAGE
                        putspan(a1-a0, TIFFFaxBlackCodes);
179 2 1. Fax3Encode2DRow : Replaced integer subtraction with addition → NO_COVERAGE
2. Fax3Encode2DRow : removed call to com/lowagie/text/pdf/codec/CCITTG4Encoder::putspan → NO_COVERAGE
                        putspan(a2-a1, TIFFFaxWhiteCodes);
180
                    }
181
                    a0 = a2;
182
                } else {            /* vertical mode */
183 2 1. Fax3Encode2DRow : Replaced integer addition with subtraction → NO_COVERAGE
2. Fax3Encode2DRow : removed call to com/lowagie/text/pdf/codec/CCITTG4Encoder::putcode → NO_COVERAGE
                    putcode(vcodes[d+3]);
184
                    a0 = a1;
185
                }
186
            } else {                /* pass mode */
187 1 1. Fax3Encode2DRow : removed call to com/lowagie/text/pdf/codec/CCITTG4Encoder::putcode → NO_COVERAGE
                putcode(passcode);
188
                a0 = b2;
189
            }
190 2 1. Fax3Encode2DRow : changed conditional boundary → NO_COVERAGE
2. Fax3Encode2DRow : negated conditional → NO_COVERAGE
            if (a0 >= rowpixels)
191
                break;
192
            a1 = finddiff(dataBp, offsetData, a0, rowpixels, pixel(dataBp, offsetData,a0));
193 1 1. Fax3Encode2DRow : Replaced XOR with AND → NO_COVERAGE
            b1 = finddiff(refline, 0, a0, rowpixels, pixel(dataBp, offsetData,a0) ^ 1);
194
            b1 = finddiff(refline, 0, b1, rowpixels, pixel(dataBp, offsetData,a0));
195
        }
196
    }
197
    
198
    private void Fax4PostEncode() {
199 1 1. Fax4PostEncode : removed call to com/lowagie/text/pdf/codec/CCITTG4Encoder::putBits → NO_COVERAGE
        putBits(EOL, 12);
200 1 1. Fax4PostEncode : removed call to com/lowagie/text/pdf/codec/CCITTG4Encoder::putBits → NO_COVERAGE
        putBits(EOL, 12);
201 1 1. Fax4PostEncode : negated conditional → NO_COVERAGE
        if (bit != 8) {
202
            outBuf.append((byte)data);
203
            data = 0;
204
            bit = 8;
205
        }
206
    }
207
    
208
    /**
209
     * Closes the encoder and returns the encoded data.
210
     * @return the encoded data
211
     */    
212
    public byte[] close() {
213 1 1. close : removed call to com/lowagie/text/pdf/codec/CCITTG4Encoder::Fax4PostEncode → NO_COVERAGE
        Fax4PostEncode();
214 1 1. close : mutated return of Object value for com/lowagie/text/pdf/codec/CCITTG4Encoder::close to ( if (x != null) null else throw new RuntimeException ) → NO_COVERAGE
        return outBuf.toByteArray();
215
    }
216
    
217
    private int pixel(byte[] data, int offset, int bit) {
218 2 1. pixel : changed conditional boundary → NO_COVERAGE
2. pixel : negated conditional → NO_COVERAGE
        if (bit >= rowpixels)
219 1 1. pixel : replaced return of integer sized value with (x == 0 ? 1 : 0) → NO_COVERAGE
            return 0;
220 8 1. pixel : Replaced Shift Right with Shift Left → NO_COVERAGE
2. pixel : Replaced integer addition with subtraction → NO_COVERAGE
3. pixel : Replaced bitwise AND with OR → NO_COVERAGE
4. pixel : Replaced bitwise AND with OR → NO_COVERAGE
5. pixel : Replaced integer subtraction with addition → NO_COVERAGE
6. pixel : Replaced Shift Right with Shift Left → NO_COVERAGE
7. pixel : Replaced bitwise AND with OR → NO_COVERAGE
8. pixel : replaced return of integer sized value with (x == 0 ? 1 : 0) → NO_COVERAGE
        return ((data[offset + (bit >> 3)] & 0xff) >> (7-((bit)&7))) & 1;
221
    }
222
    
223
    private static int find1span(byte[] bp, int offset, int bs, int be) {
224 1 1. find1span : Replaced integer subtraction with addition → NO_COVERAGE
        int bits = be - bs;
225
        int n, span;
226
        
227 2 1. find1span : Replaced Shift Right with Shift Left → NO_COVERAGE
2. find1span : Replaced integer addition with subtraction → NO_COVERAGE
        int pos = offset + (bs >> 3);
228
        /*
229
         * Check partial byte on lhs.
230
         */
231 4 1. find1span : changed conditional boundary → NO_COVERAGE
2. find1span : Replaced bitwise AND with OR → NO_COVERAGE
3. find1span : negated conditional → NO_COVERAGE
4. find1span : negated conditional → NO_COVERAGE
        if (bits > 0 && (n = (bs & 7)) != 0) {
232 2 1. find1span : Replaced Shift Left with Shift Right → NO_COVERAGE
2. find1span : Replaced bitwise AND with OR → NO_COVERAGE
            span = oneruns[(bp[pos] << n) & 0xff];
233 3 1. find1span : changed conditional boundary → NO_COVERAGE
2. find1span : Replaced integer subtraction with addition → NO_COVERAGE
3. find1span : negated conditional → NO_COVERAGE
            if (span > 8-n)        /* table value too generous */
234 1 1. find1span : Replaced integer subtraction with addition → NO_COVERAGE
                span = 8-n;
235 2 1. find1span : changed conditional boundary → NO_COVERAGE
2. find1span : negated conditional → NO_COVERAGE
            if (span > bits)    /* constrain span to bit range */
236
                span = bits;
237 3 1. find1span : changed conditional boundary → NO_COVERAGE
2. find1span : Replaced integer addition with subtraction → NO_COVERAGE
3. find1span : negated conditional → NO_COVERAGE
            if (n+span < 8)        /* doesn't extend to edge of byte */
238 1 1. find1span : replaced return of integer sized value with (x == 0 ? 1 : 0) → NO_COVERAGE
                return span;
239 1 1. find1span : Replaced integer subtraction with addition → NO_COVERAGE
            bits -= span;
240 1 1. find1span : Changed increment from 1 to -1 → NO_COVERAGE
            pos++;
241
        } else
242
            span = 0;
243
        /*
244
         * Scan full bytes for all 1's.
245
         */
246 2 1. find1span : changed conditional boundary → NO_COVERAGE
2. find1span : negated conditional → NO_COVERAGE
        while (bits >= 8) {
247 1 1. find1span : negated conditional → NO_COVERAGE
            if (bp[pos] != -1)    /* end of run */
248 3 1. find1span : Replaced bitwise AND with OR → NO_COVERAGE
2. find1span : Replaced integer addition with subtraction → NO_COVERAGE
3. find1span : replaced return of integer sized value with (x == 0 ? 1 : 0) → NO_COVERAGE
                return (span + oneruns[bp[pos] & 0xff]);
249 1 1. find1span : Changed increment from 8 to -8 → NO_COVERAGE
            span += 8;
250 1 1. find1span : Changed increment from -8 to 8 → NO_COVERAGE
            bits -= 8;
251 1 1. find1span : Changed increment from 1 to -1 → NO_COVERAGE
            pos++;
252
        }
253
        /*
254
         * Check partial byte on rhs.
255
         */
256 2 1. find1span : changed conditional boundary → NO_COVERAGE
2. find1span : negated conditional → NO_COVERAGE
        if (bits > 0) {
257 1 1. find1span : Replaced bitwise AND with OR → NO_COVERAGE
            n = oneruns[bp[pos] & 0xff];
258 3 1. find1span : changed conditional boundary → NO_COVERAGE
2. find1span : Replaced integer addition with subtraction → NO_COVERAGE
3. find1span : negated conditional → NO_COVERAGE
            span += (n > bits ? bits : n);
259
        }
260 1 1. find1span : replaced return of integer sized value with (x == 0 ? 1 : 0) → NO_COVERAGE
        return span;
261
    }
262
    
263
    private static int find0span(byte[] bp, int offset, int bs, int be) {
264 1 1. find0span : Replaced integer subtraction with addition → NO_COVERAGE
        int bits = be - bs;
265
        int n, span;
266
        
267 2 1. find0span : Replaced Shift Right with Shift Left → NO_COVERAGE
2. find0span : Replaced integer addition with subtraction → NO_COVERAGE
        int pos = offset + (bs >> 3);
268
        /*
269
         * Check partial byte on lhs.
270
         */
271 4 1. find0span : changed conditional boundary → NO_COVERAGE
2. find0span : Replaced bitwise AND with OR → NO_COVERAGE
3. find0span : negated conditional → NO_COVERAGE
4. find0span : negated conditional → NO_COVERAGE
        if (bits > 0 && (n = (bs & 7)) != 0) {
272 2 1. find0span : Replaced Shift Left with Shift Right → NO_COVERAGE
2. find0span : Replaced bitwise AND with OR → NO_COVERAGE
            span = zeroruns[(bp[pos] << n) & 0xff];
273 3 1. find0span : changed conditional boundary → NO_COVERAGE
2. find0span : Replaced integer subtraction with addition → NO_COVERAGE
3. find0span : negated conditional → NO_COVERAGE
            if (span > 8-n)        /* table value too generous */
274 1 1. find0span : Replaced integer subtraction with addition → NO_COVERAGE
                span = 8-n;
275 2 1. find0span : changed conditional boundary → NO_COVERAGE
2. find0span : negated conditional → NO_COVERAGE
            if (span > bits)    /* constrain span to bit range */
276
                span = bits;
277 3 1. find0span : changed conditional boundary → NO_COVERAGE
2. find0span : Replaced integer addition with subtraction → NO_COVERAGE
3. find0span : negated conditional → NO_COVERAGE
            if (n+span < 8)        /* doesn't extend to edge of byte */
278 1 1. find0span : replaced return of integer sized value with (x == 0 ? 1 : 0) → NO_COVERAGE
                return span;
279 1 1. find0span : Replaced integer subtraction with addition → NO_COVERAGE
            bits -= span;
280 1 1. find0span : Changed increment from 1 to -1 → NO_COVERAGE
            pos++;
281
        } else
282
            span = 0;
283
        /*
284
         * Scan full bytes for all 1's.
285
         */
286 2 1. find0span : changed conditional boundary → NO_COVERAGE
2. find0span : negated conditional → NO_COVERAGE
        while (bits >= 8) {
287 1 1. find0span : negated conditional → NO_COVERAGE
            if (bp[pos] != 0)    /* end of run */
288 3 1. find0span : Replaced bitwise AND with OR → NO_COVERAGE
2. find0span : Replaced integer addition with subtraction → NO_COVERAGE
3. find0span : replaced return of integer sized value with (x == 0 ? 1 : 0) → NO_COVERAGE
                return (span + zeroruns[bp[pos] & 0xff]);
289 1 1. find0span : Changed increment from 8 to -8 → NO_COVERAGE
            span += 8;
290 1 1. find0span : Changed increment from -8 to 8 → NO_COVERAGE
            bits -= 8;
291 1 1. find0span : Changed increment from 1 to -1 → NO_COVERAGE
            pos++;
292
        }
293
        /*
294
         * Check partial byte on rhs.
295
         */
296 2 1. find0span : changed conditional boundary → NO_COVERAGE
2. find0span : negated conditional → NO_COVERAGE
        if (bits > 0) {
297 1 1. find0span : Replaced bitwise AND with OR → NO_COVERAGE
            n = zeroruns[bp[pos] & 0xff];
298 3 1. find0span : changed conditional boundary → NO_COVERAGE
2. find0span : Replaced integer addition with subtraction → NO_COVERAGE
3. find0span : negated conditional → NO_COVERAGE
            span += (n > bits ? bits : n);
299
        }
300 1 1. find0span : replaced return of integer sized value with (x == 0 ? 1 : 0) → NO_COVERAGE
        return span;
301
    }
302
    
303
    private static int finddiff(byte[] bp, int offset, int bs, int be, int color) {
304 3 1. finddiff : Replaced integer addition with subtraction → NO_COVERAGE
2. finddiff : negated conditional → NO_COVERAGE
3. finddiff : replaced return of integer sized value with (x == 0 ? 1 : 0) → NO_COVERAGE
        return bs + (color != 0 ? find1span(bp, offset, bs, be) : find0span(bp, offset, bs, be));
305
    }
306
    
307
    private static int finddiff2(byte[] bp, int offset, int bs, int be, int color) {
308 3 1. finddiff2 : changed conditional boundary → NO_COVERAGE
2. finddiff2 : negated conditional → NO_COVERAGE
3. finddiff2 : replaced return of integer sized value with (x == 0 ? 1 : 0) → NO_COVERAGE
        return bs < be ? finddiff(bp, offset, bs, be, color) : be;
309
    }
310
311
    private static byte[] zeroruns = {
312
            8, 7, 6, 6, 5, 5, 5, 5, 4, 4, 4, 4, 4, 4, 4, 4,    /* 0x00 - 0x0f */
313
            3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3,    /* 0x10 - 0x1f */
314
            2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,    /* 0x20 - 0x2f */
315
            2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,    /* 0x30 - 0x3f */
316
            1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,    /* 0x40 - 0x4f */
317
            1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,    /* 0x50 - 0x5f */
318
            1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,    /* 0x60 - 0x6f */
319
            1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,    /* 0x70 - 0x7f */
320
            0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,    /* 0x80 - 0x8f */
321
            0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,    /* 0x90 - 0x9f */
322
            0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,    /* 0xa0 - 0xaf */
323
            0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,    /* 0xb0 - 0xbf */
324
            0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,    /* 0xc0 - 0xcf */
325
            0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,    /* 0xd0 - 0xdf */
326
            0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,    /* 0xe0 - 0xef */
327
            0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0    /* 0xf0 - 0xff */
328
    };
329
330
    private static byte[] oneruns = {
331
            0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,    /* 0x00 - 0x0f */
332
            0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,    /* 0x10 - 0x1f */
333
            0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,    /* 0x20 - 0x2f */
334
            0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,    /* 0x30 - 0x3f */
335
            0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,    /* 0x40 - 0x4f */
336
            0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,    /* 0x50 - 0x5f */
337
            0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,    /* 0x60 - 0x6f */
338
            0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,    /* 0x70 - 0x7f */
339
            1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,    /* 0x80 - 0x8f */
340
            1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,    /* 0x90 - 0x9f */
341
            1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,    /* 0xa0 - 0xaf */
342
            1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,    /* 0xb0 - 0xbf */
343
            2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,    /* 0xc0 - 0xcf */
344
            2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,    /* 0xd0 - 0xdf */
345
            3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3,    /* 0xe0 - 0xef */
346
            4, 4, 4, 4, 4, 4, 4, 4, 5, 5, 5, 5, 6, 6, 7, 8    /* 0xf0 - 0xff */
347
    };
348
349
    private static final int LENGTH = 0; /* bit length of g3 code */
350
    private static final int CODE = 1;   /* g3 code */
351
    private static final int RUNLEN = 2; /* run length in bits */
352
353
    private static final int EOL = 0x001; /* EOL code value - 0000 0000 0000 1 */
354
355
    /* status values returned instead of a run length */
356
    private static final int G3CODE_EOL    = -1;     /* NB: ACT_EOL - ACT_WRUNT */
357
    private static final int G3CODE_INVALID = -2; /* NB: ACT_INVALID - ACT_WRUNT */
358
    private static final int G3CODE_EOF = -3;     /* end of input data */
359
    private static final int G3CODE_INCOMP = -4;  /* incomplete run code */
360
361
    private int[][] TIFFFaxWhiteCodes = {
362
        { 8, 0x35, 0 },    /* 0011 0101 */
363
        { 6, 0x7, 1 },    /* 0001 11 */
364
        { 4, 0x7, 2 },    /* 0111 */
365
        { 4, 0x8, 3 },    /* 1000 */
366
        { 4, 0xB, 4 },    /* 1011 */
367
        { 4, 0xC, 5 },    /* 1100 */
368
        { 4, 0xE, 6 },    /* 1110 */
369
        { 4, 0xF, 7 },    /* 1111 */
370
        { 5, 0x13, 8 },    /* 1001 1 */
371
        { 5, 0x14, 9 },    /* 1010 0 */
372
        { 5, 0x7, 10 },    /* 0011 1 */
373
        { 5, 0x8, 11 },    /* 0100 0 */
374
        { 6, 0x8, 12 },    /* 0010 00 */
375
        { 6, 0x3, 13 },    /* 0000 11 */
376
        { 6, 0x34, 14 },    /* 1101 00 */
377
        { 6, 0x35, 15 },    /* 1101 01 */
378
        { 6, 0x2A, 16 },    /* 1010 10 */
379
        { 6, 0x2B, 17 },    /* 1010 11 */
380
        { 7, 0x27, 18 },    /* 0100 111 */
381
        { 7, 0xC, 19 },    /* 0001 100 */
382
        { 7, 0x8, 20 },    /* 0001 000 */
383
        { 7, 0x17, 21 },    /* 0010 111 */
384
        { 7, 0x3, 22 },    /* 0000 011 */
385
        { 7, 0x4, 23 },    /* 0000 100 */
386
        { 7, 0x28, 24 },    /* 0101 000 */
387
        { 7, 0x2B, 25 },    /* 0101 011 */
388
        { 7, 0x13, 26 },    /* 0010 011 */
389
        { 7, 0x24, 27 },    /* 0100 100 */
390
        { 7, 0x18, 28 },    /* 0011 000 */
391
        { 8, 0x2, 29 },    /* 0000 0010 */
392
        { 8, 0x3, 30 },    /* 0000 0011 */
393
        { 8, 0x1A, 31 },    /* 0001 1010 */
394
        { 8, 0x1B, 32 },    /* 0001 1011 */
395
        { 8, 0x12, 33 },    /* 0001 0010 */
396
        { 8, 0x13, 34 },    /* 0001 0011 */
397
        { 8, 0x14, 35 },    /* 0001 0100 */
398
        { 8, 0x15, 36 },    /* 0001 0101 */
399
        { 8, 0x16, 37 },    /* 0001 0110 */
400
        { 8, 0x17, 38 },    /* 0001 0111 */
401
        { 8, 0x28, 39 },    /* 0010 1000 */
402
        { 8, 0x29, 40 },    /* 0010 1001 */
403
        { 8, 0x2A, 41 },    /* 0010 1010 */
404
        { 8, 0x2B, 42 },    /* 0010 1011 */
405
        { 8, 0x2C, 43 },    /* 0010 1100 */
406
        { 8, 0x2D, 44 },    /* 0010 1101 */
407
        { 8, 0x4, 45 },    /* 0000 0100 */
408
        { 8, 0x5, 46 },    /* 0000 0101 */
409
        { 8, 0xA, 47 },    /* 0000 1010 */
410
        { 8, 0xB, 48 },    /* 0000 1011 */
411
        { 8, 0x52, 49 },    /* 0101 0010 */
412
        { 8, 0x53, 50 },    /* 0101 0011 */
413
        { 8, 0x54, 51 },    /* 0101 0100 */
414
        { 8, 0x55, 52 },    /* 0101 0101 */
415
        { 8, 0x24, 53 },    /* 0010 0100 */
416
        { 8, 0x25, 54 },    /* 0010 0101 */
417
        { 8, 0x58, 55 },    /* 0101 1000 */
418
        { 8, 0x59, 56 },    /* 0101 1001 */
419
        { 8, 0x5A, 57 },    /* 0101 1010 */
420
        { 8, 0x5B, 58 },    /* 0101 1011 */
421
        { 8, 0x4A, 59 },    /* 0100 1010 */
422
        { 8, 0x4B, 60 },    /* 0100 1011 */
423
        { 8, 0x32, 61 },    /* 0011 0010 */
424
        { 8, 0x33, 62 },    /* 0011 0011 */
425
        { 8, 0x34, 63 },    /* 0011 0100 */
426
        { 5, 0x1B, 64 },    /* 1101 1 */
427
        { 5, 0x12, 128 },    /* 1001 0 */
428
        { 6, 0x17, 192 },    /* 0101 11 */
429
        { 7, 0x37, 256 },    /* 0110 111 */
430
        { 8, 0x36, 320 },    /* 0011 0110 */
431
        { 8, 0x37, 384 },    /* 0011 0111 */
432
        { 8, 0x64, 448 },    /* 0110 0100 */
433
        { 8, 0x65, 512 },    /* 0110 0101 */
434
        { 8, 0x68, 576 },    /* 0110 1000 */
435
        { 8, 0x67, 640 },    /* 0110 0111 */
436
        { 9, 0xCC, 704 },    /* 0110 0110 0 */
437
        { 9, 0xCD, 768 },    /* 0110 0110 1 */
438
        { 9, 0xD2, 832 },    /* 0110 1001 0 */
439
        { 9, 0xD3, 896 },    /* 0110 1001 1 */
440
        { 9, 0xD4, 960 },    /* 0110 1010 0 */
441
        { 9, 0xD5, 1024 },    /* 0110 1010 1 */
442
        { 9, 0xD6, 1088 },    /* 0110 1011 0 */
443
        { 9, 0xD7, 1152 },    /* 0110 1011 1 */
444
        { 9, 0xD8, 1216 },    /* 0110 1100 0 */
445
        { 9, 0xD9, 1280 },    /* 0110 1100 1 */
446
        { 9, 0xDA, 1344 },    /* 0110 1101 0 */
447
        { 9, 0xDB, 1408 },    /* 0110 1101 1 */
448
        { 9, 0x98, 1472 },    /* 0100 1100 0 */
449
        { 9, 0x99, 1536 },    /* 0100 1100 1 */
450
        { 9, 0x9A, 1600 },    /* 0100 1101 0 */
451
        { 6, 0x18, 1664 },    /* 0110 00 */
452
        { 9, 0x9B, 1728 },    /* 0100 1101 1 */
453
        { 11, 0x8, 1792 },    /* 0000 0001 000 */
454
        { 11, 0xC, 1856 },    /* 0000 0001 100 */
455
        { 11, 0xD, 1920 },    /* 0000 0001 101 */
456
        { 12, 0x12, 1984 },    /* 0000 0001 0010 */
457
        { 12, 0x13, 2048 },    /* 0000 0001 0011 */
458
        { 12, 0x14, 2112 },    /* 0000 0001 0100 */
459
        { 12, 0x15, 2176 },    /* 0000 0001 0101 */
460
        { 12, 0x16, 2240 },    /* 0000 0001 0110 */
461
        { 12, 0x17, 2304 },    /* 0000 0001 0111 */
462
        { 12, 0x1C, 2368 },    /* 0000 0001 1100 */
463
        { 12, 0x1D, 2432 },    /* 0000 0001 1101 */
464
        { 12, 0x1E, 2496 },    /* 0000 0001 1110 */
465
        { 12, 0x1F, 2560 },    /* 0000 0001 1111 */
466
        { 12, 0x1, G3CODE_EOL },    /* 0000 0000 0001 */
467
        { 9, 0x1, G3CODE_INVALID },    /* 0000 0000 1 */
468
        { 10, 0x1, G3CODE_INVALID },    /* 0000 0000 01 */
469
        { 11, 0x1, G3CODE_INVALID },    /* 0000 0000 001 */
470
        { 12, 0x0, G3CODE_INVALID }    /* 0000 0000 0000 */
471
    };
472
473
    private int[][] TIFFFaxBlackCodes = {
474
        { 10, 0x37, 0 },    /* 0000 1101 11 */
475
        { 3, 0x2, 1 },    /* 010 */
476
        { 2, 0x3, 2 },    /* 11 */
477
        { 2, 0x2, 3 },    /* 10 */
478
        { 3, 0x3, 4 },    /* 011 */
479
        { 4, 0x3, 5 },    /* 0011 */
480
        { 4, 0x2, 6 },    /* 0010 */
481
        { 5, 0x3, 7 },    /* 0001 1 */
482
        { 6, 0x5, 8 },    /* 0001 01 */
483
        { 6, 0x4, 9 },    /* 0001 00 */
484
        { 7, 0x4, 10 },    /* 0000 100 */
485
        { 7, 0x5, 11 },    /* 0000 101 */
486
        { 7, 0x7, 12 },    /* 0000 111 */
487
        { 8, 0x4, 13 },    /* 0000 0100 */
488
        { 8, 0x7, 14 },    /* 0000 0111 */
489
        { 9, 0x18, 15 },    /* 0000 1100 0 */
490
        { 10, 0x17, 16 },    /* 0000 0101 11 */
491
        { 10, 0x18, 17 },    /* 0000 0110 00 */
492
        { 10, 0x8, 18 },    /* 0000 0010 00 */
493
        { 11, 0x67, 19 },    /* 0000 1100 111 */
494
        { 11, 0x68, 20 },    /* 0000 1101 000 */
495
        { 11, 0x6C, 21 },    /* 0000 1101 100 */
496
        { 11, 0x37, 22 },    /* 0000 0110 111 */
497
        { 11, 0x28, 23 },    /* 0000 0101 000 */
498
        { 11, 0x17, 24 },    /* 0000 0010 111 */
499
        { 11, 0x18, 25 },    /* 0000 0011 000 */
500
        { 12, 0xCA, 26 },    /* 0000 1100 1010 */
501
        { 12, 0xCB, 27 },    /* 0000 1100 1011 */
502
        { 12, 0xCC, 28 },    /* 0000 1100 1100 */
503
        { 12, 0xCD, 29 },    /* 0000 1100 1101 */
504
        { 12, 0x68, 30 },    /* 0000 0110 1000 */
505
        { 12, 0x69, 31 },    /* 0000 0110 1001 */
506
        { 12, 0x6A, 32 },    /* 0000 0110 1010 */
507
        { 12, 0x6B, 33 },    /* 0000 0110 1011 */
508
        { 12, 0xD2, 34 },    /* 0000 1101 0010 */
509
        { 12, 0xD3, 35 },    /* 0000 1101 0011 */
510
        { 12, 0xD4, 36 },    /* 0000 1101 0100 */
511
        { 12, 0xD5, 37 },    /* 0000 1101 0101 */
512
        { 12, 0xD6, 38 },    /* 0000 1101 0110 */
513
        { 12, 0xD7, 39 },    /* 0000 1101 0111 */
514
        { 12, 0x6C, 40 },    /* 0000 0110 1100 */
515
        { 12, 0x6D, 41 },    /* 0000 0110 1101 */
516
        { 12, 0xDA, 42 },    /* 0000 1101 1010 */
517
        { 12, 0xDB, 43 },    /* 0000 1101 1011 */
518
        { 12, 0x54, 44 },    /* 0000 0101 0100 */
519
        { 12, 0x55, 45 },    /* 0000 0101 0101 */
520
        { 12, 0x56, 46 },    /* 0000 0101 0110 */
521
        { 12, 0x57, 47 },    /* 0000 0101 0111 */
522
        { 12, 0x64, 48 },    /* 0000 0110 0100 */
523
        { 12, 0x65, 49 },    /* 0000 0110 0101 */
524
        { 12, 0x52, 50 },    /* 0000 0101 0010 */
525
        { 12, 0x53, 51 },    /* 0000 0101 0011 */
526
        { 12, 0x24, 52 },    /* 0000 0010 0100 */
527
        { 12, 0x37, 53 },    /* 0000 0011 0111 */
528
        { 12, 0x38, 54 },    /* 0000 0011 1000 */
529
        { 12, 0x27, 55 },    /* 0000 0010 0111 */
530
        { 12, 0x28, 56 },    /* 0000 0010 1000 */
531
        { 12, 0x58, 57 },    /* 0000 0101 1000 */
532
        { 12, 0x59, 58 },    /* 0000 0101 1001 */
533
        { 12, 0x2B, 59 },    /* 0000 0010 1011 */
534
        { 12, 0x2C, 60 },    /* 0000 0010 1100 */
535
        { 12, 0x5A, 61 },    /* 0000 0101 1010 */
536
        { 12, 0x66, 62 },    /* 0000 0110 0110 */
537
        { 12, 0x67, 63 },    /* 0000 0110 0111 */
538
        { 10, 0xF, 64 },    /* 0000 0011 11 */
539
        { 12, 0xC8, 128 },    /* 0000 1100 1000 */
540
        { 12, 0xC9, 192 },    /* 0000 1100 1001 */
541
        { 12, 0x5B, 256 },    /* 0000 0101 1011 */
542
        { 12, 0x33, 320 },    /* 0000 0011 0011 */
543
        { 12, 0x34, 384 },    /* 0000 0011 0100 */
544
        { 12, 0x35, 448 },    /* 0000 0011 0101 */
545
        { 13, 0x6C, 512 },    /* 0000 0011 0110 0 */
546
        { 13, 0x6D, 576 },    /* 0000 0011 0110 1 */
547
        { 13, 0x4A, 640 },    /* 0000 0010 0101 0 */
548
        { 13, 0x4B, 704 },    /* 0000 0010 0101 1 */
549
        { 13, 0x4C, 768 },    /* 0000 0010 0110 0 */
550
        { 13, 0x4D, 832 },    /* 0000 0010 0110 1 */
551
        { 13, 0x72, 896 },    /* 0000 0011 1001 0 */
552
        { 13, 0x73, 960 },    /* 0000 0011 1001 1 */
553
        { 13, 0x74, 1024 },    /* 0000 0011 1010 0 */
554
        { 13, 0x75, 1088 },    /* 0000 0011 1010 1 */
555
        { 13, 0x76, 1152 },    /* 0000 0011 1011 0 */
556
        { 13, 0x77, 1216 },    /* 0000 0011 1011 1 */
557
        { 13, 0x52, 1280 },    /* 0000 0010 1001 0 */
558
        { 13, 0x53, 1344 },    /* 0000 0010 1001 1 */
559
        { 13, 0x54, 1408 },    /* 0000 0010 1010 0 */
560
        { 13, 0x55, 1472 },    /* 0000 0010 1010 1 */
561
        { 13, 0x5A, 1536 },    /* 0000 0010 1101 0 */
562
        { 13, 0x5B, 1600 },    /* 0000 0010 1101 1 */
563
        { 13, 0x64, 1664 },    /* 0000 0011 0010 0 */
564
        { 13, 0x65, 1728 },    /* 0000 0011 0010 1 */
565
        { 11, 0x8, 1792 },    /* 0000 0001 000 */
566
        { 11, 0xC, 1856 },    /* 0000 0001 100 */
567
        { 11, 0xD, 1920 },    /* 0000 0001 101 */
568
        { 12, 0x12, 1984 },    /* 0000 0001 0010 */
569
        { 12, 0x13, 2048 },    /* 0000 0001 0011 */
570
        { 12, 0x14, 2112 },    /* 0000 0001 0100 */
571
        { 12, 0x15, 2176 },    /* 0000 0001 0101 */
572
        { 12, 0x16, 2240 },    /* 0000 0001 0110 */
573
        { 12, 0x17, 2304 },    /* 0000 0001 0111 */
574
        { 12, 0x1C, 2368 },    /* 0000 0001 1100 */
575
        { 12, 0x1D, 2432 },    /* 0000 0001 1101 */
576
        { 12, 0x1E, 2496 },    /* 0000 0001 1110 */
577
        { 12, 0x1F, 2560 },    /* 0000 0001 1111 */
578
        { 12, 0x1, G3CODE_EOL },    /* 0000 0000 0001 */
579
        { 9, 0x1, G3CODE_INVALID },    /* 0000 0000 1 */
580
        { 10, 0x1, G3CODE_INVALID },    /* 0000 0000 01 */
581
        { 11, 0x1, G3CODE_INVALID },    /* 0000 0000 001 */
582
        { 12, 0x0, G3CODE_INVALID }    /* 0000 0000 0000 */
583
    };
584
    
585
    private int[] horizcode =
586
        { 3, 0x1, 0 };        /* 001 */
587
    private int[] passcode =
588
        { 4, 0x1, 0 };        /* 0001 */
589
    private int[][] vcodes = {
590
        { 7, 0x03, 0 },    /* 0000 011 */
591
        { 6, 0x03, 0 },    /* 0000 11 */
592
        { 3, 0x03, 0 },    /* 011 */
593
        { 1, 0x1, 0 },        /* 1 */
594
        { 3, 0x2, 0 },        /* 010 */
595
        { 6, 0x02, 0 },    /* 0000 10 */
596
        { 7, 0x02, 0 }        /* 0000 010 */
597
    };
598
    private int[] msbmask =
599
    { 0x00, 0x01, 0x03, 0x07, 0x0f, 0x1f, 0x3f, 0x7f, 0xff };
600
}

Mutations

73

1.1
Location :
Killed by : none
Replaced integer addition with subtraction → NO_COVERAGE

2.2
Location :
Killed by : none
Replaced integer division with multiplication → NO_COVERAGE

87

1.1
Location : fax4Encode
Killed by : none
changed conditional boundary → NO_COVERAGE

2.2
Location : fax4Encode
Killed by : none
negated conditional → NO_COVERAGE

88

1.1
Location : fax4Encode
Killed by : none
removed call to com/lowagie/text/pdf/codec/CCITTG4Encoder::Fax3Encode2DRow → NO_COVERAGE

89

1.1
Location : fax4Encode
Killed by : none
removed call to java/lang/System::arraycopy → NO_COVERAGE

90

1.1
Location : fax4Encode
Killed by : none
Replaced integer addition with subtraction → NO_COVERAGE

91

1.1
Location : fax4Encode
Killed by : none
Replaced integer subtraction with addition → NO_COVERAGE

105

1.1
Location : compress
Killed by : none
Replaced integer multiplication with division → NO_COVERAGE

2.2
Location : compress
Killed by : none
removed call to com/lowagie/text/pdf/codec/CCITTG4Encoder::fax4Encode → NO_COVERAGE

106

1.1
Location : compress
Killed by : none
mutated return of Object value for com/lowagie/text/pdf/codec/CCITTG4Encoder::compress to ( if (x != null) null else throw new RuntimeException ) → NO_COVERAGE

115

1.1
Location : fax4Encode
Killed by : none
Replaced integer multiplication with division → NO_COVERAGE

2.2
Location : fax4Encode
Killed by : none
removed call to com/lowagie/text/pdf/codec/CCITTG4Encoder::fax4Encode → NO_COVERAGE

119

1.1
Location : putcode
Killed by : none
removed call to com/lowagie/text/pdf/codec/CCITTG4Encoder::putBits → NO_COVERAGE

125

1.1
Location : putspan
Killed by : none
changed conditional boundary → NO_COVERAGE

2.2
Location : putspan
Killed by : none
negated conditional → NO_COVERAGE

129

1.1
Location : putspan
Killed by : none
removed call to com/lowagie/text/pdf/codec/CCITTG4Encoder::putBits → NO_COVERAGE

130

1.1
Location : putspan
Killed by : none
Replaced integer subtraction with addition → NO_COVERAGE

132

1.1
Location : putspan
Killed by : none
changed conditional boundary → NO_COVERAGE

2.2
Location : putspan
Killed by : none
negated conditional → NO_COVERAGE

133

1.1
Location : putspan
Killed by : none
Replaced Shift Right with Shift Left → NO_COVERAGE

2.2
Location : putspan
Killed by : none
Replaced integer addition with subtraction → NO_COVERAGE

136

1.1
Location : putspan
Killed by : none
removed call to com/lowagie/text/pdf/codec/CCITTG4Encoder::putBits → NO_COVERAGE

137

1.1
Location : putspan
Killed by : none
Replaced integer subtraction with addition → NO_COVERAGE

141

1.1
Location : putspan
Killed by : none
removed call to com/lowagie/text/pdf/codec/CCITTG4Encoder::putBits → NO_COVERAGE

145

1.1
Location : putBits
Killed by : none
changed conditional boundary → NO_COVERAGE

2.2
Location : putBits
Killed by : none
negated conditional → NO_COVERAGE

146

1.1
Location : putBits
Killed by : none
Replaced integer subtraction with addition → NO_COVERAGE

2.2
Location : putBits
Killed by : none
Replaced Shift Right with Shift Left → NO_COVERAGE

3.3
Location : putBits
Killed by : none
Replaced bitwise OR with AND → NO_COVERAGE

147

1.1
Location : putBits
Killed by : none
Replaced integer subtraction with addition → NO_COVERAGE

152

1.1
Location : putBits
Killed by : none
Replaced bitwise AND with OR → NO_COVERAGE

2.2
Location : putBits
Killed by : none
Replaced integer subtraction with addition → NO_COVERAGE

3.3
Location : putBits
Killed by : none
Replaced Shift Left with Shift Right → NO_COVERAGE

4.4
Location : putBits
Killed by : none
Replaced bitwise OR with AND → NO_COVERAGE

153

1.1
Location : putBits
Killed by : none
Replaced integer subtraction with addition → NO_COVERAGE

154

1.1
Location : putBits
Killed by : none
negated conditional → NO_COVERAGE

163

1.1
Location : Fax3Encode2DRow
Killed by : none
negated conditional → NO_COVERAGE

164

1.1
Location : Fax3Encode2DRow
Killed by : none
negated conditional → NO_COVERAGE

169

1.1
Location : Fax3Encode2DRow
Killed by : none
changed conditional boundary → NO_COVERAGE

2.2
Location : Fax3Encode2DRow
Killed by : none
negated conditional → NO_COVERAGE

170

1.1
Location : Fax3Encode2DRow
Killed by : none
Replaced integer subtraction with addition → NO_COVERAGE

171

1.1
Location : Fax3Encode2DRow
Killed by : none
changed conditional boundary → NO_COVERAGE

2.2
Location : Fax3Encode2DRow
Killed by : none
changed conditional boundary → NO_COVERAGE

3.3
Location : Fax3Encode2DRow
Killed by : none
negated conditional → NO_COVERAGE

4.4
Location : Fax3Encode2DRow
Killed by : none
negated conditional → NO_COVERAGE

173

1.1
Location : Fax3Encode2DRow
Killed by : none
removed call to com/lowagie/text/pdf/codec/CCITTG4Encoder::putcode → NO_COVERAGE

174

1.1
Location : Fax3Encode2DRow
Killed by : none
Replaced integer addition with subtraction → NO_COVERAGE

2.2
Location : Fax3Encode2DRow
Killed by : none
negated conditional → NO_COVERAGE

3.3
Location : Fax3Encode2DRow
Killed by : none
negated conditional → NO_COVERAGE

175

1.1
Location : Fax3Encode2DRow
Killed by : none
Replaced integer subtraction with addition → NO_COVERAGE

2.2
Location : Fax3Encode2DRow
Killed by : none
removed call to com/lowagie/text/pdf/codec/CCITTG4Encoder::putspan → NO_COVERAGE

176

1.1
Location : Fax3Encode2DRow
Killed by : none
Replaced integer subtraction with addition → NO_COVERAGE

2.2
Location : Fax3Encode2DRow
Killed by : none
removed call to com/lowagie/text/pdf/codec/CCITTG4Encoder::putspan → NO_COVERAGE

178

1.1
Location : Fax3Encode2DRow
Killed by : none
Replaced integer subtraction with addition → NO_COVERAGE

2.2
Location : Fax3Encode2DRow
Killed by : none
removed call to com/lowagie/text/pdf/codec/CCITTG4Encoder::putspan → NO_COVERAGE

179

1.1
Location : Fax3Encode2DRow
Killed by : none
Replaced integer subtraction with addition → NO_COVERAGE

2.2
Location : Fax3Encode2DRow
Killed by : none
removed call to com/lowagie/text/pdf/codec/CCITTG4Encoder::putspan → NO_COVERAGE

183

1.1
Location : Fax3Encode2DRow
Killed by : none
Replaced integer addition with subtraction → NO_COVERAGE

2.2
Location : Fax3Encode2DRow
Killed by : none
removed call to com/lowagie/text/pdf/codec/CCITTG4Encoder::putcode → NO_COVERAGE

187

1.1
Location : Fax3Encode2DRow
Killed by : none
removed call to com/lowagie/text/pdf/codec/CCITTG4Encoder::putcode → NO_COVERAGE

190

1.1
Location : Fax3Encode2DRow
Killed by : none
changed conditional boundary → NO_COVERAGE

2.2
Location : Fax3Encode2DRow
Killed by : none
negated conditional → NO_COVERAGE

193

1.1
Location : Fax3Encode2DRow
Killed by : none
Replaced XOR with AND → NO_COVERAGE

199

1.1
Location : Fax4PostEncode
Killed by : none
removed call to com/lowagie/text/pdf/codec/CCITTG4Encoder::putBits → NO_COVERAGE

200

1.1
Location : Fax4PostEncode
Killed by : none
removed call to com/lowagie/text/pdf/codec/CCITTG4Encoder::putBits → NO_COVERAGE

201

1.1
Location : Fax4PostEncode
Killed by : none
negated conditional → NO_COVERAGE

213

1.1
Location : close
Killed by : none
removed call to com/lowagie/text/pdf/codec/CCITTG4Encoder::Fax4PostEncode → NO_COVERAGE

214

1.1
Location : close
Killed by : none
mutated return of Object value for com/lowagie/text/pdf/codec/CCITTG4Encoder::close to ( if (x != null) null else throw new RuntimeException ) → NO_COVERAGE

218

1.1
Location : pixel
Killed by : none
changed conditional boundary → NO_COVERAGE

2.2
Location : pixel
Killed by : none
negated conditional → NO_COVERAGE

219

1.1
Location : pixel
Killed by : none
replaced return of integer sized value with (x == 0 ? 1 : 0) → NO_COVERAGE

220

1.1
Location : pixel
Killed by : none
Replaced Shift Right with Shift Left → NO_COVERAGE

2.2
Location : pixel
Killed by : none
Replaced integer addition with subtraction → NO_COVERAGE

3.3
Location : pixel
Killed by : none
Replaced bitwise AND with OR → NO_COVERAGE

4.4
Location : pixel
Killed by : none
Replaced bitwise AND with OR → NO_COVERAGE

5.5
Location : pixel
Killed by : none
Replaced integer subtraction with addition → NO_COVERAGE

6.6
Location : pixel
Killed by : none
Replaced Shift Right with Shift Left → NO_COVERAGE

7.7
Location : pixel
Killed by : none
Replaced bitwise AND with OR → NO_COVERAGE

8.8
Location : pixel
Killed by : none
replaced return of integer sized value with (x == 0 ? 1 : 0) → NO_COVERAGE

224

1.1
Location : find1span
Killed by : none
Replaced integer subtraction with addition → NO_COVERAGE

227

1.1
Location : find1span
Killed by : none
Replaced Shift Right with Shift Left → NO_COVERAGE

2.2
Location : find1span
Killed by : none
Replaced integer addition with subtraction → NO_COVERAGE

231

1.1
Location : find1span
Killed by : none
changed conditional boundary → NO_COVERAGE

2.2
Location : find1span
Killed by : none
Replaced bitwise AND with OR → NO_COVERAGE

3.3
Location : find1span
Killed by : none
negated conditional → NO_COVERAGE

4.4
Location : find1span
Killed by : none
negated conditional → NO_COVERAGE

232

1.1
Location : find1span
Killed by : none
Replaced Shift Left with Shift Right → NO_COVERAGE

2.2
Location : find1span
Killed by : none
Replaced bitwise AND with OR → NO_COVERAGE

233

1.1
Location : find1span
Killed by : none
changed conditional boundary → NO_COVERAGE

2.2
Location : find1span
Killed by : none
Replaced integer subtraction with addition → NO_COVERAGE

3.3
Location : find1span
Killed by : none
negated conditional → NO_COVERAGE

234

1.1
Location : find1span
Killed by : none
Replaced integer subtraction with addition → NO_COVERAGE

235

1.1
Location : find1span
Killed by : none
changed conditional boundary → NO_COVERAGE

2.2
Location : find1span
Killed by : none
negated conditional → NO_COVERAGE

237

1.1
Location : find1span
Killed by : none
changed conditional boundary → NO_COVERAGE

2.2
Location : find1span
Killed by : none
Replaced integer addition with subtraction → NO_COVERAGE

3.3
Location : find1span
Killed by : none
negated conditional → NO_COVERAGE

238

1.1
Location : find1span
Killed by : none
replaced return of integer sized value with (x == 0 ? 1 : 0) → NO_COVERAGE

239

1.1
Location : find1span
Killed by : none
Replaced integer subtraction with addition → NO_COVERAGE

240

1.1
Location : find1span
Killed by : none
Changed increment from 1 to -1 → NO_COVERAGE

246

1.1
Location : find1span
Killed by : none
changed conditional boundary → NO_COVERAGE

2.2
Location : find1span
Killed by : none
negated conditional → NO_COVERAGE

247

1.1
Location : find1span
Killed by : none
negated conditional → NO_COVERAGE

248

1.1
Location : find1span
Killed by : none
Replaced bitwise AND with OR → NO_COVERAGE

2.2
Location : find1span
Killed by : none
Replaced integer addition with subtraction → NO_COVERAGE

3.3
Location : find1span
Killed by : none
replaced return of integer sized value with (x == 0 ? 1 : 0) → NO_COVERAGE

249

1.1
Location : find1span
Killed by : none
Changed increment from 8 to -8 → NO_COVERAGE

250

1.1
Location : find1span
Killed by : none
Changed increment from -8 to 8 → NO_COVERAGE

251

1.1
Location : find1span
Killed by : none
Changed increment from 1 to -1 → NO_COVERAGE

256

1.1
Location : find1span
Killed by : none
changed conditional boundary → NO_COVERAGE

2.2
Location : find1span
Killed by : none
negated conditional → NO_COVERAGE

257

1.1
Location : find1span
Killed by : none
Replaced bitwise AND with OR → NO_COVERAGE

258

1.1
Location : find1span
Killed by : none
changed conditional boundary → NO_COVERAGE

2.2
Location : find1span
Killed by : none
Replaced integer addition with subtraction → NO_COVERAGE

3.3
Location : find1span
Killed by : none
negated conditional → NO_COVERAGE

260

1.1
Location : find1span
Killed by : none
replaced return of integer sized value with (x == 0 ? 1 : 0) → NO_COVERAGE

264

1.1
Location : find0span
Killed by : none
Replaced integer subtraction with addition → NO_COVERAGE

267

1.1
Location : find0span
Killed by : none
Replaced Shift Right with Shift Left → NO_COVERAGE

2.2
Location : find0span
Killed by : none
Replaced integer addition with subtraction → NO_COVERAGE

271

1.1
Location : find0span
Killed by : none
changed conditional boundary → NO_COVERAGE

2.2
Location : find0span
Killed by : none
Replaced bitwise AND with OR → NO_COVERAGE

3.3
Location : find0span
Killed by : none
negated conditional → NO_COVERAGE

4.4
Location : find0span
Killed by : none
negated conditional → NO_COVERAGE

272

1.1
Location : find0span
Killed by : none
Replaced Shift Left with Shift Right → NO_COVERAGE

2.2
Location : find0span
Killed by : none
Replaced bitwise AND with OR → NO_COVERAGE

273

1.1
Location : find0span
Killed by : none
changed conditional boundary → NO_COVERAGE

2.2
Location : find0span
Killed by : none
Replaced integer subtraction with addition → NO_COVERAGE

3.3
Location : find0span
Killed by : none
negated conditional → NO_COVERAGE

274

1.1
Location : find0span
Killed by : none
Replaced integer subtraction with addition → NO_COVERAGE

275

1.1
Location : find0span
Killed by : none
changed conditional boundary → NO_COVERAGE

2.2
Location : find0span
Killed by : none
negated conditional → NO_COVERAGE

277

1.1
Location : find0span
Killed by : none
changed conditional boundary → NO_COVERAGE

2.2
Location : find0span
Killed by : none
Replaced integer addition with subtraction → NO_COVERAGE

3.3
Location : find0span
Killed by : none
negated conditional → NO_COVERAGE

278

1.1
Location : find0span
Killed by : none
replaced return of integer sized value with (x == 0 ? 1 : 0) → NO_COVERAGE

279

1.1
Location : find0span
Killed by : none
Replaced integer subtraction with addition → NO_COVERAGE

280

1.1
Location : find0span
Killed by : none
Changed increment from 1 to -1 → NO_COVERAGE

286

1.1
Location : find0span
Killed by : none
changed conditional boundary → NO_COVERAGE

2.2
Location : find0span
Killed by : none
negated conditional → NO_COVERAGE

287

1.1
Location : find0span
Killed by : none
negated conditional → NO_COVERAGE

288

1.1
Location : find0span
Killed by : none
Replaced bitwise AND with OR → NO_COVERAGE

2.2
Location : find0span
Killed by : none
Replaced integer addition with subtraction → NO_COVERAGE

3.3
Location : find0span
Killed by : none
replaced return of integer sized value with (x == 0 ? 1 : 0) → NO_COVERAGE

289

1.1
Location : find0span
Killed by : none
Changed increment from 8 to -8 → NO_COVERAGE

290

1.1
Location : find0span
Killed by : none
Changed increment from -8 to 8 → NO_COVERAGE

291

1.1
Location : find0span
Killed by : none
Changed increment from 1 to -1 → NO_COVERAGE

296

1.1
Location : find0span
Killed by : none
changed conditional boundary → NO_COVERAGE

2.2
Location : find0span
Killed by : none
negated conditional → NO_COVERAGE

297

1.1
Location : find0span
Killed by : none
Replaced bitwise AND with OR → NO_COVERAGE

298

1.1
Location : find0span
Killed by : none
changed conditional boundary → NO_COVERAGE

2.2
Location : find0span
Killed by : none
Replaced integer addition with subtraction → NO_COVERAGE

3.3
Location : find0span
Killed by : none
negated conditional → NO_COVERAGE

300

1.1
Location : find0span
Killed by : none
replaced return of integer sized value with (x == 0 ? 1 : 0) → NO_COVERAGE

304

1.1
Location : finddiff
Killed by : none
Replaced integer addition with subtraction → NO_COVERAGE

2.2
Location : finddiff
Killed by : none
negated conditional → NO_COVERAGE

3.3
Location : finddiff
Killed by : none
replaced return of integer sized value with (x == 0 ? 1 : 0) → NO_COVERAGE

308

1.1
Location : finddiff2
Killed by : none
changed conditional boundary → NO_COVERAGE

2.2
Location : finddiff2
Killed by : none
negated conditional → NO_COVERAGE

3.3
Location : finddiff2
Killed by : none
replaced return of integer sized value with (x == 0 ? 1 : 0) → NO_COVERAGE

Active mutators

Tests examined


Report generated by PIT 1.4.2