|
|
@ -22,8 +22,8 @@ if (typeof PDFJS === 'undefined') { |
|
|
|
(typeof window !== 'undefined' ? window : this).PDFJS = {}; |
|
|
|
(typeof window !== 'undefined' ? window : this).PDFJS = {}; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
PDFJS.version = '1.0.1000'; |
|
|
|
PDFJS.version = '1.0.1002'; |
|
|
|
PDFJS.build = '59ccf49'; |
|
|
|
PDFJS.build = 'f4fa7aa'; |
|
|
|
|
|
|
|
|
|
|
|
(function pdfjsWrapper() { |
|
|
|
(function pdfjsWrapper() { |
|
|
|
// Use strict in our context only - users might not want it
|
|
|
|
// Use strict in our context only - users might not want it
|
|
|
@ -36202,31 +36202,14 @@ var Parser = (function ParserClosure() { |
|
|
|
// simple object
|
|
|
|
// simple object
|
|
|
|
return buf1; |
|
|
|
return buf1; |
|
|
|
}, |
|
|
|
}, |
|
|
|
makeInlineImage: function Parser_makeInlineImage(cipherTransform) { |
|
|
|
/** |
|
|
|
var lexer = this.lexer; |
|
|
|
* Find the end of the stream by searching for the /EI\s/. |
|
|
|
var stream = lexer.stream; |
|
|
|
* @returns {number} The inline stream length. |
|
|
|
|
|
|
|
*/ |
|
|
|
// parse dictionary
|
|
|
|
findDefaultInlineStreamEnd: |
|
|
|
var dict = new Dict(null); |
|
|
|
function Parser_findDefaultInlineStreamEnd(stream) { |
|
|
|
while (!isCmd(this.buf1, 'ID') && !isEOF(this.buf1)) { |
|
|
|
var E = 0x45, I = 0x49, SPACE = 0x20, LF = 0xA, CR = 0xD; |
|
|
|
if (!isName(this.buf1)) { |
|
|
|
var startPos = stream.pos, state = 0, ch, i, n, followingBytes; |
|
|
|
error('Dictionary key must be a name object'); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
var key = this.buf1.name; |
|
|
|
|
|
|
|
this.shift(); |
|
|
|
|
|
|
|
if (isEOF(this.buf1)) { |
|
|
|
|
|
|
|
break; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
dict.set(key, this.getObj(cipherTransform)); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// parse image stream
|
|
|
|
|
|
|
|
var startPos = stream.pos; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// searching for the /EI\s/
|
|
|
|
|
|
|
|
var state = 0, ch, i, ii; |
|
|
|
|
|
|
|
var E = 0x45, I = 0x49, SPACE = 0x20, NL = 0xA, CR = 0xD; |
|
|
|
|
|
|
|
while ((ch = stream.getByte()) !== -1) { |
|
|
|
while ((ch = stream.getByte()) !== -1) { |
|
|
|
if (state === 0) { |
|
|
|
if (state === 0) { |
|
|
|
state = (ch === E) ? 1 : 0; |
|
|
|
state = (ch === E) ? 1 : 0; |
|
|
@ -36234,13 +36217,13 @@ var Parser = (function ParserClosure() { |
|
|
|
state = (ch === I) ? 2 : 0; |
|
|
|
state = (ch === I) ? 2 : 0; |
|
|
|
} else { |
|
|
|
} else { |
|
|
|
assert(state === 2); |
|
|
|
assert(state === 2); |
|
|
|
if (ch === SPACE || ch === NL || ch === CR) { |
|
|
|
if (ch === SPACE || ch === LF || ch === CR) { |
|
|
|
// Let's check the next five bytes are ASCII... just be sure.
|
|
|
|
// Let's check the next five bytes are ASCII... just be sure.
|
|
|
|
var n = 5; |
|
|
|
n = 5; |
|
|
|
var followingBytes = stream.peekBytes(n); |
|
|
|
followingBytes = stream.peekBytes(n); |
|
|
|
for (i = 0; i < n; i++) { |
|
|
|
for (i = 0; i < n; i++) { |
|
|
|
ch = followingBytes[i]; |
|
|
|
ch = followingBytes[i]; |
|
|
|
if (ch !== NL && ch !== CR && (ch < SPACE || ch > 0x7F)) { |
|
|
|
if (ch !== LF && ch !== CR && (ch < SPACE || ch > 0x7F)) { |
|
|
|
// Not a LF, CR, SPACE or any visible ASCII character, i.e.
|
|
|
|
// Not a LF, CR, SPACE or any visible ASCII character, i.e.
|
|
|
|
// it's binary stuff. Resetting the state.
|
|
|
|
// it's binary stuff. Resetting the state.
|
|
|
|
state = 0; |
|
|
|
state = 0; |
|
|
@ -36248,18 +36231,116 @@ var Parser = (function ParserClosure() { |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
if (state === 2) { |
|
|
|
if (state === 2) { |
|
|
|
break; // finished!
|
|
|
|
break; // Finished!
|
|
|
|
} |
|
|
|
} |
|
|
|
} else { |
|
|
|
} else { |
|
|
|
state = 0; |
|
|
|
state = 0; |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
return ((stream.pos - 4) - startPos); |
|
|
|
|
|
|
|
}, |
|
|
|
|
|
|
|
/** |
|
|
|
|
|
|
|
* Find the EOD (end-of-data) marker '~>' (i.e. TILDE + GT) of the stream. |
|
|
|
|
|
|
|
* @returns {number} The inline stream length. |
|
|
|
|
|
|
|
*/ |
|
|
|
|
|
|
|
findASCII85DecodeInlineStreamEnd: |
|
|
|
|
|
|
|
function Parser_findASCII85DecodeInlineStreamEnd(stream) { |
|
|
|
|
|
|
|
var TILDE = 0x7E, GT = 0x3E; |
|
|
|
|
|
|
|
var startPos = stream.pos, ch, length; |
|
|
|
|
|
|
|
while ((ch = stream.getByte()) !== -1) { |
|
|
|
|
|
|
|
if (ch === TILDE && stream.peekByte() === GT) { |
|
|
|
|
|
|
|
stream.skip(); |
|
|
|
|
|
|
|
break; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
length = stream.pos - startPos; |
|
|
|
|
|
|
|
if (ch === -1) { |
|
|
|
|
|
|
|
warn('Inline ASCII85Decode image stream: ' + |
|
|
|
|
|
|
|
'EOD marker not found, searching for /EI/ instead.'); |
|
|
|
|
|
|
|
stream.skip(-length); // Reset the stream position.
|
|
|
|
|
|
|
|
return this.findDefaultInlineStreamEnd(stream); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
this.inlineStreamSkipEI(stream); |
|
|
|
|
|
|
|
return length; |
|
|
|
|
|
|
|
}, |
|
|
|
|
|
|
|
/** |
|
|
|
|
|
|
|
* Find the EOD (end-of-data) marker '>' (i.e. GT) of the stream. |
|
|
|
|
|
|
|
* @returns {number} The inline stream length. |
|
|
|
|
|
|
|
*/ |
|
|
|
|
|
|
|
findASCIIHexDecodeInlineStreamEnd: |
|
|
|
|
|
|
|
function Parser_findASCIIHexDecodeInlineStreamEnd(stream) { |
|
|
|
|
|
|
|
var GT = 0x3E; |
|
|
|
|
|
|
|
var startPos = stream.pos, ch, length; |
|
|
|
|
|
|
|
while ((ch = stream.getByte()) !== -1) { |
|
|
|
|
|
|
|
if (ch === GT) { |
|
|
|
|
|
|
|
break; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
length = stream.pos - startPos; |
|
|
|
|
|
|
|
if (ch === -1) { |
|
|
|
|
|
|
|
warn('Inline ASCIIHexDecode image stream: ' + |
|
|
|
|
|
|
|
'EOD marker not found, searching for /EI/ instead.'); |
|
|
|
|
|
|
|
stream.skip(-length); // Reset the stream position.
|
|
|
|
|
|
|
|
return this.findDefaultInlineStreamEnd(stream); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
this.inlineStreamSkipEI(stream); |
|
|
|
|
|
|
|
return length; |
|
|
|
|
|
|
|
}, |
|
|
|
|
|
|
|
/** |
|
|
|
|
|
|
|
* Skip over the /EI/ for streams where we search for an EOD marker. |
|
|
|
|
|
|
|
*/ |
|
|
|
|
|
|
|
inlineStreamSkipEI: function Parser_inlineStreamSkipEI(stream) { |
|
|
|
|
|
|
|
var E = 0x45, I = 0x49; |
|
|
|
|
|
|
|
var state = 0, ch; |
|
|
|
|
|
|
|
while ((ch = stream.getByte()) !== -1) { |
|
|
|
|
|
|
|
if (state === 0) { |
|
|
|
|
|
|
|
state = (ch === E) ? 1 : 0; |
|
|
|
|
|
|
|
} else if (state === 1) { |
|
|
|
|
|
|
|
state = (ch === I) ? 2 : 0; |
|
|
|
|
|
|
|
} else if (state === 2) { |
|
|
|
|
|
|
|
break; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
}, |
|
|
|
|
|
|
|
makeInlineImage: function Parser_makeInlineImage(cipherTransform) { |
|
|
|
|
|
|
|
var lexer = this.lexer; |
|
|
|
|
|
|
|
var stream = lexer.stream; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Parse dictionary.
|
|
|
|
|
|
|
|
var dict = new Dict(null); |
|
|
|
|
|
|
|
while (!isCmd(this.buf1, 'ID') && !isEOF(this.buf1)) { |
|
|
|
|
|
|
|
if (!isName(this.buf1)) { |
|
|
|
|
|
|
|
error('Dictionary key must be a name object'); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
var key = this.buf1.name; |
|
|
|
|
|
|
|
this.shift(); |
|
|
|
|
|
|
|
if (isEOF(this.buf1)) { |
|
|
|
|
|
|
|
break; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
dict.set(key, this.getObj(cipherTransform)); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Extract the name of the first (i.e. the current) image filter.
|
|
|
|
|
|
|
|
var filter = this.fetchIfRef(dict.get('Filter', 'F')), filterName; |
|
|
|
|
|
|
|
if (isName(filter)) { |
|
|
|
|
|
|
|
filterName = filter.name; |
|
|
|
|
|
|
|
} else if (isArray(filter) && isName(filter[0])) { |
|
|
|
|
|
|
|
filterName = filter[0].name; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
var length = (stream.pos - 4) - startPos; |
|
|
|
// Parse image stream.
|
|
|
|
|
|
|
|
var startPos = stream.pos, length, i, ii; |
|
|
|
|
|
|
|
if (filterName === 'ASCII85Decide' || filterName === 'A85') { |
|
|
|
|
|
|
|
length = this.findASCII85DecodeInlineStreamEnd(stream); |
|
|
|
|
|
|
|
} else if (filterName === 'ASCIIHexDecode' || filterName === 'AHx') { |
|
|
|
|
|
|
|
length = this.findASCIIHexDecodeInlineStreamEnd(stream); |
|
|
|
|
|
|
|
} else { |
|
|
|
|
|
|
|
length = this.findDefaultInlineStreamEnd(stream); |
|
|
|
|
|
|
|
} |
|
|
|
var imageStream = stream.makeSubStream(startPos, length, dict); |
|
|
|
var imageStream = stream.makeSubStream(startPos, length, dict); |
|
|
|
|
|
|
|
|
|
|
|
// cache all images below the MAX_LENGTH_TO_CACHE threshold by their
|
|
|
|
// Cache all images below the MAX_LENGTH_TO_CACHE threshold by their
|
|
|
|
// adler32 checksum.
|
|
|
|
// adler32 checksum.
|
|
|
|
var adler32; |
|
|
|
var adler32; |
|
|
|
if (length < MAX_LENGTH_TO_CACHE) { |
|
|
|
if (length < MAX_LENGTH_TO_CACHE) { |
|
|
@ -36269,7 +36350,7 @@ var Parser = (function ParserClosure() { |
|
|
|
var a = 1; |
|
|
|
var a = 1; |
|
|
|
var b = 0; |
|
|
|
var b = 0; |
|
|
|
for (i = 0, ii = imageBytes.length; i < ii; ++i) { |
|
|
|
for (i = 0, ii = imageBytes.length; i < ii; ++i) { |
|
|
|
// no modulo required in the loop if imageBytes.length < 5552
|
|
|
|
// No modulo required in the loop if imageBytes.length < 5552.
|
|
|
|
a += imageBytes[i] & 0xff; |
|
|
|
a += imageBytes[i] & 0xff; |
|
|
|
b += a; |
|
|
|
b += a; |
|
|
|
} |
|
|
|
} |
|
|
|