1
0
Fork 0
mirror of https://github.com/mozilla/pdf.js.git synced 2025-04-22 16:18:08 +02:00

Add a helper function for handling locally cached image data (PR 18269 follow-up)

This avoids having to duplicate the same exact code multiple times.
This commit is contained in:
Jonas Jenwald 2024-06-18 17:01:30 +02:00
parent 4c041586fb
commit 604e8977e9

View file

@ -171,7 +171,12 @@ function normalizeBlendMode(value, parsingArray = false) {
return "source-over";
}
function incrementCachedImageMaskCount(data) {
function addLocallyCachedImageOps(opList, data) {
if (data.objId) {
opList.addDependency(data.objId);
}
opList.addImageOps(data.fn, data.args, data.optionalContent);
if (data.fn === OPS.paintImageMaskXObject && data.args[0]?.count > 0) {
data.args[0].count++;
}
@ -1785,16 +1790,7 @@ class PartialEvaluator {
if (isValidName) {
const localImage = localImageCache.getByName(name);
if (localImage) {
if (localImage.objId) {
operatorList.addDependency(localImage.objId);
}
operatorList.addImageOps(
localImage.fn,
localImage.args,
localImage.optionalContent
);
incrementCachedImageMaskCount(localImage);
addLocallyCachedImageOps(operatorList, localImage);
args = null;
continue;
}
@ -1812,16 +1808,7 @@ class PartialEvaluator {
localImageCache.getByRef(xobj) ||
self._regionalImageCache.getByRef(xobj);
if (localImage) {
if (localImage.objId) {
operatorList.addDependency(localImage.objId);
}
operatorList.addImageOps(
localImage.fn,
localImage.args,
localImage.optionalContent
);
incrementCachedImageMaskCount(localImage);
addLocallyCachedImageOps(operatorList, localImage);
resolveXObject();
return;
}
@ -1936,16 +1923,7 @@ class PartialEvaluator {
if (cacheKey) {
const localImage = localImageCache.getByName(cacheKey);
if (localImage) {
if (localImage.objId) {
operatorList.addDependency(localImage.objId);
}
operatorList.addImageOps(
localImage.fn,
localImage.args,
localImage.optionalContent
);
incrementCachedImageMaskCount(localImage);
addLocallyCachedImageOps(operatorList, localImage);
args = null;
continue;
}