Spaces:
Running
Running
File size: 3,970 Bytes
a9694d2 |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 |
//========================================================================
//
// JArithmeticDecoder.h
//
// Arithmetic decoder used by the JBIG2 and JPEG2000 decoders.
//
// Copyright 2002-2004 Glyph & Cog, LLC
//
//========================================================================
//========================================================================
//
// Modified under the Poppler project - http://poppler.freedesktop.org
//
// All changes made under the Poppler project to this file are licensed
// under GPL version 2 or later
//
// Copyright (C) 2018, 2021 Albert Astals Cid <[email protected]>
// Copyright (C) 2019 Volker Krause <[email protected]>
// Copyright (C) 2020 Even Rouault <[email protected]>
//
// To see a description of the changes please see the Changelog file that
// came with your tarball or type make ChangeLog if you are building from git
//
//========================================================================
#ifndef JARITHMETICDECODER_H
#define JARITHMETICDECODER_H
class Stream;
//------------------------------------------------------------------------
// JArithmeticDecoderStats
//------------------------------------------------------------------------
class JArithmeticDecoderStats
{
public:
explicit JArithmeticDecoderStats(int contextSizeA);
~JArithmeticDecoderStats();
JArithmeticDecoderStats(const JArithmeticDecoderStats &) = delete;
JArithmeticDecoderStats &operator=(const JArithmeticDecoderStats &) = delete;
JArithmeticDecoderStats *copy();
void reset();
int getContextSize() { return contextSize; }
void copyFrom(JArithmeticDecoderStats *stats);
void setEntry(unsigned int cx, int i, int mps);
bool isValid() const { return cxTab != nullptr; }
private:
unsigned char *cxTab; // cxTab[cx] = (i[cx] << 1) + mps[cx]
int contextSize;
friend class JArithmeticDecoder;
};
//------------------------------------------------------------------------
// JArithmeticDecoder
//------------------------------------------------------------------------
class JArithmeticDecoder
{
public:
JArithmeticDecoder();
~JArithmeticDecoder();
JArithmeticDecoder(const JArithmeticDecoder &) = delete;
JArithmeticDecoder &operator=(const JArithmeticDecoder &) = delete;
void setStream(Stream *strA)
{
str = strA;
dataLen = 0;
limitStream = false;
}
void setStream(Stream *strA, int dataLenA)
{
str = strA;
dataLen = dataLenA;
limitStream = true;
}
// Start decoding on a new stream. This fills the byte buffers and
// runs INITDEC.
void start();
// Restart decoding on an interrupted stream. This refills the
// buffers if needed, but does not run INITDEC. (This is used in
// JPEG 2000 streams when codeblock data is split across multiple
// packets/layers.)
void restart(int dataLenA);
// Read any leftover data in the stream.
void cleanup();
// Decode one bit.
int decodeBit(unsigned int context, JArithmeticDecoderStats *stats);
// Decode eight bits.
int decodeByte(unsigned int context, JArithmeticDecoderStats *stats);
// Returns false for OOB, otherwise sets *<x> and returns true.
bool decodeInt(int *x, JArithmeticDecoderStats *stats);
unsigned int decodeIAID(unsigned int codeLen, JArithmeticDecoderStats *stats);
void resetByteCounter() { nBytesRead = 0; }
unsigned int getByteCounter() { return nBytesRead; }
private:
unsigned int readByte();
int decodeIntBit(JArithmeticDecoderStats *stats);
void byteIn();
static const unsigned int qeTab[47];
static const int nmpsTab[47];
static const int nlpsTab[47];
static const int switchTab[47];
unsigned int buf0, buf1;
unsigned int c, a;
int ct;
unsigned int prev; // for the integer decoder
Stream *str;
unsigned int nBytesRead;
int dataLen;
bool limitStream;
};
#endif
|