Merge pull request #12001 from Snuffleupagus/cache-ColorSpace-locally
Add local caching of `ColorSpace`s, by name, in `PartialEvaluator.getOperatorList` (issue 2504)
This commit is contained in:
commit
a91f24cda9
@ -381,7 +381,8 @@ var PartialEvaluator = (function PartialEvaluatorClosure() {
|
|||||||
smask,
|
smask,
|
||||||
operatorList,
|
operatorList,
|
||||||
task,
|
task,
|
||||||
initialState
|
initialState,
|
||||||
|
localColorSpaceCache
|
||||||
) {
|
) {
|
||||||
var dict = xobj.dict;
|
var dict = xobj.dict;
|
||||||
var matrix = dict.getArray("Matrix");
|
var matrix = dict.getArray("Matrix");
|
||||||
@ -407,12 +408,21 @@ var PartialEvaluator = (function PartialEvaluatorClosure() {
|
|||||||
groupOptions.isolated = group.get("I") || false;
|
groupOptions.isolated = group.get("I") || false;
|
||||||
groupOptions.knockout = group.get("K") || false;
|
groupOptions.knockout = group.get("K") || false;
|
||||||
if (group.has("CS")) {
|
if (group.has("CS")) {
|
||||||
|
const cs = group.get("CS");
|
||||||
|
|
||||||
|
const localColorSpace =
|
||||||
|
cs instanceof Name && localColorSpaceCache.getByName(cs.name);
|
||||||
|
if (localColorSpace) {
|
||||||
|
colorSpace = localColorSpace;
|
||||||
|
} else {
|
||||||
colorSpace = await this.parseColorSpace({
|
colorSpace = await this.parseColorSpace({
|
||||||
cs: group.get("CS"),
|
cs,
|
||||||
resources,
|
resources,
|
||||||
|
localColorSpaceCache,
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (smask && smask.backdrop) {
|
if (smask && smask.backdrop) {
|
||||||
colorSpace = colorSpace || ColorSpace.singletons.rgb;
|
colorSpace = colorSpace || ColorSpace.singletons.rgb;
|
||||||
@ -619,7 +629,8 @@ var PartialEvaluator = (function PartialEvaluatorClosure() {
|
|||||||
resources,
|
resources,
|
||||||
operatorList,
|
operatorList,
|
||||||
task,
|
task,
|
||||||
stateManager
|
stateManager,
|
||||||
|
localColorSpaceCache
|
||||||
) {
|
) {
|
||||||
var smaskContent = smask.get("G");
|
var smaskContent = smask.get("G");
|
||||||
var smaskOptions = {
|
var smaskOptions = {
|
||||||
@ -648,7 +659,8 @@ var PartialEvaluator = (function PartialEvaluatorClosure() {
|
|||||||
smaskOptions,
|
smaskOptions,
|
||||||
operatorList,
|
operatorList,
|
||||||
task,
|
task,
|
||||||
stateManager.state.clone()
|
stateManager.state.clone(),
|
||||||
|
localColorSpaceCache
|
||||||
);
|
);
|
||||||
},
|
},
|
||||||
|
|
||||||
@ -800,7 +812,8 @@ var PartialEvaluator = (function PartialEvaluatorClosure() {
|
|||||||
gState,
|
gState,
|
||||||
operatorList,
|
operatorList,
|
||||||
task,
|
task,
|
||||||
stateManager
|
stateManager,
|
||||||
|
localColorSpaceCache
|
||||||
) {
|
) {
|
||||||
// This array holds the converted/processed state data.
|
// This array holds the converted/processed state data.
|
||||||
var gStateObj = [];
|
var gStateObj = [];
|
||||||
@ -853,7 +866,8 @@ var PartialEvaluator = (function PartialEvaluatorClosure() {
|
|||||||
resources,
|
resources,
|
||||||
operatorList,
|
operatorList,
|
||||||
task,
|
task,
|
||||||
stateManager
|
stateManager,
|
||||||
|
localColorSpaceCache
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
gStateObj.push([key, true]);
|
gStateObj.push([key, true]);
|
||||||
@ -1117,11 +1131,20 @@ var PartialEvaluator = (function PartialEvaluatorClosure() {
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
parseColorSpace({ cs, resources }) {
|
parseColorSpace({ cs, resources, localColorSpaceCache }) {
|
||||||
return new Promise(resolve => {
|
return new Promise(resolve => {
|
||||||
resolve(
|
const parsedColorSpace = ColorSpace.parse(
|
||||||
ColorSpace.parse(cs, this.xref, resources, this.pdfFunctionFactory)
|
cs,
|
||||||
|
this.xref,
|
||||||
|
resources,
|
||||||
|
this.pdfFunctionFactory
|
||||||
);
|
);
|
||||||
|
|
||||||
|
const csName = cs instanceof Name ? cs.name : null;
|
||||||
|
if (csName) {
|
||||||
|
localColorSpaceCache.set(csName, /* ref = */ null, parsedColorSpace);
|
||||||
|
}
|
||||||
|
resolve(parsedColorSpace);
|
||||||
}).catch(reason => {
|
}).catch(reason => {
|
||||||
if (reason instanceof AbortException) {
|
if (reason instanceof AbortException) {
|
||||||
return null;
|
return null;
|
||||||
@ -1198,6 +1221,7 @@ var PartialEvaluator = (function PartialEvaluatorClosure() {
|
|||||||
var xref = this.xref;
|
var xref = this.xref;
|
||||||
let parsingText = false;
|
let parsingText = false;
|
||||||
const localImageCache = new LocalImageCache();
|
const localImageCache = new LocalImageCache();
|
||||||
|
const localColorSpaceCache = new LocalImageCache();
|
||||||
|
|
||||||
var xobjs = resources.get("XObject") || Dict.empty;
|
var xobjs = resources.get("XObject") || Dict.empty;
|
||||||
var patterns = resources.get("Pattern") || Dict.empty;
|
var patterns = resources.get("Pattern") || Dict.empty;
|
||||||
@ -1309,7 +1333,8 @@ var PartialEvaluator = (function PartialEvaluatorClosure() {
|
|||||||
null,
|
null,
|
||||||
operatorList,
|
operatorList,
|
||||||
task,
|
task,
|
||||||
stateManager.state.clone()
|
stateManager.state.clone(),
|
||||||
|
localColorSpaceCache
|
||||||
)
|
)
|
||||||
.then(function () {
|
.then(function () {
|
||||||
stateManager.restore();
|
stateManager.restore();
|
||||||
@ -1454,12 +1479,21 @@ var PartialEvaluator = (function PartialEvaluatorClosure() {
|
|||||||
stateManager.state.textRenderingMode = args[0];
|
stateManager.state.textRenderingMode = args[0];
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case OPS.setFillColorSpace:
|
case OPS.setFillColorSpace: {
|
||||||
|
const localColorSpace =
|
||||||
|
args[0] instanceof Name &&
|
||||||
|
localColorSpaceCache.getByName(args[0].name);
|
||||||
|
if (localColorSpace) {
|
||||||
|
stateManager.state.fillColorSpace = localColorSpace;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
next(
|
next(
|
||||||
self
|
self
|
||||||
.parseColorSpace({
|
.parseColorSpace({
|
||||||
cs: args[0],
|
cs: args[0],
|
||||||
resources,
|
resources,
|
||||||
|
localColorSpaceCache,
|
||||||
})
|
})
|
||||||
.then(function (colorSpace) {
|
.then(function (colorSpace) {
|
||||||
if (colorSpace) {
|
if (colorSpace) {
|
||||||
@ -1468,12 +1502,22 @@ var PartialEvaluator = (function PartialEvaluatorClosure() {
|
|||||||
})
|
})
|
||||||
);
|
);
|
||||||
return;
|
return;
|
||||||
case OPS.setStrokeColorSpace:
|
}
|
||||||
|
case OPS.setStrokeColorSpace: {
|
||||||
|
const localColorSpace =
|
||||||
|
args[0] instanceof Name &&
|
||||||
|
localColorSpaceCache.getByName(args[0].name);
|
||||||
|
if (localColorSpace) {
|
||||||
|
stateManager.state.strokeColorSpace = localColorSpace;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
next(
|
next(
|
||||||
self
|
self
|
||||||
.parseColorSpace({
|
.parseColorSpace({
|
||||||
cs: args[0],
|
cs: args[0],
|
||||||
resources,
|
resources,
|
||||||
|
localColorSpaceCache,
|
||||||
})
|
})
|
||||||
.then(function (colorSpace) {
|
.then(function (colorSpace) {
|
||||||
if (colorSpace) {
|
if (colorSpace) {
|
||||||
@ -1482,6 +1526,7 @@ var PartialEvaluator = (function PartialEvaluatorClosure() {
|
|||||||
})
|
})
|
||||||
);
|
);
|
||||||
return;
|
return;
|
||||||
|
}
|
||||||
case OPS.setFillColor:
|
case OPS.setFillColor:
|
||||||
cs = stateManager.state.fillColorSpace;
|
cs = stateManager.state.fillColorSpace;
|
||||||
args = cs.getRgb(args, 0);
|
args = cs.getRgb(args, 0);
|
||||||
@ -1597,7 +1642,8 @@ var PartialEvaluator = (function PartialEvaluatorClosure() {
|
|||||||
gState,
|
gState,
|
||||||
operatorList,
|
operatorList,
|
||||||
task,
|
task,
|
||||||
stateManager
|
stateManager,
|
||||||
|
localColorSpaceCache
|
||||||
)
|
)
|
||||||
);
|
);
|
||||||
return;
|
return;
|
||||||
|
Loading…
Reference in New Issue
Block a user