-
Notifications
You must be signed in to change notification settings - Fork 29
/
Copy pathpdfpagelabels.mli
73 lines (56 loc) · 2.29 KB
/
pdfpagelabels.mli
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
(** Page Labels *)
(** The type for page labels. The page labels of a document, if well-formed,
are a list of [t]s where the [startpage] values are in increasing numerical
order. The numerical page number for the page range is [startvalue]. The
default labelstyle is [DecimalArabic]. The default [labelprefix] is the empty
string.
For example, a document might have five pages of introduction with roman
numerals, followed by the rest of the pages in decimal arabic, numbered from
one:
{labelstyle = LowercaseRoman;
labelprefix = "";
startpage = 1;
startvalue = 1}
{labelstyle = DecimalArabic;
labelprefix = "";
startpage = 6;
startvalue = 1}
For more details, see ISO 32000 12.4.2, but note that in our implementation,
pages are 1-based not 0-based, just like PDF page numbers. *)
type labelstyle =
| DecimalArabic
| UppercaseRoman
| LowercaseRoman
| UppercaseLetters
| LowercaseLetters
| NoLabelPrefixOnly
type t =
{labelstyle : labelstyle;
labelprefix : string option;
startpage : int;
startvalue : int}
(** String of label style e.g DecimalArabic *)
val string_of_labelstyle : labelstyle -> string
(** Debug string of page label *)
val string_of_pagelabel : t -> string
(** Read the page labels from a document *)
val read : Pdf.t -> t list
(** Return a list where every page has a label - pages which don't are given
arabic page numbers *)
val complete : t list -> t list
(** Single label representing a given page. Raises [Not_found] if no label. *)
val pagelabel_of_pagenumber : int -> t list -> t
(** Return the text for a page label. Raises [Not_found] if no label. *)
val pagelabeltext_of_pagenumber : int -> t list -> string
(** Add a range starting at pagelabel.startpage, ending at the integer page
given. The first integer argument is the number of pages in the PDF. *)
val add_label : int -> t list -> t -> int -> t list
(** Optimise page labels, removing any which are not required. *)
val coalesce : t list -> t list
(** Merge some page labels for some PDFs and page ranges. *)
val merge_pagelabels : Pdf.t list -> int list list -> t list
(** Write page labels to a document, replacing any there. Any existing page
labels are removed. *)
val write : Pdf.t -> t list -> unit
(** Remove all page labels. Equivalent to an empty list given to [write]. *)
val remove : Pdf.t -> unit