hand in xref to the parser if needed so we can resolve 'Length' for sub-streams

This commit is contained in:
Andreas Gal 2011-06-03 14:38:54 -07:00
parent ed51d65409
commit 92aa46cf81

12
pdf.js
View File

@ -1402,9 +1402,10 @@ var Lexer = (function() {
})();
var Parser = (function() {
function constructor(lexer, allowStreams) {
function constructor(lexer, allowStreams, xref) {
this.lexer = lexer;
this.allowStreams = allowStreams;
this.xref = xref;
this.inlineImg = 0;
this.refill();
}
@ -1513,8 +1514,11 @@ var Parser = (function() {
var pos = stream.pos;
// get length
var length;
if (!IsInt(length = dict.get("Length"))) {
var length = dict.get("Length");
var xref = this.xref;
if (xref)
length = xref.fetchIfRef(length);
if (!IsInt(length)) {
error("Bad 'Length' attribute in stream");
lenght = 0;
}
@ -1783,7 +1787,7 @@ var XRef = (function() {
if (e.gen != gen)
throw("inconsistent generation in XRef");
var stream = this.stream.makeSubStream(e.offset);
var parser = new Parser(new Lexer(stream), true);
var parser = new Parser(new Lexer(stream), true, this);
var obj1 = parser.getObj();
var obj2 = parser.getObj();
var obj3 = parser.getObj();