Pattern match optimization
This commit is contained in:
parent
502f7cb81b
commit
eca6c82bbc
23
pdf.js
23
pdf.js
@ -3176,23 +3176,26 @@ var XRef = (function xRefXRef() {
|
|||||||
}
|
}
|
||||||
function skipUntil(data, offset, what) {
|
function skipUntil(data, offset, what) {
|
||||||
var length = what.length, dataLength = data.length;
|
var length = what.length, dataLength = data.length;
|
||||||
var bytes = new Uint8Array(length);
|
var skipped = 0;
|
||||||
var i, skipped = 0;
|
|
||||||
for (i = 0; i < length; i++)
|
|
||||||
bytes[i] = what.charCodeAt(i);
|
|
||||||
// finding byte sequence
|
// finding byte sequence
|
||||||
while (offset < dataLength) {
|
while (offset < dataLength) {
|
||||||
var i = 0;
|
var i = 0;
|
||||||
while (i < length && data[offset + i] == bytes[i])
|
while (i < length && data[offset + i] == what[i])
|
||||||
++i;
|
++i;
|
||||||
if (i >= length)
|
if (i >= length)
|
||||||
break; // sequnce found
|
break; // sequence found
|
||||||
|
|
||||||
offset++;
|
offset++;
|
||||||
skipped++;
|
skipped++;
|
||||||
}
|
}
|
||||||
return skipped;
|
return skipped;
|
||||||
}
|
}
|
||||||
|
var trailerBytes = new Uint8Array([116, 114, 97, 105, 108, 101, 114]);
|
||||||
|
var startxrefBytes = new Uint8Array([115, 116, 97, 114, 116, 120, 114,
|
||||||
|
101, 102]);
|
||||||
|
var endobjBytes = new Uint8Array([101, 110, 100, 111, 98, 106]);
|
||||||
|
var xrefBytes = new Uint8Array([47, 88, 82, 101, 102]);
|
||||||
|
|
||||||
var stream = this.stream;
|
var stream = this.stream;
|
||||||
stream.pos = 0;
|
stream.pos = 0;
|
||||||
var buffer = stream.getBytes();
|
var buffer = stream.getBytes();
|
||||||
@ -3216,9 +3219,9 @@ var XRef = (function xRefXRef() {
|
|||||||
var token = readToken(buffer, position);
|
var token = readToken(buffer, position);
|
||||||
var m;
|
var m;
|
||||||
if (token === 'xref') {
|
if (token === 'xref') {
|
||||||
position += skipUntil(buffer, position, 'trailer');
|
position += skipUntil(buffer, position, trailerBytes);
|
||||||
trailers.push(position);
|
trailers.push(position);
|
||||||
position += skipUntil(buffer, position, 'startxref');
|
position += skipUntil(buffer, position, startxrefBytes);
|
||||||
} else if ((m = /^(\d+)\s+(\d+)\s+obj\b/.exec(token))) {
|
} else if ((m = /^(\d+)\s+(\d+)\s+obj\b/.exec(token))) {
|
||||||
this.entries[m[1]] = {
|
this.entries[m[1]] = {
|
||||||
offset: position,
|
offset: position,
|
||||||
@ -3226,12 +3229,12 @@ var XRef = (function xRefXRef() {
|
|||||||
uncompressed: true
|
uncompressed: true
|
||||||
};
|
};
|
||||||
|
|
||||||
var contentLength = skipUntil(buffer, position, 'endobj') + 7;
|
var contentLength = skipUntil(buffer, position, endobjBytes) + 7;
|
||||||
var content = buffer.subarray(position, position + contentLength);
|
var content = buffer.subarray(position, position + contentLength);
|
||||||
|
|
||||||
// checking XRef stream suspect
|
// checking XRef stream suspect
|
||||||
// (it shall have '/XRef' and next char is not a letter)
|
// (it shall have '/XRef' and next char is not a letter)
|
||||||
var xrefTagOffset = skipUntil(content, 0, '/XRef');
|
var xrefTagOffset = skipUntil(content, 0, xrefBytes);
|
||||||
if (xrefTagOffset < contentLength &&
|
if (xrefTagOffset < contentLength &&
|
||||||
content[xrefTagOffset + 5] < 64) {
|
content[xrefTagOffset + 5] < 64) {
|
||||||
xrefStms.push(position);
|
xrefStms.push(position);
|
||||||
|
Loading…
Reference in New Issue
Block a user