Beginnings of support for transforming bookmark destinations
This commit is contained in:
parent
d57602e5e5
commit
3073c74367
2
Changes
2
Changes
|
@ -3,12 +3,12 @@ Version 2.4 (June 2021)
|
||||||
o New operation -extract-images
|
o New operation -extract-images
|
||||||
o Optional Content Groups now preserved when merging / stamping pages
|
o Optional Content Groups now preserved when merging / stamping pages
|
||||||
o Listing, coalescing and modfying Optional Content Groups.
|
o Listing, coalescing and modfying Optional Content Groups.
|
||||||
o Vendored in tiny_json from Yoshihiro Imai via Jan Furuse
|
|
||||||
o New -labels-progress option to improve page labels interface
|
o New -labels-progress option to improve page labels interface
|
||||||
o New options -output-json et al. to export PDF files in JSON format
|
o New options -output-json et al. to export PDF files in JSON format
|
||||||
o New option -stamp-as-xobject to add one PDF as an xobject in another
|
o New option -stamp-as-xobject to add one PDF as an xobject in another
|
||||||
o No longer depends on Bigarray or Unix modules
|
o No longer depends on Bigarray or Unix modules
|
||||||
o Appearance streams transformed when transforming annotations
|
o Appearance streams transformed when transforming annotations
|
||||||
|
o Bookmark desitination positions transformed when transforming pages
|
||||||
|
|
||||||
Version 2.3 (patchlevel 1, December 2019)
|
Version 2.3 (patchlevel 1, December 2019)
|
||||||
|
|
||||||
|
|
77
cpdf.ml
77
cpdf.ml
|
@ -590,15 +590,20 @@ let expand_date = function
|
||||||
| "now" -> Cpdfstrftime.strftime "D:%Y%m%d%H%M%S"
|
| "now" -> Cpdfstrftime.strftime "D:%Y%m%d%H%M%S"
|
||||||
| x -> x
|
| x -> x
|
||||||
|
|
||||||
|
(* For uses of process_pages which don't need to deal with matrices, this
|
||||||
|
function transforms into one which returns the identity matrix *)
|
||||||
|
let ppstub f n p = (f n p, n, Pdftransform.i_matrix)
|
||||||
|
|
||||||
let process_pages f pdf range =
|
let process_pages f pdf range =
|
||||||
let pages = Pdfpage.pages_of_pagetree pdf in
|
let pages = Pdfpage.pages_of_pagetree pdf in
|
||||||
let pages' =
|
let pages', pagenumbers, matrices = (* new page objects, page number, matrix *)
|
||||||
map2
|
split3
|
||||||
(fun n p -> if mem n range then f n p else p)
|
(map2
|
||||||
|
(fun n p -> if mem n range then f n p else (p, n, Pdftransform.i_matrix))
|
||||||
(ilist 1 (length pages))
|
(ilist 1 (length pages))
|
||||||
pages
|
pages)
|
||||||
in
|
in
|
||||||
Pdfpage.change_pages true pdf pages'
|
Pdfpage.change_pages ~matrices:(combine pagenumbers matrices) true pdf pages'
|
||||||
|
|
||||||
let iter_pages f pdf range =
|
let iter_pages f pdf range =
|
||||||
let pages = Pdfpage.pages_of_pagetree pdf in
|
let pages = Pdfpage.pages_of_pagetree pdf in
|
||||||
|
@ -1923,7 +1928,7 @@ let addtext
|
||||||
if metrics then
|
if metrics then
|
||||||
(ignore (iter_pages (fun a b -> ignore (addtext_page a b)) pdf pages); pdf)
|
(ignore (iter_pages (fun a b -> ignore (addtext_page a b)) pdf pages); pdf)
|
||||||
else
|
else
|
||||||
process_pages addtext_page pdf pages
|
process_pages (ppstub addtext_page) pdf pages
|
||||||
|
|
||||||
(* Prev is a list of lists of characters *)
|
(* Prev is a list of lists of characters *)
|
||||||
let split_at_newline t =
|
let split_at_newline t =
|
||||||
|
@ -2059,7 +2064,7 @@ let removetext range pdf =
|
||||||
let ops = Pdfops.parse_operators pdf page.Pdfpage.resources page.Pdfpage.content in
|
let ops = Pdfops.parse_operators pdf page.Pdfpage.resources page.Pdfpage.content in
|
||||||
[Pdfops.stream_of_ops (remove_stamps [] ops)]}
|
[Pdfops.stream_of_ops (remove_stamps [] ops)]}
|
||||||
in
|
in
|
||||||
process_pages removetext_page pdf range
|
process_pages (ppstub removetext_page) pdf range
|
||||||
|
|
||||||
(* \section{Padding with blank pages.} *)
|
(* \section{Padding with blank pages.} *)
|
||||||
let insert_after pos page pages =
|
let insert_after pos page pages =
|
||||||
|
@ -2388,7 +2393,7 @@ let shift_page ?(fast=false) dxdylist pdf pnum page =
|
||||||
Pdfpage.prepend_operators pdf [transform_op] ~fast page
|
Pdfpage.prepend_operators pdf [transform_op] ~fast page
|
||||||
|
|
||||||
let shift_pdf ?(fast=false) dxdylist pdf range =
|
let shift_pdf ?(fast=false) dxdylist pdf range =
|
||||||
process_pages (shift_page ~fast dxdylist pdf) pdf range
|
process_pages (ppstub (shift_page ~fast dxdylist pdf)) pdf range
|
||||||
|
|
||||||
(* Change a page's media box so its minimum x and y are 0, making other
|
(* Change a page's media box so its minimum x and y are 0, making other
|
||||||
operations simpler to think about. Any shift that is done is reflected in
|
operations simpler to think about. Any shift that is done is reflected in
|
||||||
|
@ -2420,14 +2425,14 @@ let vflip_pdf ?(fast=false) pdf range =
|
||||||
Pdftransform.matrix_of_op
|
Pdftransform.matrix_of_op
|
||||||
(Pdftransform.Scale ((0., ((miny +. maxy) /. 2.)), 1., -.1.))
|
(Pdftransform.Scale ((0., ((miny +. maxy) /. 2.)), 1., -.1.))
|
||||||
in
|
in
|
||||||
process_pages (flip_page ~fast transform_op pdf) pdf range
|
process_pages (ppstub (flip_page ~fast transform_op pdf)) pdf range
|
||||||
|
|
||||||
let hflip_pdf ?(fast=false) pdf range =
|
let hflip_pdf ?(fast=false) pdf range =
|
||||||
let transform_op minx _ maxx _ =
|
let transform_op minx _ maxx _ =
|
||||||
Pdftransform.matrix_of_op
|
Pdftransform.matrix_of_op
|
||||||
(Pdftransform.Scale (((minx +. maxx) /. 2., 0.), -.1., 1.))
|
(Pdftransform.Scale (((minx +. maxx) /. 2., 0.), -.1., 1.))
|
||||||
in
|
in
|
||||||
process_pages (flip_page ~fast transform_op pdf) pdf range
|
process_pages (ppstub (flip_page ~fast transform_op pdf)) pdf range
|
||||||
|
|
||||||
let stamp_shift_of_position topline midline sw sh w h p =
|
let stamp_shift_of_position topline midline sw sh w h p =
|
||||||
let half x = x /. 2.
|
let half x = x /. 2.
|
||||||
|
@ -2806,7 +2811,7 @@ let set_mediabox xywhlist pdf range =
|
||||||
[Pdf.Real x; Pdf.Real y;
|
[Pdf.Real x; Pdf.Real y;
|
||||||
Pdf.Real (x +. w); Pdf.Real (y +. h)])}
|
Pdf.Real (x +. w); Pdf.Real (y +. h)])}
|
||||||
in
|
in
|
||||||
process_pages crop_page pdf range
|
process_pages (ppstub crop_page) pdf range
|
||||||
|
|
||||||
(* Just used by cpdflib for historical reasons *)
|
(* Just used by cpdflib for historical reasons *)
|
||||||
let setBox box minx maxx miny maxy pdf range =
|
let setBox box minx maxx miny maxy pdf range =
|
||||||
|
@ -2817,7 +2822,7 @@ let setBox box minx maxx miny maxy pdf range =
|
||||||
page.Pdfpage.rest box
|
page.Pdfpage.rest box
|
||||||
(Pdf.Array [Pdf.Real minx; Pdf.Real miny; Pdf.Real maxx; Pdf.Real maxy])}
|
(Pdf.Array [Pdf.Real minx; Pdf.Real miny; Pdf.Real maxx; Pdf.Real maxy])}
|
||||||
in
|
in
|
||||||
process_pages set_box_page pdf range
|
process_pages (ppstub set_box_page) pdf range
|
||||||
|
|
||||||
(* \section{Cropping} *)
|
(* \section{Cropping} *)
|
||||||
let crop_pdf ?(box="/CropBox") xywhlist pdf range =
|
let crop_pdf ?(box="/CropBox") xywhlist pdf range =
|
||||||
|
@ -2832,7 +2837,7 @@ let crop_pdf ?(box="/CropBox") xywhlist pdf range =
|
||||||
[Pdf.Real x; Pdf.Real y;
|
[Pdf.Real x; Pdf.Real y;
|
||||||
Pdf.Real (x +. w); Pdf.Real (y +. h)])))}
|
Pdf.Real (x +. w); Pdf.Real (y +. h)])))}
|
||||||
in
|
in
|
||||||
process_pages crop_page pdf range
|
process_pages (ppstub crop_page) pdf range
|
||||||
|
|
||||||
(* Clip a page to one of its boxes, or the media box if that box is not
|
(* Clip a page to one of its boxes, or the media box if that box is not
|
||||||
* present. This is a hard clip, done by using a clipping rectangle, so that
|
* present. This is a hard clip, done by using a clipping rectangle, so that
|
||||||
|
@ -2840,7 +2845,7 @@ let crop_pdf ?(box="/CropBox") xywhlist pdf range =
|
||||||
* *)
|
* *)
|
||||||
let hard_box pdf range boxname mediabox_if_missing fast =
|
let hard_box pdf range boxname mediabox_if_missing fast =
|
||||||
process_pages
|
process_pages
|
||||||
(fun pagenum page ->
|
(ppstub (fun pagenum page ->
|
||||||
let minx, miny, maxx, maxy =
|
let minx, miny, maxx, maxy =
|
||||||
if boxname = "/MediaBox" then
|
if boxname = "/MediaBox" then
|
||||||
Pdf.parse_rectangle page.Pdfpage.mediabox
|
Pdf.parse_rectangle page.Pdfpage.mediabox
|
||||||
|
@ -2853,7 +2858,7 @@ let hard_box pdf range boxname mediabox_if_missing fast =
|
||||||
else error (Printf.sprintf "hard_box: box %s not found" boxname)
|
else error (Printf.sprintf "hard_box: box %s not found" boxname)
|
||||||
in
|
in
|
||||||
let ops = [Pdfops.Op_re (minx, miny, maxx -. minx, maxy -. miny); Pdfops.Op_W; Pdfops.Op_n] in
|
let ops = [Pdfops.Op_re (minx, miny, maxx -. minx, maxy -. miny); Pdfops.Op_W; Pdfops.Op_n] in
|
||||||
Pdfpage.prepend_operators pdf ops ~fast:fast page)
|
Pdfpage.prepend_operators pdf ops ~fast:fast page))
|
||||||
pdf
|
pdf
|
||||||
range
|
range
|
||||||
|
|
||||||
|
@ -2863,7 +2868,7 @@ let remove_cropping_pdf pdf range =
|
||||||
Pdfpage.rest =
|
Pdfpage.rest =
|
||||||
(Pdf.remove_dict_entry page.Pdfpage.rest "/CropBox")}
|
(Pdf.remove_dict_entry page.Pdfpage.rest "/CropBox")}
|
||||||
in
|
in
|
||||||
process_pages remove_cropping_page pdf range
|
process_pages (ppstub remove_cropping_page) pdf range
|
||||||
|
|
||||||
let remove_trim_pdf pdf range =
|
let remove_trim_pdf pdf range =
|
||||||
let remove_trim_page _ page =
|
let remove_trim_page _ page =
|
||||||
|
@ -2871,7 +2876,7 @@ let remove_trim_pdf pdf range =
|
||||||
Pdfpage.rest =
|
Pdfpage.rest =
|
||||||
(Pdf.remove_dict_entry page.Pdfpage.rest "/TrimBox")}
|
(Pdf.remove_dict_entry page.Pdfpage.rest "/TrimBox")}
|
||||||
in
|
in
|
||||||
process_pages remove_trim_page pdf range
|
process_pages (ppstub remove_trim_page) pdf range
|
||||||
|
|
||||||
let remove_art_pdf pdf range =
|
let remove_art_pdf pdf range =
|
||||||
let remove_art_page _ page =
|
let remove_art_page _ page =
|
||||||
|
@ -2879,7 +2884,7 @@ let remove_art_pdf pdf range =
|
||||||
Pdfpage.rest =
|
Pdfpage.rest =
|
||||||
(Pdf.remove_dict_entry page.Pdfpage.rest "/ArtBox")}
|
(Pdf.remove_dict_entry page.Pdfpage.rest "/ArtBox")}
|
||||||
in
|
in
|
||||||
process_pages remove_art_page pdf range
|
process_pages (ppstub remove_art_page) pdf range
|
||||||
|
|
||||||
let remove_bleed_pdf pdf range =
|
let remove_bleed_pdf pdf range =
|
||||||
let remove_bleed_page _ page =
|
let remove_bleed_page _ page =
|
||||||
|
@ -2887,7 +2892,7 @@ let remove_bleed_pdf pdf range =
|
||||||
Pdfpage.rest =
|
Pdfpage.rest =
|
||||||
(Pdf.remove_dict_entry page.Pdfpage.rest "/BleedBox")}
|
(Pdf.remove_dict_entry page.Pdfpage.rest "/BleedBox")}
|
||||||
in
|
in
|
||||||
process_pages remove_bleed_page pdf range
|
process_pages (ppstub remove_bleed_page) pdf range
|
||||||
|
|
||||||
(* \section{Rotating pages} *)
|
(* \section{Rotating pages} *)
|
||||||
let rotate_pdf r pdf range =
|
let rotate_pdf r pdf range =
|
||||||
|
@ -2895,14 +2900,14 @@ let rotate_pdf r pdf range =
|
||||||
{page with Pdfpage.rotate =
|
{page with Pdfpage.rotate =
|
||||||
Pdfpage.rotation_of_int r}
|
Pdfpage.rotation_of_int r}
|
||||||
in
|
in
|
||||||
process_pages rotate_page pdf range
|
process_pages (ppstub rotate_page) pdf range
|
||||||
|
|
||||||
let rotate_pdf_by r pdf range =
|
let rotate_pdf_by r pdf range =
|
||||||
let rotate_page_by _ page =
|
let rotate_page_by _ page =
|
||||||
{page with Pdfpage.rotate =
|
{page with Pdfpage.rotate =
|
||||||
Pdfpage.rotation_of_int ((Pdfpage.int_of_rotation page.Pdfpage.rotate + r) mod 360)}
|
Pdfpage.rotation_of_int ((Pdfpage.int_of_rotation page.Pdfpage.rotate + r) mod 360)}
|
||||||
in
|
in
|
||||||
process_pages rotate_page_by pdf range
|
process_pages (ppstub rotate_page_by) pdf range
|
||||||
|
|
||||||
let rotate_page_contents ~fast rotpoint r pdf _ page =
|
let rotate_page_contents ~fast rotpoint r pdf _ page =
|
||||||
let rotation_point =
|
let rotation_point =
|
||||||
|
@ -2925,7 +2930,7 @@ let rotate_page_contents ~fast rotpoint r pdf _ page =
|
||||||
Pdfpage.prepend_operators pdf [transform_op] ~fast page
|
Pdfpage.prepend_operators pdf [transform_op] ~fast page
|
||||||
|
|
||||||
let rotate_contents ?(fast=false) r pdf range =
|
let rotate_contents ?(fast=false) r pdf range =
|
||||||
process_pages (rotate_page_contents ~fast None r pdf) pdf range
|
process_pages (ppstub (rotate_page_contents ~fast None r pdf)) pdf range
|
||||||
|
|
||||||
(* Return the pages from the pdf in the range, unordered. *)
|
(* Return the pages from the pdf in the range, unordered. *)
|
||||||
let select_pages range pdf =
|
let select_pages range pdf =
|
||||||
|
@ -2976,7 +2981,7 @@ let upright ?(fast=false) range pdf =
|
||||||
let page = transform_contents ~fast tr pdf page in
|
let page = transform_contents ~fast tr pdf page in
|
||||||
rectify_boxes ~fast pdf {page with Pdfpage.rotate = Pdfpage.Rotate0}
|
rectify_boxes ~fast pdf {page with Pdfpage.rotate = Pdfpage.Rotate0}
|
||||||
in
|
in
|
||||||
process_pages (upright_page pdf) pdf range
|
process_pages (ppstub (upright_page pdf)) pdf range
|
||||||
|
|
||||||
(* \section{Scale page data} *)
|
(* \section{Scale page data} *)
|
||||||
let scale_pdf ?(fast=false) sxsylist pdf range =
|
let scale_pdf ?(fast=false) sxsylist pdf range =
|
||||||
|
@ -2995,7 +3000,7 @@ let scale_pdf ?(fast=false) sxsylist pdf range =
|
||||||
transform_annotations pdf matrix page.Pdfpage.rest;
|
transform_annotations pdf matrix page.Pdfpage.rest;
|
||||||
Pdfpage.prepend_operators pdf ~fast [transform_op] page
|
Pdfpage.prepend_operators pdf ~fast [transform_op] page
|
||||||
in
|
in
|
||||||
process_pages scale_page pdf range
|
process_pages (ppstub scale_page) pdf range
|
||||||
|
|
||||||
(* Scale to fit page of size x * y *)
|
(* Scale to fit page of size x * y *)
|
||||||
let scale_to_fit_pdf ?(fast=false) position input_scale xylist op pdf range =
|
let scale_to_fit_pdf ?(fast=false) position input_scale xylist op pdf range =
|
||||||
|
@ -3036,7 +3041,7 @@ let scale_to_fit_pdf ?(fast=false) position input_scale xylist op pdf range =
|
||||||
Pdfpage.prepend_operators pdf [Pdfops.Op_cm matrix] ~fast
|
Pdfpage.prepend_operators pdf [Pdfops.Op_cm matrix] ~fast
|
||||||
(change_pattern_matrices_page pdf (Pdftransform.matrix_invert matrix) page)
|
(change_pattern_matrices_page pdf (Pdftransform.matrix_invert matrix) page)
|
||||||
in
|
in
|
||||||
process_pages scale_page_to_fit pdf range
|
process_pages (ppstub scale_page_to_fit) pdf range
|
||||||
|
|
||||||
|
|
||||||
(* Scale contents *)
|
(* Scale contents *)
|
||||||
|
@ -3072,7 +3077,7 @@ let scale_page_contents ?(fast=false) scale position pdf _ page =
|
||||||
Pdfpage.prepend_operators pdf [transform_op] ~fast page
|
Pdfpage.prepend_operators pdf [transform_op] ~fast page
|
||||||
|
|
||||||
let scale_contents ?(fast=false) position scale pdf range =
|
let scale_contents ?(fast=false) position scale pdf range =
|
||||||
process_pages (scale_page_contents ~fast scale position pdf) pdf range
|
process_pages (ppstub (scale_page_contents ~fast scale position pdf)) pdf range
|
||||||
|
|
||||||
(* \section{List annotations} *)
|
(* \section{List annotations} *)
|
||||||
let get_annotation_string encoding pdf annot =
|
let get_annotation_string encoding pdf annot =
|
||||||
|
@ -3941,7 +3946,7 @@ let blacktext (r, g, b) range pdf =
|
||||||
process_xobjects pdf page (blacktext_ops (r, g, b));
|
process_xobjects pdf page (blacktext_ops (r, g, b));
|
||||||
{page with Pdfpage.content = content'}
|
{page with Pdfpage.content = content'}
|
||||||
in
|
in
|
||||||
process_pages blacktext_page pdf range
|
process_pages (ppstub blacktext_page) pdf range
|
||||||
|
|
||||||
(* \section{Blacken lines} *)
|
(* \section{Blacken lines} *)
|
||||||
let blacklines_ops (r, g, b) pdf resources content =
|
let blacklines_ops (r, g, b) pdf resources content =
|
||||||
|
@ -3967,7 +3972,7 @@ let blacklines (r, g, b) range pdf =
|
||||||
process_xobjects pdf page (blacklines_ops (r, g, b));
|
process_xobjects pdf page (blacklines_ops (r, g, b));
|
||||||
{page with Pdfpage.content = content'}
|
{page with Pdfpage.content = content'}
|
||||||
in
|
in
|
||||||
process_pages blacklines_page pdf range
|
process_pages (ppstub blacklines_page) pdf range
|
||||||
|
|
||||||
(* \section{Blacken Fills} *)
|
(* \section{Blacken Fills} *)
|
||||||
let blackfills_ops (r, g, b) pdf resources content =
|
let blackfills_ops (r, g, b) pdf resources content =
|
||||||
|
@ -3993,7 +3998,7 @@ let blackfills (r, g, b) range pdf =
|
||||||
process_xobjects pdf page (blackfills_ops (r, g, b));
|
process_xobjects pdf page (blackfills_ops (r, g, b));
|
||||||
{page with Pdfpage.content = content'}
|
{page with Pdfpage.content = content'}
|
||||||
in
|
in
|
||||||
process_pages blackfills_page pdf range
|
process_pages (ppstub blackfills_page) pdf range
|
||||||
|
|
||||||
(* \section{Set a minimum line width to avoid dropout} *)
|
(* \section{Set a minimum line width to avoid dropout} *)
|
||||||
let thinlines range width pdf =
|
let thinlines range width pdf =
|
||||||
|
@ -4068,7 +4073,7 @@ let thinlines range width pdf =
|
||||||
let content' = [Pdfops.stream_of_ops operators] in
|
let content' = [Pdfops.stream_of_ops operators] in
|
||||||
{page with Pdfpage.content = content'}
|
{page with Pdfpage.content = content'}
|
||||||
in
|
in
|
||||||
process_pages thinpage pdf range
|
process_pages (ppstub thinpage) pdf range
|
||||||
|
|
||||||
(* \section{Remove annotations} *)
|
(* \section{Remove annotations} *)
|
||||||
let remove_annotations range pdf =
|
let remove_annotations range pdf =
|
||||||
|
@ -4081,7 +4086,7 @@ let remove_annotations range pdf =
|
||||||
else
|
else
|
||||||
page
|
page
|
||||||
in
|
in
|
||||||
process_pages remove_annotations_page pdf range
|
process_pages (ppstub remove_annotations_page) pdf range
|
||||||
|
|
||||||
(* \section{Making draft documents} *)
|
(* \section{Making draft documents} *)
|
||||||
|
|
||||||
|
@ -4283,7 +4288,7 @@ let custom_csp1_page pdf _ page =
|
||||||
Pdfpage.rest = Pdf.add_dict_entry page.Pdfpage.rest "/CropBox" new_mediabox}
|
Pdfpage.rest = Pdf.add_dict_entry page.Pdfpage.rest "/CropBox" new_mediabox}
|
||||||
|
|
||||||
let custom_csp1 pdf =
|
let custom_csp1 pdf =
|
||||||
process_pages (custom_csp1_page pdf) pdf (ilist 1 (Pdfpage.endpage pdf))
|
process_pages (ppstub (custom_csp1_page pdf)) pdf (ilist 1 (Pdfpage.endpage pdf))
|
||||||
|
|
||||||
let custom_csp2 f pdf =
|
let custom_csp2 f pdf =
|
||||||
let page = hd (Pdfpage.pages_of_pagetree pdf) in
|
let page = hd (Pdfpage.pages_of_pagetree pdf) in
|
||||||
|
@ -4373,7 +4378,7 @@ let append_page_content_page fast s before pdf n page =
|
||||||
pdf ops ~fast page
|
pdf ops ~fast page
|
||||||
|
|
||||||
let append_page_content s before fast range pdf =
|
let append_page_content s before fast range pdf =
|
||||||
process_pages (append_page_content_page fast s before pdf) pdf range
|
process_pages (ppstub (append_page_content_page fast s before pdf)) pdf range
|
||||||
|
|
||||||
|
|
||||||
(* 1. Get list of indirects of all OCGs from the /OCProperties, and their textual names
|
(* 1. Get list of indirects of all OCGs from the /OCProperties, and their textual names
|
||||||
|
@ -4547,7 +4552,7 @@ let show_boxes_page fast pdf _ page =
|
||||||
Pdfpage.postpend_operators pdf ops ~fast page
|
Pdfpage.postpend_operators pdf ops ~fast page
|
||||||
|
|
||||||
let show_boxes ?(fast=false) pdf range =
|
let show_boxes ?(fast=false) pdf range =
|
||||||
process_pages (show_boxes_page fast pdf) pdf range
|
process_pages (ppstub (show_boxes_page fast pdf)) pdf range
|
||||||
|
|
||||||
let allowance = 9.
|
let allowance = 9.
|
||||||
|
|
||||||
|
@ -4577,7 +4582,7 @@ let trim_marks_page fast pdf n page =
|
||||||
| _, _ -> Printf.eprintf "warning: no /TrimBox found on page %i\n" n; page
|
| _, _ -> Printf.eprintf "warning: no /TrimBox found on page %i\n" n; page
|
||||||
|
|
||||||
let trim_marks ?(fast=false) pdf range =
|
let trim_marks ?(fast=false) pdf range =
|
||||||
process_pages (trim_marks_page fast pdf) pdf range
|
process_pages (ppstub (trim_marks_page fast pdf)) pdf range
|
||||||
|
|
||||||
let rec remove_all_text_ops pdf resources content =
|
let rec remove_all_text_ops pdf resources content =
|
||||||
let is_textop = function
|
let is_textop = function
|
||||||
|
@ -4641,7 +4646,7 @@ let remove_clipping pdf range =
|
||||||
process_xobjects pdf page remove_clipping_ops;
|
process_xobjects pdf page remove_clipping_ops;
|
||||||
{page with Pdfpage.content = content'}
|
{page with Pdfpage.content = content'}
|
||||||
in
|
in
|
||||||
process_pages remove_clipping_page pdf range
|
process_pages (ppstub remove_clipping_page) pdf range
|
||||||
|
|
||||||
(* Image resolution *)
|
(* Image resolution *)
|
||||||
type xobj =
|
type xobj =
|
||||||
|
|
3
cpdf.mli
3
cpdf.mli
|
@ -44,7 +44,8 @@ val endpage_io : ?revision:int -> Pdfio.input -> string option -> string option
|
||||||
|
|
||||||
(** Given a function from page number and page to page, a document, and a list
|
(** Given a function from page number and page to page, a document, and a list
|
||||||
of page numbers to apply it to, apply the function to all those pages. *)
|
of page numbers to apply it to, apply the function to all those pages. *)
|
||||||
val process_pages : (int -> Pdfpage.t -> Pdfpage.t) -> Pdf.t -> int list -> Pdf.t
|
val process_pages : (int -> Pdfpage.t -> Pdfpage.t * int * Pdftransform.transform_matrix) ->
|
||||||
|
Pdf.t -> int list -> Pdf.t
|
||||||
|
|
||||||
(** Same as [process_pages], but iterate rather than map. *)
|
(** Same as [process_pages], but iterate rather than map. *)
|
||||||
val iter_pages : (int -> Pdfpage.t -> unit) -> Pdf.t -> int list -> unit
|
val iter_pages : (int -> Pdfpage.t -> unit) -> Pdf.t -> int list -> unit
|
||||||
|
|
|
@ -43,7 +43,6 @@ let optstring = function
|
||||||
| "" -> None
|
| "" -> None
|
||||||
| x -> Some x
|
| x -> Some x
|
||||||
|
|
||||||
(* To prevent problems when piping on Windows *)
|
|
||||||
let _ =
|
let _ =
|
||||||
set_binary_mode_in stdin true;
|
set_binary_mode_in stdin true;
|
||||||
set_binary_mode_out stdout true
|
set_binary_mode_out stdout true
|
||||||
|
@ -782,9 +781,12 @@ let rec decrypt_if_necessary (_, _, user_pw, owner_pw, was_dec_with_owner, _) op
|
||||||
if args.debugcrypt then Printf.printf "Failed to decrypt with user password: raising soft_error";
|
if args.debugcrypt then Printf.printf "Failed to decrypt with user password: raising soft_error";
|
||||||
soft_error "Failed to decrypt file: wrong password?"
|
soft_error "Failed to decrypt file: wrong password?"
|
||||||
|
|
||||||
|
(* Duplicated from cpdf.ml -> fix *)
|
||||||
|
let ppstub f n p = (f n p, n, Pdftransform.i_matrix)
|
||||||
|
|
||||||
let nobble pdf =
|
let nobble pdf =
|
||||||
if not demo then pdf else
|
if not demo then pdf else
|
||||||
Cpdf.process_pages (Cpdf.nobble_page pdf) pdf (ilist 1 (Pdfpage.endpage pdf))
|
Cpdf.process_pages (ppstub (Cpdf.nobble_page pdf)) pdf (ilist 1 (Pdfpage.endpage pdf))
|
||||||
|
|
||||||
(* Output Page Count *)
|
(* Output Page Count *)
|
||||||
let output_page_count pdf =
|
let output_page_count pdf =
|
||||||
|
@ -2237,7 +2239,7 @@ and specs =
|
||||||
]
|
]
|
||||||
|
|
||||||
and usage_msg =
|
and usage_msg =
|
||||||
"Syntax: cpdf <op> <op-specific arguments> [-o <output file>] <input files>\n\n\
|
"Syntax: cpdf [<operation>] <input files> [-o <output file>]\n\n\
|
||||||
This is a copyrighted, commercial program, and may NOT be freely copied.\n\n\
|
This is a copyrighted, commercial program, and may NOT be freely copied.\n\n\
|
||||||
Version " ^ string_of_int major_version ^ "." ^ string_of_int minor_version ^ " " ^ version_date ^ "\n\n\
|
Version " ^ string_of_int major_version ^ "." ^ string_of_int minor_version ^ " " ^ version_date ^ "\n\n\
|
||||||
To buy, visit http://www.coherentpdf.com/\n\n\
|
To buy, visit http://www.coherentpdf.com/\n\n\
|
||||||
|
@ -2975,10 +2977,10 @@ let getencryption pdf =
|
||||||
(* If a cropbox exists, make it the mediabox. If not, change nothing. *)
|
(* If a cropbox exists, make it the mediabox. If not, change nothing. *)
|
||||||
let copy_cropbox_to_mediabox pdf range =
|
let copy_cropbox_to_mediabox pdf range =
|
||||||
Cpdf.process_pages
|
Cpdf.process_pages
|
||||||
(fun _ page ->
|
(ppstub (fun _ page ->
|
||||||
match Pdf.lookup_direct pdf "/CropBox" page.Pdfpage.rest with
|
match Pdf.lookup_direct pdf "/CropBox" page.Pdfpage.rest with
|
||||||
| Some pdfobject -> {page with Pdfpage.mediabox = Pdf.direct pdf pdfobject}
|
| Some pdfobject -> {page with Pdfpage.mediabox = Pdf.direct pdf pdfobject}
|
||||||
| None -> page)
|
| None -> page))
|
||||||
pdf
|
pdf
|
||||||
range
|
range
|
||||||
|
|
||||||
|
@ -3146,7 +3148,7 @@ the contents of the mediabox will be used if the from fox is not available. If
|
||||||
mediabox_is_missing is false, the page is unaltered. *)
|
mediabox_is_missing is false, the page is unaltered. *)
|
||||||
let copy_box f t mediabox_if_missing pdf range =
|
let copy_box f t mediabox_if_missing pdf range =
|
||||||
Cpdf.process_pages
|
Cpdf.process_pages
|
||||||
(fun _ page ->
|
(ppstub (fun _ page ->
|
||||||
if f = "/MediaBox" then
|
if f = "/MediaBox" then
|
||||||
{page with Pdfpage.rest =
|
{page with Pdfpage.rest =
|
||||||
(Pdf.add_dict_entry page.Pdfpage.rest t (page.Pdfpage.mediabox))}
|
(Pdf.add_dict_entry page.Pdfpage.rest t (page.Pdfpage.mediabox))}
|
||||||
|
@ -3161,7 +3163,7 @@ let copy_box f t mediabox_if_missing pdf range =
|
||||||
| None ->
|
| None ->
|
||||||
if mediabox_if_missing
|
if mediabox_if_missing
|
||||||
then {page with Pdfpage.rest = Pdf.add_dict_entry page.Pdfpage.rest t page.Pdfpage.mediabox}
|
then {page with Pdfpage.rest = Pdf.add_dict_entry page.Pdfpage.rest t page.Pdfpage.mediabox}
|
||||||
else page)
|
else page))
|
||||||
pdf
|
pdf
|
||||||
range
|
range
|
||||||
|
|
||||||
|
@ -3280,7 +3282,7 @@ let remove_unused_resources_page pdf n page =
|
||||||
{page with Pdfpage.resources = Pdf.add_dict_entry page.Pdfpage.resources "/XObject" xobjdict}
|
{page with Pdfpage.resources = Pdf.add_dict_entry page.Pdfpage.resources "/XObject" xobjdict}
|
||||||
|
|
||||||
let remove_unused_resources pdf =
|
let remove_unused_resources pdf =
|
||||||
Cpdf.process_pages (remove_unused_resources_page pdf) pdf (ilist 1 (Pdfpage.endpage pdf))
|
Cpdf.process_pages (ppstub (remove_unused_resources_page pdf)) pdf (ilist 1 (Pdfpage.endpage pdf))
|
||||||
|
|
||||||
(* Extracts font to font.dat in CWD. *)
|
(* Extracts font to font.dat in CWD. *)
|
||||||
let extract_fontfile pagenumber fontname pdf =
|
let extract_fontfile pagenumber fontname pdf =
|
||||||
|
@ -3382,7 +3384,7 @@ let addrectangle
|
||||||
then Pdfpage.prepend_operators pdf ops ~fast:fast page
|
then Pdfpage.prepend_operators pdf ops ~fast:fast page
|
||||||
else Pdfpage.postpend_operators pdf ops ~fast:fast page
|
else Pdfpage.postpend_operators pdf ops ~fast:fast page
|
||||||
in
|
in
|
||||||
Cpdf.process_pages addrectangle_page pdf range
|
Cpdf.process_pages (ppstub addrectangle_page) pdf range
|
||||||
|
|
||||||
let print_spot_colour n s =
|
let print_spot_colour n s =
|
||||||
Printf.printf "%i %s\n" n s
|
Printf.printf "%i %s\n" n s
|
||||||
|
@ -3448,7 +3450,7 @@ let write_json output pdf =
|
||||||
| Stdout ->
|
| Stdout ->
|
||||||
CpdfwriteJSON.write stdout args.jsonparsecontentstreams args.jsonnostreamdata pdf
|
CpdfwriteJSON.write stdout args.jsonparsecontentstreams args.jsonnostreamdata pdf
|
||||||
| File filename ->
|
| File filename ->
|
||||||
let f = open_out_bin filename in
|
let f = open_out filename in
|
||||||
CpdfwriteJSON.write f args.jsonparsecontentstreams args.jsonnostreamdata pdf;
|
CpdfwriteJSON.write f args.jsonparsecontentstreams args.jsonnostreamdata pdf;
|
||||||
close_out f
|
close_out f
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue