mirror of
https://github.com/mozilla/pdf.js.git
synced 2025-04-20 15:18:08 +02:00
Improve handling of named destinations in out-of-order NameTrees (PR 10274 follow-up)
According to the specification, see https://web.archive.org/web/20210404042322if_/https://www.adobe.com/content/dam/acom/en/devnet/acrobat/pdfs/PDF32000_2008.pdf#G6.2384179, the keys of a NameTree/NumberTree should be ordered. For corrupt PDF files, which violate this assumption, it's thus possible that trying to lookup a single entry fails. Previously, in PR 10274, we implemented a fallback that only applies to the "bottom" node of a NameTree/NumberTree, which in general might not actually help for sufficiently corrupt NameTree/NumberTree data. Instead we remove the current *limited* fallback from `NameOrNumberTree.get`, and defer to the call-site to handle this case explicitly e.g. by using `NameOrNumberTree.getAll` for data where that makes sense. For well-formed documents, these changes should *not* lead to any additional data fetching/parsing. Finally, as part of these changes, the validation of named destination data is improved in the `Catalog` and a new unit-test is also added.
This commit is contained in:
parent
faf6b10939
commit
8d5689387b
6 changed files with 58 additions and 27 deletions
1
test/pdfs/issue10272.pdf.link
Normal file
1
test/pdfs/issue10272.pdf.link
Normal file
|
@ -0,0 +1 @@
|
|||
https://github.com/mozilla/pdf.js/files/2598691/ATS_TEST_PVC_2_1.pdf
|
|
@ -917,6 +917,12 @@
|
|||
"link": true,
|
||||
"type": "load"
|
||||
},
|
||||
{ "id": "issue10272",
|
||||
"file": "pdfs/issue10272.pdf",
|
||||
"md5": "bf3b2f74c6878d38a70dc0825f1b9a02",
|
||||
"link": true,
|
||||
"type": "other"
|
||||
},
|
||||
{ "id": "issue10388",
|
||||
"file": "pdfs/issue10388_reduced.pdf",
|
||||
"md5": "62a6b2adbea1535432bd94a3516e2d4c",
|
||||
|
|
|
@ -669,6 +669,24 @@ describe("api", function () {
|
|||
await loadingTask.destroy();
|
||||
});
|
||||
|
||||
it("gets a destination, from out-of-order /Names (NameTree) dictionary (issue 10272)", async function () {
|
||||
if (isNodeJS) {
|
||||
pending("Linked test-cases are not supported in Node.js.");
|
||||
}
|
||||
const loadingTask = getDocument(buildGetDocumentParams("issue10272.pdf"));
|
||||
const pdfDoc = await loadingTask.promise;
|
||||
const destination = await pdfDoc.getDestination("link_1");
|
||||
expect(destination).toEqual([
|
||||
{ num: 17, gen: 0 },
|
||||
{ name: "XYZ" },
|
||||
69,
|
||||
125,
|
||||
0,
|
||||
]);
|
||||
|
||||
await loadingTask.destroy();
|
||||
});
|
||||
|
||||
it("gets non-string destination", async function () {
|
||||
let numberPromise = pdfDocument.getDestination(4.3);
|
||||
let booleanPromise = pdfDocument.getDestination(true);
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue