Fixed StampOn / StampUnder support for retaining bookmarks.

This commit is contained in:
John Whitington 2014-04-18 15:33:15 +01:00
parent dc23aa91ba
commit f00a9c5b04
2 changed files with 42 additions and 6 deletions

38
cpdf.ml
View File

@ -1050,8 +1050,34 @@ let do_stamp fast scale_to_fit isover pdf o u opdf =
Pdfpage.resources = Pdfpage.resources =
combine_pdf_resources pdf u.Pdfpage.resources o.Pdfpage.resources} combine_pdf_resources pdf u.Pdfpage.resources o.Pdfpage.resources}
(* Alter bookmark destinations given a hash table of (old page reference
* number, new page reference number) pairings *)
let change_destination t = function
Pdfdest.XYZ (Pdfdest.PageObject p, a, b, c) ->
Pdfdest.XYZ (Pdfdest.PageObject (Hashtbl.find t p), a, b, c)
| Pdfdest.Fit (Pdfdest.PageObject p) ->
Pdfdest.Fit (Pdfdest.PageObject (Hashtbl.find t p))
| Pdfdest.FitH (Pdfdest.PageObject p, x) ->
Pdfdest.FitH (Pdfdest.PageObject (Hashtbl.find t p), x)
| Pdfdest.FitV (Pdfdest.PageObject p, x) ->
Pdfdest.FitV (Pdfdest.PageObject (Hashtbl.find t p), x)
| Pdfdest.FitR (Pdfdest.PageObject p, a, b, c, d) ->
Pdfdest.FitR (Pdfdest.PageObject (Hashtbl.find t p), a, b, c, d)
| Pdfdest.FitB (Pdfdest.PageObject p) ->
Pdfdest.Fit (Pdfdest.PageObject (Hashtbl.find t p))
| Pdfdest.FitBH (Pdfdest.PageObject p, x) ->
Pdfdest.FitBH (Pdfdest.PageObject (Hashtbl.find t p), x)
| Pdfdest.FitBV (Pdfdest.PageObject p, x) ->
Pdfdest.FitBV (Pdfdest.PageObject (Hashtbl.find t p), x)
| x -> x
let change_bookmark t m =
{m with Pdfmarks.target =
try change_destination t m.Pdfmarks.target with Not_found -> m.Pdfmarks.target}
let stamp (fast : bool) scale_to_fit isover range over pdf = let stamp (fast : bool) scale_to_fit isover range over pdf =
let marks = Pdfmarks.read_bookmarks pdf in let marks = Pdfmarks.read_bookmarks pdf in
let marks_refnumbers = Pdf.page_reference_numbers pdf in
let pdf = Pdfmarks.remove_bookmarks pdf in let pdf = Pdfmarks.remove_bookmarks pdf in
let over = Pdfmarks.remove_bookmarks over in let over = Pdfmarks.remove_bookmarks over in
let pageseqs = ilist 1 (Pdfpage.endpage pdf) in let pageseqs = ilist 1 (Pdfpage.endpage pdf) in
@ -1060,7 +1086,11 @@ let stamp (fast : bool) scale_to_fit isover range over pdf =
| [] -> error "empty PDF" | [] -> error "empty PDF"
| h::_ -> Pdfpage.change_pages true over [h] | h::_ -> Pdfpage.change_pages true over [h]
in in
let merged = Pdfmerge.merge_pdfs ~rotations:[Pdfmerge.DNR; Pdfmerge.DNR] false false ["a"; "b"] [pdf; over_firstpage_pdf] [pageseqs; [1]] in let merged =
Pdfmerge.merge_pdfs
~rotations:[Pdfmerge.DNR; Pdfmerge.DNR]
false false ["a"; "b"] [pdf; over_firstpage_pdf] [pageseqs; [1]]
in
let renamed_pdf = let renamed_pdf =
Pdfpage.change_pages true Pdfpage.change_pages true
merged (Pdfpage.renumber_pages merged (Pdfpage.pages_of_pagetree merged)) merged (Pdfpage.renumber_pages merged (Pdfpage.pages_of_pagetree merged))
@ -1079,7 +1109,11 @@ let stamp (fast : bool) scale_to_fit isover range over pdf =
pageseqs pageseqs
under_pages under_pages
in in
Pdfmarks.add_bookmarks marks (Pdfpage.change_pages true renamed_pdf new_pages) let changed = Pdfpage.change_pages true renamed_pdf new_pages in
let new_refnumbers = Pdf.page_reference_numbers changed in
let changetable = hashtable_of_dictionary (List.combine marks_refnumbers new_refnumbers) in
let new_marks = map (change_bookmark changetable) marks in
Pdfmarks.add_bookmarks new_marks changed
(* Combine pages from two PDFs. For now, assume equal length. *) (* Combine pages from two PDFs. For now, assume equal length. *)

View File

@ -3277,7 +3277,7 @@ let go () =
in in
let overpdf = if args.uprightstamp then Cpdf.upright ~fast:args.fast (ilist 1 (Pdfpage.endpage overpdf)) overpdf else overpdf in let overpdf = if args.uprightstamp then Cpdf.upright ~fast:args.fast (ilist 1 (Pdfpage.endpage overpdf)) overpdf else overpdf in
let pdf = get_single_pdf args.op false in let pdf = get_single_pdf args.op false in
let marks = Pdfmarks.read_bookmarks pdf in (*let marks = Pdfmarks.read_bookmarks pdf in*)
let range = parse_pagespec pdf (get_pagespec ()) in let range = parse_pagespec pdf (get_pagespec ()) in
let pdf = let pdf =
if args.ismulti if args.ismulti
@ -3287,7 +3287,9 @@ let go () =
else else
Cpdf.stamp args.fast args.scale_stamp_to_fit true range overpdf pdf Cpdf.stamp args.fast args.scale_stamp_to_fit true range overpdf pdf
in in
write_pdf false (Pdfmarks.add_bookmarks marks pdf) (*let p = Pdfmarks.add_bookmarks marks pdf in
Pdfwrite.debug_whole_pdf p;*)
write_pdf false pdf
| Some (StampUnder under) -> | Some (StampUnder under) ->
let underpdf = let underpdf =
match under with match under with
@ -3296,7 +3298,7 @@ let go () =
in in
let underpdf = if args.uprightstamp then Cpdf.upright ~fast:args.fast (ilist 1 (Pdfpage.endpage underpdf)) underpdf else underpdf in let underpdf = if args.uprightstamp then Cpdf.upright ~fast:args.fast (ilist 1 (Pdfpage.endpage underpdf)) underpdf else underpdf in
let pdf = get_single_pdf args.op false in let pdf = get_single_pdf args.op false in
let marks = Pdfmarks.read_bookmarks pdf in (*let marks = Pdfmarks.read_bookmarks pdf in*)
let range = parse_pagespec pdf (get_pagespec ()) in let range = parse_pagespec pdf (get_pagespec ()) in
let pdf = let pdf =
if args.ismulti if args.ismulti
@ -3305,7 +3307,7 @@ let go () =
Cpdf.combine_pages args.fast pdf underpdf true true false Cpdf.combine_pages args.fast pdf underpdf true true false
else Cpdf.stamp args.fast args.scale_stamp_to_fit false range underpdf pdf else Cpdf.stamp args.fast args.scale_stamp_to_fit false range underpdf pdf
in in
write_pdf false (Pdfmarks.add_bookmarks marks pdf) write_pdf false pdf (*(Pdfmarks.add_bookmarks marks pdf)*)
| Some (CombinePages over) -> | Some (CombinePages over) ->
write_pdf false write_pdf false
(Cpdf.combine_pages args.fast (get_single_pdf args.op false) (pdfread_pdf_of_file None None over) false false true) (Cpdf.combine_pages args.fast (get_single_pdf args.op false) (pdfread_pdf_of_file None None over) false false true)