mirror of
				https://github.com/johnwhitington/cpdf-source.git
				synced 2025-06-05 22:09:39 +02:00 
			
		
		
		
	more
This commit is contained in:
		
							
								
								
									
										21
									
								
								cpdfannot.ml
									
									
									
									
									
								
							
							
						
						
									
										21
									
								
								cpdfannot.ml
									
									
									
									
									
								
							| @@ -78,10 +78,11 @@ let annotations_json_page pdf page pagenum = | |||||||
|         annots |         annots | ||||||
|   | _ -> [] |   | _ -> [] | ||||||
|  |  | ||||||
| (* Rewrite any /Parent entries in /Popup annotations to have annot serial number, not object number *) | (* Rewrite any /Parent entries in /Popup annotations to have annot serial number, not object number, and all /Popup entries in parent annotations similarly. *) | ||||||
| let postprocess_json_pdf objnum_to_serial_map pdf obj = | let postprocess_json_pdf objnum_to_serial_map pdf obj = | ||||||
|   match obj with |   match obj with | ||||||
|   | Pdf.Dictionary d -> |   | Pdf.Dictionary d -> | ||||||
|  |       let obj = | ||||||
|       begin match lookup "/Subtype" d, lookup "/Parent" d with |       begin match lookup "/Subtype" d, lookup "/Parent" d with | ||||||
|       | Some (Pdf.Name "/Popup"), Some (Pdf.Indirect i) -> |       | Some (Pdf.Name "/Popup"), Some (Pdf.Indirect i) -> | ||||||
|           begin match lookup i objnum_to_serial_map with |           begin match lookup i objnum_to_serial_map with | ||||||
| @@ -90,6 +91,19 @@ let postprocess_json_pdf objnum_to_serial_map pdf obj = | |||||||
|           end |           end | ||||||
|       | _ -> obj |       | _ -> obj | ||||||
|       end |       end | ||||||
|  |       in | ||||||
|  |         begin match obj with | ||||||
|  |         | Pdf.Dictionary d -> | ||||||
|  |             begin match lookup "/Popup" d with | ||||||
|  |             | Some (Pdf.Indirect i) -> | ||||||
|  |                 begin match lookup i objnum_to_serial_map with | ||||||
|  |                 | Some s -> Pdf.add_dict_entry obj "/Popup" (Pdf.Integer s) | ||||||
|  |                 | None -> Printf.eprintf "Warning: Cpdfannot.process_extra_object: could not find serial number 2\n"; obj | ||||||
|  |                 end | ||||||
|  |             | _ -> obj | ||||||
|  |             end | ||||||
|  |         | _ -> obj | ||||||
|  |         end | ||||||
|   | x -> x |   | x -> x | ||||||
|  |  | ||||||
| let postprocess_json pdf objnum_to_serial_map json = | let postprocess_json pdf objnum_to_serial_map json = | ||||||
| @@ -114,11 +128,14 @@ let list_annotations_json range pdf = | |||||||
|   let pages, pagenums = split pairs in |   let pages, pagenums = split pairs in | ||||||
|   let json = flatten (map2 (annotations_json_page pdf) pages pagenums) in |   let json = flatten (map2 (annotations_json_page pdf) pages pagenums) in | ||||||
|   let json = postprocess_json pdf !objnum_to_serial_map json in |   let json = postprocess_json pdf !objnum_to_serial_map json in | ||||||
|  |   let extra = map (postprocess_json_pdf !objnum_to_serial_map pdf) !extra in | ||||||
|  |   (*Printf.printf "%i extra roots to explore\n" (length extra); | ||||||
|  |   iter (fun x -> Printf.eprintf "%s\n\n" (Pdfwrite.string_of_pdf x)) extra;*) | ||||||
|   let extra = |   let extra = | ||||||
|     map |     map | ||||||
|       (fun n -> |       (fun n -> | ||||||
|          `List [`Int ~-n; Cpdfjson.json_of_object ~clean_strings:true pdf (fun _ -> ()) false false (Pdf.lookup_obj pdf n)]) |          `List [`Int ~-n; Cpdfjson.json_of_object ~clean_strings:true pdf (fun _ -> ()) false false (Pdf.lookup_obj pdf n)]) | ||||||
|       (setify (flatten (map (Pdf.objects_referenced [] [] pdf) !extra))) |       (setify (flatten (map (Pdf.objects_referenced [] [] pdf) extra))) | ||||||
|   in |   in | ||||||
|     Printf.printf "EXTRA: %i objects\n" (length extra); |     Printf.printf "EXTRA: %i objects\n" (length extra); | ||||||
|     let json = `List (json @ extra) in |     let json = `List (json @ extra) in | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user