avoid constantly calling ensureBuffer

This commit is contained in:
Andreas Gal 2011-06-21 18:31:07 -04:00
parent 5a96404705
commit a65d1d1716

22
pdf.js
View File

@ -314,7 +314,7 @@ var FlateStream = (function() {
}, },
ensureBuffer: function(requested) { ensureBuffer: function(requested) {
var buffer = this.buffer; var buffer = this.buffer;
var current = buffer ? buffer.byteLength : 0; var current = buffer ? buffer.length : 0;
if (requested < current) if (requested < current)
return buffer; return buffer;
var size = 512; var size = 512;
@ -494,16 +494,22 @@ var FlateStream = (function() {
} }
var pos = this.bufferLength; var pos = this.bufferLength;
var buffer = this.buffer;
var limit = buffer ? buffer.length : 0;
while (true) { while (true) {
var code1 = this.getCode(litCodeTable); var code1 = this.getCode(litCodeTable);
if (code1 < 256) {
if (pos + 1 >= limit) {
buffer = this.ensureBuffer(pos + 1);
limit = buffer.length;
}
buffer[pos++] = code1;
continue;
}
if (code1 == 256) { if (code1 == 256) {
this.bufferLength = pos; this.bufferLength = pos;
return; return;
} }
if (code1 < 256) {
var buffer = this.ensureBuffer(pos + 1);
buffer[pos++] = code1;
} else {
code1 -= 257; code1 -= 257;
code1 = lengthDecode[code1]; code1 = lengthDecode[code1];
var code2 = code1 >> 16; var code2 = code1 >> 16;
@ -516,12 +522,14 @@ var FlateStream = (function() {
if (code2 > 0) if (code2 > 0)
code2 = this.getBits(code2); code2 = this.getBits(code2);
var dist = (code1 & 0xffff) + code2; var dist = (code1 & 0xffff) + code2;
var buffer = this.ensureBuffer(pos + len); if (pos + len >= limit) {
buffer = this.ensureBuffer(pos + len);
limit = buffer.length;
}
for (var k = 0; k < len; ++k, ++pos) for (var k = 0; k < len; ++k, ++pos)
buffer[pos] = buffer[pos - dist]; buffer[pos] = buffer[pos - dist];
} }
} }
}
}; };
return constructor; return constructor;