2014-03-11 00:56:00 +09:00
|
|
|
/* Copyright 2012 Mozilla Foundation
|
|
|
|
*
|
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
* you may not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at
|
|
|
|
*
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
* limitations under the License.
|
|
|
|
*/
|
|
|
|
|
2014-03-11 17:14:59 +09:00
|
|
|
/* This class implements the QM Coder decoding as defined in
|
|
|
|
* JPEG 2000 Part I Final Committee Draft Version 1.0
|
2015-02-03 00:12:52 +09:00
|
|
|
* Annex C.3 Arithmetic decoding procedure
|
2014-03-11 17:14:59 +09:00
|
|
|
* available at http://www.jpeg.org/public/fcd15444-1.pdf
|
2015-02-03 00:12:52 +09:00
|
|
|
*
|
2014-03-11 17:14:59 +09:00
|
|
|
* The arithmetic decoder is used in conjunction with context models to decode
|
|
|
|
* JPEG2000 and JBIG2 streams.
|
|
|
|
*/
|
2014-03-11 00:56:00 +09:00
|
|
|
var ArithmeticDecoder = (function ArithmeticDecoderClosure() {
|
2014-03-11 17:14:59 +09:00
|
|
|
// Table C-2
|
2014-03-11 00:56:00 +09:00
|
|
|
var QeTable = [
|
Fix inconsistent spacing and trailing commas in objects in `src/core/` files, so we can enable the `comma-dangle` and `object-curly-spacing` ESLint rules later on
*Unfortunately this patch is fairly big, even though it only covers the `src/core` folder, but splitting it even further seemed difficult.*
http://eslint.org/docs/rules/comma-dangle
http://eslint.org/docs/rules/object-curly-spacing
Given that we currently have quite inconsistent object formatting, fixing this in *one* big patch probably wouldn't be feasible (since I cannot imagine anyone wanting to review that); hence I've opted to try and do this piecewise instead.
Please note: This patch was created automatically, using the ESLint --fix command line option. In a couple of places this caused lines to become too long, and I've fixed those manually; please refer to the interdiff below for the only hand-edits in this patch.
```diff
diff --git a/src/core/evaluator.js b/src/core/evaluator.js
index abab9027..dcd3594b 100644
--- a/src/core/evaluator.js
+++ b/src/core/evaluator.js
@@ -2785,7 +2785,8 @@ var EvaluatorPreprocessor = (function EvaluatorPreprocessorClosure() {
t['Tz'] = { id: OPS.setHScale, numArgs: 1, variableArgs: false, };
t['TL'] = { id: OPS.setLeading, numArgs: 1, variableArgs: false, };
t['Tf'] = { id: OPS.setFont, numArgs: 2, variableArgs: false, };
- t['Tr'] = { id: OPS.setTextRenderingMode, numArgs: 1, variableArgs: false, };
+ t['Tr'] = { id: OPS.setTextRenderingMode, numArgs: 1,
+ variableArgs: false, };
t['Ts'] = { id: OPS.setTextRise, numArgs: 1, variableArgs: false, };
t['Td'] = { id: OPS.moveText, numArgs: 2, variableArgs: false, };
t['TD'] = { id: OPS.setLeadingMoveText, numArgs: 2, variableArgs: false, };
diff --git a/src/core/jbig2.js b/src/core/jbig2.js
index 5a17d482..71671541 100644
--- a/src/core/jbig2.js
+++ b/src/core/jbig2.js
@@ -123,19 +123,22 @@ var Jbig2Image = (function Jbig2ImageClosure() {
{ x: -1, y: -1, }, { x: 0, y: -1, }, { x: 1, y: -1, }, { x: -2, y: 0, },
{ x: -1, y: 0, }],
[{ x: -3, y: -1, }, { x: -2, y: -1, }, { x: -1, y: -1, }, { x: 0, y: -1, },
- { x: 1, y: -1, }, { x: -4, y: 0, }, { x: -3, y: 0, }, { x: -2, y: 0, }, { x: -1, y: 0, }]
+ { x: 1, y: -1, }, { x: -4, y: 0, }, { x: -3, y: 0, }, { x: -2, y: 0, },
+ { x: -1, y: 0, }]
];
var RefinementTemplates = [
{
coding: [{ x: 0, y: -1, }, { x: 1, y: -1, }, { x: -1, y: 0, }],
- reference: [{ x: 0, y: -1, }, { x: 1, y: -1, }, { x: -1, y: 0, }, { x: 0, y: 0, },
- { x: 1, y: 0, }, { x: -1, y: 1, }, { x: 0, y: 1, }, { x: 1, y: 1, }],
+ reference: [{ x: 0, y: -1, }, { x: 1, y: -1, }, { x: -1, y: 0, },
+ { x: 0, y: 0, }, { x: 1, y: 0, }, { x: -1, y: 1, },
+ { x: 0, y: 1, }, { x: 1, y: 1, }],
},
{
- coding: [{ x: -1, y: -1, }, { x: 0, y: -1, }, { x: 1, y: -1, }, { x: -1, y: 0, }],
- reference: [{ x: 0, y: -1, }, { x: -1, y: 0, }, { x: 0, y: 0, }, { x: 1, y: 0, },
- { x: 0, y: 1, }, { x: 1, y: 1, }],
+ coding: [{ x: -1, y: -1, }, { x: 0, y: -1, }, { x: 1, y: -1, },
+ { x: -1, y: 0, }],
+ reference: [{ x: 0, y: -1, }, { x: -1, y: 0, }, { x: 0, y: 0, },
+ { x: 1, y: 0, }, { x: 0, y: 1, }, { x: 1, y: 1, }],
}
];
```
2017-06-02 18:16:24 +09:00
|
|
|
{ qe: 0x5601, nmps: 1, nlps: 1, switchFlag: 1, },
|
|
|
|
{ qe: 0x3401, nmps: 2, nlps: 6, switchFlag: 0, },
|
|
|
|
{ qe: 0x1801, nmps: 3, nlps: 9, switchFlag: 0, },
|
|
|
|
{ qe: 0x0AC1, nmps: 4, nlps: 12, switchFlag: 0, },
|
|
|
|
{ qe: 0x0521, nmps: 5, nlps: 29, switchFlag: 0, },
|
|
|
|
{ qe: 0x0221, nmps: 38, nlps: 33, switchFlag: 0, },
|
|
|
|
{ qe: 0x5601, nmps: 7, nlps: 6, switchFlag: 1, },
|
|
|
|
{ qe: 0x5401, nmps: 8, nlps: 14, switchFlag: 0, },
|
|
|
|
{ qe: 0x4801, nmps: 9, nlps: 14, switchFlag: 0, },
|
|
|
|
{ qe: 0x3801, nmps: 10, nlps: 14, switchFlag: 0, },
|
|
|
|
{ qe: 0x3001, nmps: 11, nlps: 17, switchFlag: 0, },
|
|
|
|
{ qe: 0x2401, nmps: 12, nlps: 18, switchFlag: 0, },
|
|
|
|
{ qe: 0x1C01, nmps: 13, nlps: 20, switchFlag: 0, },
|
|
|
|
{ qe: 0x1601, nmps: 29, nlps: 21, switchFlag: 0, },
|
|
|
|
{ qe: 0x5601, nmps: 15, nlps: 14, switchFlag: 1, },
|
|
|
|
{ qe: 0x5401, nmps: 16, nlps: 14, switchFlag: 0, },
|
|
|
|
{ qe: 0x5101, nmps: 17, nlps: 15, switchFlag: 0, },
|
|
|
|
{ qe: 0x4801, nmps: 18, nlps: 16, switchFlag: 0, },
|
|
|
|
{ qe: 0x3801, nmps: 19, nlps: 17, switchFlag: 0, },
|
|
|
|
{ qe: 0x3401, nmps: 20, nlps: 18, switchFlag: 0, },
|
|
|
|
{ qe: 0x3001, nmps: 21, nlps: 19, switchFlag: 0, },
|
|
|
|
{ qe: 0x2801, nmps: 22, nlps: 19, switchFlag: 0, },
|
|
|
|
{ qe: 0x2401, nmps: 23, nlps: 20, switchFlag: 0, },
|
|
|
|
{ qe: 0x2201, nmps: 24, nlps: 21, switchFlag: 0, },
|
|
|
|
{ qe: 0x1C01, nmps: 25, nlps: 22, switchFlag: 0, },
|
|
|
|
{ qe: 0x1801, nmps: 26, nlps: 23, switchFlag: 0, },
|
|
|
|
{ qe: 0x1601, nmps: 27, nlps: 24, switchFlag: 0, },
|
|
|
|
{ qe: 0x1401, nmps: 28, nlps: 25, switchFlag: 0, },
|
|
|
|
{ qe: 0x1201, nmps: 29, nlps: 26, switchFlag: 0, },
|
|
|
|
{ qe: 0x1101, nmps: 30, nlps: 27, switchFlag: 0, },
|
|
|
|
{ qe: 0x0AC1, nmps: 31, nlps: 28, switchFlag: 0, },
|
|
|
|
{ qe: 0x09C1, nmps: 32, nlps: 29, switchFlag: 0, },
|
|
|
|
{ qe: 0x08A1, nmps: 33, nlps: 30, switchFlag: 0, },
|
|
|
|
{ qe: 0x0521, nmps: 34, nlps: 31, switchFlag: 0, },
|
|
|
|
{ qe: 0x0441, nmps: 35, nlps: 32, switchFlag: 0, },
|
|
|
|
{ qe: 0x02A1, nmps: 36, nlps: 33, switchFlag: 0, },
|
|
|
|
{ qe: 0x0221, nmps: 37, nlps: 34, switchFlag: 0, },
|
|
|
|
{ qe: 0x0141, nmps: 38, nlps: 35, switchFlag: 0, },
|
|
|
|
{ qe: 0x0111, nmps: 39, nlps: 36, switchFlag: 0, },
|
|
|
|
{ qe: 0x0085, nmps: 40, nlps: 37, switchFlag: 0, },
|
|
|
|
{ qe: 0x0049, nmps: 41, nlps: 38, switchFlag: 0, },
|
|
|
|
{ qe: 0x0025, nmps: 42, nlps: 39, switchFlag: 0, },
|
|
|
|
{ qe: 0x0015, nmps: 43, nlps: 40, switchFlag: 0, },
|
|
|
|
{ qe: 0x0009, nmps: 44, nlps: 41, switchFlag: 0, },
|
|
|
|
{ qe: 0x0005, nmps: 45, nlps: 42, switchFlag: 0, },
|
|
|
|
{ qe: 0x0001, nmps: 45, nlps: 43, switchFlag: 0, },
|
|
|
|
{ qe: 0x5601, nmps: 46, nlps: 46, switchFlag: 0, }
|
2014-03-11 00:56:00 +09:00
|
|
|
];
|
|
|
|
|
2014-03-11 17:14:59 +09:00
|
|
|
// C.3.5 Initialisation of the decoder (INITDEC)
|
2014-03-11 00:56:00 +09:00
|
|
|
function ArithmeticDecoder(data, start, end) {
|
|
|
|
this.data = data;
|
|
|
|
this.bp = start;
|
|
|
|
this.dataEnd = end;
|
|
|
|
|
|
|
|
this.chigh = data[start];
|
|
|
|
this.clow = 0;
|
|
|
|
|
|
|
|
this.byteIn();
|
|
|
|
|
|
|
|
this.chigh = ((this.chigh << 7) & 0xFFFF) | ((this.clow >> 9) & 0x7F);
|
|
|
|
this.clow = (this.clow << 7) & 0xFFFF;
|
|
|
|
this.ct -= 7;
|
|
|
|
this.a = 0x8000;
|
|
|
|
}
|
|
|
|
|
|
|
|
ArithmeticDecoder.prototype = {
|
2014-03-11 17:14:59 +09:00
|
|
|
// C.3.4 Compressed data input (BYTEIN)
|
2014-03-11 00:56:00 +09:00
|
|
|
byteIn: function ArithmeticDecoder_byteIn() {
|
|
|
|
var data = this.data;
|
|
|
|
var bp = this.bp;
|
2014-08-02 01:23:49 +09:00
|
|
|
if (data[bp] === 0xFF) {
|
2014-03-11 00:56:00 +09:00
|
|
|
var b1 = data[bp + 1];
|
|
|
|
if (b1 > 0x8F) {
|
|
|
|
this.clow += 0xFF00;
|
|
|
|
this.ct = 8;
|
|
|
|
} else {
|
|
|
|
bp++;
|
|
|
|
this.clow += (data[bp] << 9);
|
|
|
|
this.ct = 7;
|
|
|
|
this.bp = bp;
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
bp++;
|
|
|
|
this.clow += bp < this.dataEnd ? (data[bp] << 8) : 0xFF00;
|
|
|
|
this.ct = 8;
|
|
|
|
this.bp = bp;
|
|
|
|
}
|
|
|
|
if (this.clow > 0xFFFF) {
|
|
|
|
this.chigh += (this.clow >> 16);
|
|
|
|
this.clow &= 0xFFFF;
|
|
|
|
}
|
|
|
|
},
|
2014-03-11 17:14:59 +09:00
|
|
|
// C.3.2 Decoding a decision (DECODE)
|
2014-03-11 00:56:00 +09:00
|
|
|
readBit: function ArithmeticDecoder_readBit(contexts, pos) {
|
|
|
|
// contexts are packed into 1 byte:
|
|
|
|
// highest 7 bits carry cx.index, lowest bit carries cx.mps
|
|
|
|
var cx_index = contexts[pos] >> 1, cx_mps = contexts[pos] & 1;
|
|
|
|
var qeTableIcx = QeTable[cx_index];
|
|
|
|
var qeIcx = qeTableIcx.qe;
|
|
|
|
var d;
|
2014-03-13 23:09:33 +09:00
|
|
|
var a = this.a - qeIcx;
|
2014-03-11 00:56:00 +09:00
|
|
|
|
|
|
|
if (this.chigh < qeIcx) {
|
|
|
|
// exchangeLps
|
2014-03-13 23:09:33 +09:00
|
|
|
if (a < qeIcx) {
|
|
|
|
a = qeIcx;
|
2014-03-11 00:56:00 +09:00
|
|
|
d = cx_mps;
|
2014-03-13 23:09:33 +09:00
|
|
|
cx_index = qeTableIcx.nmps;
|
2014-03-11 00:56:00 +09:00
|
|
|
} else {
|
2014-03-13 23:09:33 +09:00
|
|
|
a = qeIcx;
|
|
|
|
d = 1 ^ cx_mps;
|
|
|
|
if (qeTableIcx.switchFlag === 1) {
|
2014-03-11 00:56:00 +09:00
|
|
|
cx_mps = d;
|
|
|
|
}
|
2014-03-13 23:09:33 +09:00
|
|
|
cx_index = qeTableIcx.nlps;
|
2014-03-11 00:56:00 +09:00
|
|
|
}
|
|
|
|
} else {
|
|
|
|
this.chigh -= qeIcx;
|
2014-03-13 23:09:33 +09:00
|
|
|
if ((a & 0x8000) !== 0) {
|
|
|
|
this.a = a;
|
2014-03-11 00:56:00 +09:00
|
|
|
return cx_mps;
|
|
|
|
}
|
|
|
|
// exchangeMps
|
2014-03-13 23:09:33 +09:00
|
|
|
if (a < qeIcx) {
|
|
|
|
d = 1 ^ cx_mps;
|
|
|
|
if (qeTableIcx.switchFlag === 1) {
|
2014-03-11 00:56:00 +09:00
|
|
|
cx_mps = d;
|
|
|
|
}
|
2014-03-13 23:09:33 +09:00
|
|
|
cx_index = qeTableIcx.nlps;
|
2014-03-11 00:56:00 +09:00
|
|
|
} else {
|
|
|
|
d = cx_mps;
|
2014-03-13 23:09:33 +09:00
|
|
|
cx_index = qeTableIcx.nmps;
|
2014-03-11 00:56:00 +09:00
|
|
|
}
|
|
|
|
}
|
2014-03-11 17:14:59 +09:00
|
|
|
// C.3.3 renormD;
|
2014-03-11 00:56:00 +09:00
|
|
|
do {
|
|
|
|
if (this.ct === 0) {
|
|
|
|
this.byteIn();
|
|
|
|
}
|
|
|
|
|
2014-03-13 23:09:33 +09:00
|
|
|
a <<= 1;
|
2014-03-11 00:56:00 +09:00
|
|
|
this.chigh = ((this.chigh << 1) & 0xFFFF) | ((this.clow >> 15) & 1);
|
|
|
|
this.clow = (this.clow << 1) & 0xFFFF;
|
|
|
|
this.ct--;
|
2014-03-13 23:09:33 +09:00
|
|
|
} while ((a & 0x8000) === 0);
|
|
|
|
this.a = a;
|
2014-03-11 00:56:00 +09:00
|
|
|
|
|
|
|
contexts[pos] = cx_index << 1 | cx_mps;
|
|
|
|
return d;
|
Fix inconsistent spacing and trailing commas in objects in `src/core/` files, so we can enable the `comma-dangle` and `object-curly-spacing` ESLint rules later on
*Unfortunately this patch is fairly big, even though it only covers the `src/core` folder, but splitting it even further seemed difficult.*
http://eslint.org/docs/rules/comma-dangle
http://eslint.org/docs/rules/object-curly-spacing
Given that we currently have quite inconsistent object formatting, fixing this in *one* big patch probably wouldn't be feasible (since I cannot imagine anyone wanting to review that); hence I've opted to try and do this piecewise instead.
Please note: This patch was created automatically, using the ESLint --fix command line option. In a couple of places this caused lines to become too long, and I've fixed those manually; please refer to the interdiff below for the only hand-edits in this patch.
```diff
diff --git a/src/core/evaluator.js b/src/core/evaluator.js
index abab9027..dcd3594b 100644
--- a/src/core/evaluator.js
+++ b/src/core/evaluator.js
@@ -2785,7 +2785,8 @@ var EvaluatorPreprocessor = (function EvaluatorPreprocessorClosure() {
t['Tz'] = { id: OPS.setHScale, numArgs: 1, variableArgs: false, };
t['TL'] = { id: OPS.setLeading, numArgs: 1, variableArgs: false, };
t['Tf'] = { id: OPS.setFont, numArgs: 2, variableArgs: false, };
- t['Tr'] = { id: OPS.setTextRenderingMode, numArgs: 1, variableArgs: false, };
+ t['Tr'] = { id: OPS.setTextRenderingMode, numArgs: 1,
+ variableArgs: false, };
t['Ts'] = { id: OPS.setTextRise, numArgs: 1, variableArgs: false, };
t['Td'] = { id: OPS.moveText, numArgs: 2, variableArgs: false, };
t['TD'] = { id: OPS.setLeadingMoveText, numArgs: 2, variableArgs: false, };
diff --git a/src/core/jbig2.js b/src/core/jbig2.js
index 5a17d482..71671541 100644
--- a/src/core/jbig2.js
+++ b/src/core/jbig2.js
@@ -123,19 +123,22 @@ var Jbig2Image = (function Jbig2ImageClosure() {
{ x: -1, y: -1, }, { x: 0, y: -1, }, { x: 1, y: -1, }, { x: -2, y: 0, },
{ x: -1, y: 0, }],
[{ x: -3, y: -1, }, { x: -2, y: -1, }, { x: -1, y: -1, }, { x: 0, y: -1, },
- { x: 1, y: -1, }, { x: -4, y: 0, }, { x: -3, y: 0, }, { x: -2, y: 0, }, { x: -1, y: 0, }]
+ { x: 1, y: -1, }, { x: -4, y: 0, }, { x: -3, y: 0, }, { x: -2, y: 0, },
+ { x: -1, y: 0, }]
];
var RefinementTemplates = [
{
coding: [{ x: 0, y: -1, }, { x: 1, y: -1, }, { x: -1, y: 0, }],
- reference: [{ x: 0, y: -1, }, { x: 1, y: -1, }, { x: -1, y: 0, }, { x: 0, y: 0, },
- { x: 1, y: 0, }, { x: -1, y: 1, }, { x: 0, y: 1, }, { x: 1, y: 1, }],
+ reference: [{ x: 0, y: -1, }, { x: 1, y: -1, }, { x: -1, y: 0, },
+ { x: 0, y: 0, }, { x: 1, y: 0, }, { x: -1, y: 1, },
+ { x: 0, y: 1, }, { x: 1, y: 1, }],
},
{
- coding: [{ x: -1, y: -1, }, { x: 0, y: -1, }, { x: 1, y: -1, }, { x: -1, y: 0, }],
- reference: [{ x: 0, y: -1, }, { x: -1, y: 0, }, { x: 0, y: 0, }, { x: 1, y: 0, },
- { x: 0, y: 1, }, { x: 1, y: 1, }],
+ coding: [{ x: -1, y: -1, }, { x: 0, y: -1, }, { x: 1, y: -1, },
+ { x: -1, y: 0, }],
+ reference: [{ x: 0, y: -1, }, { x: -1, y: 0, }, { x: 0, y: 0, },
+ { x: 1, y: 0, }, { x: 0, y: 1, }, { x: 1, y: 1, }],
}
];
```
2017-06-02 18:16:24 +09:00
|
|
|
},
|
2014-03-11 00:56:00 +09:00
|
|
|
};
|
|
|
|
|
|
|
|
return ArithmeticDecoder;
|
|
|
|
})();
|
2015-11-22 01:32:47 +09:00
|
|
|
|
2017-04-02 23:14:30 +09:00
|
|
|
export {
|
|
|
|
ArithmeticDecoder,
|
|
|
|
};
|