This commit is contained in:
John Whitington
2022-01-02 15:18:55 +00:00
parent b602834e87
commit 82863fe273
2 changed files with 30 additions and 10 deletions

View File

@@ -480,7 +480,8 @@ type args =
mutable dict_entry_search : Pdf.pdfobject option; mutable dict_entry_search : Pdf.pdfobject option;
mutable toc_title : string; mutable toc_title : string;
mutable toc_bookmark : bool; mutable toc_bookmark : bool;
mutable idir_only_pdfs : bool} mutable idir_only_pdfs : bool;
mutable no_warn_rotate : bool}
let args = let args =
{op = None; {op = None;
@@ -600,7 +601,8 @@ let args =
dict_entry_search = None; dict_entry_search = None;
toc_title = "Table of Contents"; toc_title = "Table of Contents";
toc_bookmark = true; toc_bookmark = true;
idir_only_pdfs = false} idir_only_pdfs = false;
no_warn_rotate = false}
let reset_arguments () = let reset_arguments () =
args.op <- None; args.op <- None;
@@ -707,10 +709,10 @@ let reset_arguments () =
args.toc_bookmark <- true; args.toc_bookmark <- true;
args.idir_only_pdfs <- false args.idir_only_pdfs <- false
(* Do not reset original_filename or cpdflin or was_encrypted or (* Do not reset original_filename or cpdflin or was_encrypted or
* was_decrypted_with_owner or recrypt or producer or creator or path_to_* or was_decrypted_with_owner or recrypt or producer or creator or path_to_* or
* gs_malformed or gs_quiet, since we want these to work across ANDs. Or gs_malformed or gs_quiet or no-warn-rotate, since we want these to work
* squeeze options: a little odd, but we want it to happen on eventual across ANDs. Or squeeze options: a little odd, but we want it to happen on
* output. *) eventual output. *)
(* Prefer a) the one given with -cpdflin b) a local cpdflin, c) otherwise assume (* Prefer a) the one given with -cpdflin b) a local cpdflin, c) otherwise assume
installed at a system place *) installed at a system place *)
@@ -1705,6 +1707,9 @@ let settocnobookmark () =
let setidironlypdfs () = let setidironlypdfs () =
args.idir_only_pdfs <- true args.idir_only_pdfs <- true
let setnowarnrotate () =
args.no_warn_rotate <- true
let whingemalformed () = let whingemalformed () =
prerr_string "Command line must be of exactly the form\ncpdf <infile> -gs <path> -gs-malformed-force -o <outfile>\n"; prerr_string "Command line must be of exactly the form\ncpdf <infile> -gs <path> -gs-malformed-force -o <outfile>\n";
exit 1 exit 1
@@ -1849,6 +1854,12 @@ and specs =
("-upright", ("-upright",
Arg.Unit (setop Upright), Arg.Unit (setop Upright),
" Make pages upright"); " Make pages upright");
("-prerotate",
Arg.Unit setprerotate,
" Calls -upright on pages before modifying them, if required");
("-no-warn-rotate",
Arg.Unit setnowarnrotate,
" Do not warn on pages of PDFs which are not upright");
("-hflip", ("-hflip",
Arg.Unit (setop HFlip), Arg.Unit (setop HFlip),
" Flip pages horizontally"); " Flip pages horizontally");
@@ -2090,9 +2101,7 @@ and specs =
("-embed-missing-fonts", ("-embed-missing-fonts",
Arg.Unit (setop EmbedMissingFonts), Arg.Unit (setop EmbedMissingFonts),
" Embed missing fonts by calling gs"); " Embed missing fonts by calling gs");
("-prerotate",
Arg.Unit setprerotate,
" Calls -upright on pages before adding text");
("-twoup", ("-twoup",
Arg.Unit (setop TwoUp), Arg.Unit (setop TwoUp),
" Put 2 pages onto one"); " Put 2 pages onto one");
@@ -2996,6 +3005,15 @@ let collate (names, pdfs, ranges) =
done; done;
split3 (rev !nis) split3 (rev !nis)
let warn_prerotate range pdf =
if not (Cpdfpage.allupright range pdf) then
Printf.eprintf "Some pages in the range have non-zero rotation or non (0,0)-based mediabox. \
Consider adding -prerotate or pre-processing with -upright. \
To silence this warning use -no-warn-rotate\n%!"
let prerotate range pdf =
Cpdfpage.upright ~fast:args.fast range pdf
(* Main function *) (* Main function *)
let go () = let go () =
match args.op with match args.op with
@@ -3667,7 +3685,7 @@ let go () =
| OtherFont f -> None (* it's in fontname *) | OtherFont f -> None (* it's in fontname *)
in in
let pdf = let pdf =
if args.prerotate then Cpdfpage.upright ~fast:args.fast range pdf else pdf if args.prerotate then prerotate range pdf else pdf
and filename = and filename =
match args.inputs with match args.inputs with
| (InFile inname, _, _, _, _, _)::_ -> inname | (InFile inname, _, _, _, _, _)::_ -> inname

View File

@@ -103,3 +103,5 @@ val trim_marks : ?fast:bool -> Pdf.t -> int list -> Pdf.t
val show_boxes : ?fast:bool -> Pdf.t -> int list -> Pdf.t val show_boxes : ?fast:bool -> Pdf.t -> int list -> Pdf.t
val copy_box : string -> string -> bool -> Pdf.t -> int list -> Pdf.t val copy_box : string -> string -> bool -> Pdf.t -> int list -> Pdf.t
val allupright : int list -> Pdf.t -> bool