in src/main/java/org/apache/pdfbox/jbig2/segments/GenericRegion.java [528:595]
private void decodeTemplate2(final int lineNumber, final int width, final int rowStride,
final int paddedWidth, int byteIndex, int idx) throws IOException
{
int context;
int overriddenContext;
int line1 = 0;
int line2 = 0;
if (lineNumber >= 1)
{
line1 = regionBitmap.getByteAsInteger(idx);
}
if (lineNumber >= 2)
{
line2 = regionBitmap.getByteAsInteger(idx - rowStride) << 4;
}
context = ((line1 >> 3) & 0x7c) | ((line2 >> 3) & 0x380);
int nextByte;
for (int x = 0; x < paddedWidth; x = nextByte)
{
/* 6.2.5.7 3d */
byte result = 0;
nextByte = x + 8;
final int minorWidth = width - x > 8 ? 8 : width - x;
if (lineNumber >= 1)
{
line1 = (line1 << 8)
| (nextByte < width ? regionBitmap.getByteAsInteger(idx + 1) : 0);
}
if (lineNumber >= 2)
{
line2 = (line2 << 8) | (nextByte < width
? regionBitmap.getByteAsInteger(idx - rowStride + 1) << 4 : 0);
}
for (int minorX = 0; minorX < minorWidth; minorX++)
{
if (override)
{
overriddenContext = overrideAtTemplate2(context, x + minorX, lineNumber, result,
minorX);
cx.setIndex(overriddenContext);
}
else
{
cx.setIndex(context);
}
final int bit = arithDecoder.decode(cx);
result |= bit << (7 - minorX);
final int toShift = 10 - minorX;
context = ((context & 0x1bd) << 1) | bit | ((line1 >> toShift) & 0x4)
| ((line2 >> toShift) & 0x80);
}
regionBitmap.setByte(byteIndex++, result);
idx++;
}
}