Merge pull request #19889 from Snuffleupagus/loadXfaResources
Slightly re-factor how we pre-load fonts and images in XFA documents
This commit is contained in:
commit
06f44916c8
@ -1237,7 +1237,7 @@ class PDFDocument {
|
|||||||
return this.xfaFactory ? this.xfaFactory.getPages() : null;
|
return this.xfaFactory ? this.xfaFactory.getPages() : null;
|
||||||
}
|
}
|
||||||
|
|
||||||
async loadXfaImages() {
|
async #loadXfaImages() {
|
||||||
const xfaImages = await this.pdfManager.ensureCatalog("xfaImages");
|
const xfaImages = await this.pdfManager.ensureCatalog("xfaImages");
|
||||||
if (!xfaImages) {
|
if (!xfaImages) {
|
||||||
return;
|
return;
|
||||||
@ -1245,7 +1245,7 @@ class PDFDocument {
|
|||||||
this.xfaFactory.setImages(xfaImages);
|
this.xfaFactory.setImages(xfaImages);
|
||||||
}
|
}
|
||||||
|
|
||||||
async loadXfaFonts(handler, task) {
|
async #loadXfaFonts(handler, task) {
|
||||||
const acroForm = await this.pdfManager.ensureCatalog("acroForm");
|
const acroForm = await this.pdfManager.ensureCatalog("acroForm");
|
||||||
if (!acroForm) {
|
if (!acroForm) {
|
||||||
return;
|
return;
|
||||||
@ -1264,18 +1264,19 @@ class PDFDocument {
|
|||||||
|
|
||||||
const options = Object.assign(
|
const options = Object.assign(
|
||||||
Object.create(null),
|
Object.create(null),
|
||||||
this.pdfManager.evaluatorOptions
|
this.pdfManager.evaluatorOptions,
|
||||||
|
{ useSystemFonts: false }
|
||||||
);
|
);
|
||||||
options.useSystemFonts = false;
|
const { builtInCMapCache, fontCache, standardFontDataCache } = this.catalog;
|
||||||
|
|
||||||
const partialEvaluator = new PartialEvaluator({
|
const partialEvaluator = new PartialEvaluator({
|
||||||
xref: this.xref,
|
xref: this.xref,
|
||||||
handler,
|
handler,
|
||||||
pageIndex: -1,
|
pageIndex: -1,
|
||||||
idFactory: this._globalIdFactory,
|
idFactory: this._globalIdFactory,
|
||||||
fontCache: this.catalog.fontCache,
|
fontCache,
|
||||||
builtInCMapCache: this.catalog.builtInCMapCache,
|
builtInCMapCache,
|
||||||
standardFontDataCache: this.catalog.standardFontDataCache,
|
standardFontDataCache,
|
||||||
options,
|
options,
|
||||||
});
|
});
|
||||||
const operatorList = new OperatorList();
|
const operatorList = new OperatorList();
|
||||||
@ -1292,6 +1293,23 @@ class PDFDocument {
|
|||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
|
const parseFont = (fontName, fallbackFontDict, cssFontInfo) =>
|
||||||
|
partialEvaluator
|
||||||
|
.handleSetFont(
|
||||||
|
resources,
|
||||||
|
[Name.get(fontName), 1],
|
||||||
|
/* fontRef = */ null,
|
||||||
|
operatorList,
|
||||||
|
task,
|
||||||
|
initialState,
|
||||||
|
fallbackFontDict,
|
||||||
|
cssFontInfo
|
||||||
|
)
|
||||||
|
.catch(reason => {
|
||||||
|
warn(`loadXfaFonts: "${reason}".`);
|
||||||
|
return null;
|
||||||
|
});
|
||||||
|
|
||||||
const promises = [];
|
const promises = [];
|
||||||
for (const [fontName, font] of fontRes) {
|
for (const [fontName, font] of fontRes) {
|
||||||
const descriptor = font.get("FontDescriptor");
|
const descriptor = font.get("FontDescriptor");
|
||||||
@ -1313,21 +1331,7 @@ class PDFDocument {
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
promises.push(
|
promises.push(
|
||||||
partialEvaluator
|
parseFont(fontName, /* fallbackFontDict = */ null, cssFontInfo)
|
||||||
.handleSetFont(
|
|
||||||
resources,
|
|
||||||
[Name.get(fontName), 1],
|
|
||||||
/* fontRef = */ null,
|
|
||||||
operatorList,
|
|
||||||
task,
|
|
||||||
initialState,
|
|
||||||
/* fallbackFontDict = */ null,
|
|
||||||
/* cssFontInfo = */ cssFontInfo
|
|
||||||
)
|
|
||||||
.catch(function (reason) {
|
|
||||||
warn(`loadXfaFonts: "${reason}".`);
|
|
||||||
return null;
|
|
||||||
})
|
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1365,27 +1369,12 @@ class PDFDocument {
|
|||||||
{ name: "BoldItalic", fontWeight: 700, italicAngle: 12 },
|
{ name: "BoldItalic", fontWeight: 700, italicAngle: 12 },
|
||||||
]) {
|
]) {
|
||||||
const name = `${missing}-${fontInfo.name}`;
|
const name = `${missing}-${fontInfo.name}`;
|
||||||
const dict = getXfaFontDict(name);
|
|
||||||
|
|
||||||
promises.push(
|
promises.push(
|
||||||
partialEvaluator
|
parseFont(name, getXfaFontDict(name), {
|
||||||
.handleSetFont(
|
|
||||||
resources,
|
|
||||||
[Name.get(name), 1],
|
|
||||||
/* fontRef = */ null,
|
|
||||||
operatorList,
|
|
||||||
task,
|
|
||||||
initialState,
|
|
||||||
/* fallbackFontDict = */ dict,
|
|
||||||
/* cssFontInfo = */ {
|
|
||||||
fontFamily: missing,
|
fontFamily: missing,
|
||||||
fontWeight: fontInfo.fontWeight,
|
fontWeight: fontInfo.fontWeight,
|
||||||
italicAngle: fontInfo.italicAngle,
|
italicAngle: fontInfo.italicAngle,
|
||||||
}
|
|
||||||
)
|
|
||||||
.catch(function (reason) {
|
|
||||||
warn(`loadXfaFonts: "${reason}".`);
|
|
||||||
return null;
|
|
||||||
})
|
})
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
@ -1395,6 +1384,15 @@ class PDFDocument {
|
|||||||
this.xfaFactory.appendFonts(pdfFonts, reallyMissingFonts);
|
this.xfaFactory.appendFonts(pdfFonts, reallyMissingFonts);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
loadXfaResources(handler, task) {
|
||||||
|
return Promise.all([
|
||||||
|
this.#loadXfaFonts(handler, task).catch(() => {
|
||||||
|
// Ignore errors, to allow the document to load.
|
||||||
|
}),
|
||||||
|
this.#loadXfaImages(),
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
|
||||||
serializeXfaData(annotationStorage) {
|
serializeXfaData(annotationStorage) {
|
||||||
return this.xfaFactory
|
return this.xfaFactory
|
||||||
? this.xfaFactory.serializeData(annotationStorage)
|
? this.xfaFactory.serializeData(annotationStorage)
|
||||||
|
|||||||
@ -115,14 +115,6 @@ class BasePdfManager {
|
|||||||
return this.pdfDocument.fontFallback(id, handler);
|
return this.pdfDocument.fontFallback(id, handler);
|
||||||
}
|
}
|
||||||
|
|
||||||
loadXfaFonts(handler, task) {
|
|
||||||
return this.pdfDocument.loadXfaFonts(handler, task);
|
|
||||||
}
|
|
||||||
|
|
||||||
loadXfaImages() {
|
|
||||||
return this.pdfDocument.loadXfaImages();
|
|
||||||
}
|
|
||||||
|
|
||||||
cleanup(manuallyTriggered = false) {
|
cleanup(manuallyTriggered = false) {
|
||||||
return this.pdfDocument.cleanup(manuallyTriggered);
|
return this.pdfDocument.cleanup(manuallyTriggered);
|
||||||
}
|
}
|
||||||
|
|||||||
@ -170,18 +170,11 @@ class WorkerMessageHandler {
|
|||||||
|
|
||||||
const isPureXfa = await pdfManager.ensureDoc("isPureXfa");
|
const isPureXfa = await pdfManager.ensureDoc("isPureXfa");
|
||||||
if (isPureXfa) {
|
if (isPureXfa) {
|
||||||
const task = new WorkerTask("loadXfaFonts");
|
const task = new WorkerTask("loadXfaResources");
|
||||||
startWorkerTask(task);
|
startWorkerTask(task);
|
||||||
|
|
||||||
await Promise.all([
|
await pdfManager.ensureDoc("loadXfaResources", [handler, task]);
|
||||||
pdfManager
|
finishWorkerTask(task);
|
||||||
.loadXfaFonts(handler, task)
|
|
||||||
.catch(reason => {
|
|
||||||
// Ignore errors, to allow the document to load.
|
|
||||||
})
|
|
||||||
.then(() => finishWorkerTask(task)),
|
|
||||||
pdfManager.loadXfaImages(),
|
|
||||||
]);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
const [numPages, fingerprints] = await Promise.all([
|
const [numPages, fingerprints] = await Promise.all([
|
||||||
|
|||||||
@ -43,7 +43,7 @@ class XFAFactory {
|
|||||||
}
|
}
|
||||||
|
|
||||||
isValid() {
|
isValid() {
|
||||||
return this.root && this.form;
|
return !!(this.root && this.form);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user