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