Fallback to check all pages when getting the pageIndex of FieldObjects
Given that the FieldObjects are parsed in parallel, in combination with the existing caching in the `getPage`-method and `annotations`-getter, adding additional caches for this fallback code-path doesn't seem entirely necessary.
This commit is contained in:
		
							parent
							
								
									4be6c90796
								
							
						
					
					
						commit
						389a26c115
					
				| @ -26,6 +26,7 @@ import { | |||||||
|   FeatureTest, |   FeatureTest, | ||||||
|   getModificationDate, |   getModificationDate, | ||||||
|   IDENTITY_MATRIX, |   IDENTITY_MATRIX, | ||||||
|  |   info, | ||||||
|   LINE_DESCENT_FACTOR, |   LINE_DESCENT_FACTOR, | ||||||
|   LINE_FACTOR, |   LINE_FACTOR, | ||||||
|   OPS, |   OPS, | ||||||
| @ -52,7 +53,7 @@ import { | |||||||
|   parseAppearanceStream, |   parseAppearanceStream, | ||||||
|   parseDefaultAppearance, |   parseDefaultAppearance, | ||||||
| } from "./default_appearance.js"; | } from "./default_appearance.js"; | ||||||
| import { Dict, isName, Name, Ref, RefSet } from "./primitives.js"; | import { Dict, isName, isRefsEqual, Name, Ref, RefSet } from "./primitives.js"; | ||||||
| import { Stream, StringStream } from "./stream.js"; | import { Stream, StringStream } from "./stream.js"; | ||||||
| import { writeDict, writeObject } from "./writer.js"; | import { writeDict, writeObject } from "./writer.js"; | ||||||
| import { BaseStream } from "./base_stream.js"; | import { BaseStream } from "./base_stream.js"; | ||||||
| @ -245,18 +246,39 @@ class AnnotationFactory { | |||||||
|         return -1; |         return -1; | ||||||
|       } |       } | ||||||
|       const pageRef = annotDict.getRaw("P"); |       const pageRef = annotDict.getRaw("P"); | ||||||
|       if (!(pageRef instanceof Ref)) { |       if (pageRef instanceof Ref) { | ||||||
|         return -1; |         try { | ||||||
|       } |  | ||||||
|           const pageIndex = await pdfManager.ensureCatalog("getPageIndex", [ |           const pageIndex = await pdfManager.ensureCatalog("getPageIndex", [ | ||||||
|             pageRef, |             pageRef, | ||||||
|           ]); |           ]); | ||||||
|           return pageIndex; |           return pageIndex; | ||||||
|         } catch (ex) { |         } catch (ex) { | ||||||
|       warn(`_getPageIndex: "${ex}".`); |           info(`_getPageIndex -- not a valid page reference: "${ex}".`); | ||||||
|       return -1; |  | ||||||
|         } |         } | ||||||
|       } |       } | ||||||
|  |       if (annotDict.has("Kids")) { | ||||||
|  |         return -1; // Not an annotation reference.
 | ||||||
|  |       } | ||||||
|  |       // Fallback to, potentially, checking the annotations of all pages.
 | ||||||
|  |       // PLEASE NOTE: This could force the *entire* PDF document to load,
 | ||||||
|  |       //              hence it absolutely cannot be done unconditionally.
 | ||||||
|  |       const numPages = await pdfManager.ensureDoc("numPages"); | ||||||
|  | 
 | ||||||
|  |       for (let pageIndex = 0; pageIndex < numPages; pageIndex++) { | ||||||
|  |         const page = await pdfManager.getPage(pageIndex); | ||||||
|  |         const annotations = await pdfManager.ensure(page, "annotations"); | ||||||
|  | 
 | ||||||
|  |         for (const annotRef of annotations) { | ||||||
|  |           if (annotRef instanceof Ref && isRefsEqual(annotRef, ref)) { | ||||||
|  |             return pageIndex; | ||||||
|  |           } | ||||||
|  |         } | ||||||
|  |       } | ||||||
|  |     } catch (ex) { | ||||||
|  |       warn(`_getPageIndex: "${ex}".`); | ||||||
|  |     } | ||||||
|  |     return -1; | ||||||
|  |   } | ||||||
| 
 | 
 | ||||||
|   static generateImages(annotations, xref, isOffscreenCanvasSupported) { |   static generateImages(annotations, xref, isOffscreenCanvasSupported) { | ||||||
|     if (!isOffscreenCanvasSupported) { |     if (!isOffscreenCanvasSupported) { | ||||||
|  | |||||||
| @ -1485,6 +1485,42 @@ describe("api", function () { | |||||||
|       await loadingTask.destroy(); |       await loadingTask.destroy(); | ||||||
|     }); |     }); | ||||||
| 
 | 
 | ||||||
|  |     it("gets fieldObjects with missing /P-entries", async function () { | ||||||
|  |       if (isNodeJS) { | ||||||
|  |         pending("Linked test-cases are not supported in Node.js."); | ||||||
|  |       } | ||||||
|  | 
 | ||||||
|  |       const loadingTask = getDocument(buildGetDocumentParams("bug1847733.pdf")); | ||||||
|  |       const pdfDoc = await loadingTask.promise; | ||||||
|  |       const fieldObjects = await pdfDoc.getFieldObjects(); | ||||||
|  | 
 | ||||||
|  |       for (const name in fieldObjects) { | ||||||
|  |         const pageIndexes = fieldObjects[name].map(o => o.page); | ||||||
|  |         let expected; | ||||||
|  | 
 | ||||||
|  |         switch (name) { | ||||||
|  |           case "formID": | ||||||
|  |           case "pdf_submission_new": | ||||||
|  |           case "simple_spc": | ||||||
|  |           case "adobeWarning": | ||||||
|  |             expected = [0]; | ||||||
|  |             break; | ||||||
|  |           case "typeA13": | ||||||
|  |             expected = [0, 0, 0, 0]; | ||||||
|  |             break; | ||||||
|  |           case "typeA15[0]": | ||||||
|  |           case "typeA15[1]": | ||||||
|  |           case "typeA15[2]": | ||||||
|  |           case "typeA15[3]": | ||||||
|  |             expected = [-1, 0, 0, 0, 0]; | ||||||
|  |             break; | ||||||
|  |         } | ||||||
|  |         expect(pageIndexes).toEqual(expected); | ||||||
|  |       } | ||||||
|  | 
 | ||||||
|  |       await loadingTask.destroy(); | ||||||
|  |     }); | ||||||
|  | 
 | ||||||
|     it("check field object for group of buttons", async function () { |     it("check field object for group of buttons", async function () { | ||||||
|       if (isNodeJS) { |       if (isNodeJS) { | ||||||
|         pending("Linked test-cases are not supported in Node.js."); |         pending("Linked test-cases are not supported in Node.js."); | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user