package pp
Install
Dune Dependency
Authors
Maintainers
Sources
sha256=8651351518b092b4a2def4e08171c276152f92fb6a84a8b19b6b929ccdb44419
sha512=78cb68f35c0b975dd1e91bd83d5e33bcec1ee642431585d55864c483c70a032755dfcf21ec5697691e7e7554381ddb580639fd149e28ba6f74d04d2ee43d360d
doc/pp/Pp/index.html
Module Pp
Source
Pretty-printing.
'tag t
represents a document that is not yet rendered. The argument 'tag
is the type of tags in the document. For instance tags might be used for styles.
If you want to serialise and deserialise this datastructure, you can use the Ast.t
type together with the of_ast
and to_ast
functions.
Basic combinators
concat ?sep l
prints elements in l
separated by sep
. sep
defaults to nop
.
Convenience function for List.map
followed by concat
.
Convenience function for List.mapi
followed by concat
.
Same as verbatim
but take a format string as argument.
Print a bunch of text. The line may be broken at any spaces in the text.
Same as text
but take a format string as argument.
Break hints
space
instructs the pretty-printing algorithm that the line may be broken at this point. If the algorithm decides not to break the line, a single space will be printed instead.
So for instance verbatim "x" ++ space ++ verbatim "y"
might produce "x y" or "x\n<indentation>y".
cut
instructs the pretty-printing algorithm that the line may be broken at this point. If the algorithm decides not to break the line, nothing is printed instead.
So for instance verbatim "x" ++ space ++ verbatim "y"
might produce "xy" or "x\n<indentation>y".
break
is a generalisation of space
and cut
. It also instructs the pretty-printing algorithm that the line may be broken at this point. If it ends up being broken, shift
will be added to the indentation level, otherwise nspaces
spaces will be printed. shift
can be negative, in which case the indentation will be reduced.
custom_break ~fits:(a, b, c) ~breaks:(x, y, z)
is a generalisation of break
. It also instructs the pretty-printing algorithm that the line may be broken at this point. If it ends up being broken, x
is printed, the line breaks, y
will be added to the indentation level and z
is printed, otherwise a
will be printed, b
spaces are printed and then c
is printed. The indentation y
can be negative, in which case the indentation will be reduced.
Force a newline to be printed. Usage is discourage since it breaks printing with boxes. If you need to add breaks to your text, put your items into box
es and concat
with a separating space
afterwhich wrapping it in a vbox
.
Boxes
Boxes are the basic components to control the layout of the text. Break hints such as space
and cut
may cause the line to be broken, depending on the splitting rules. Whenever a line is split, the rest of the material printed in the box is indented with indent
.
You can think of a box with indentation as something with this shape:
######################### <- first line <indent>################# <indent>################# <indent>################# <indent>#################
And the top left corner of this shape is anchored where the box was declared. So for instance, the following document:
Pp.verbatim "....." ++ Pp.box ~indent:2 (Pp.text "some long ... text")
would produce:
.....some long ... text
Try to put as much as possible on each line. Additionally, a break hint always break the line if the breaking would reduce the indentation level inside the box (break
with negative shift
value).
Always break the line when encountering a break hint.
If possible, print everything on one line. Otherwise, behave as a vbox
Try to put as much as possible on each line. Basically the same as box
but without the rule about breaks with negative shift
value.
Tags
Tags are arbitrary pieces of information attached to a document. They can be used to add styles to pretty-printed text, for instance to print to the terminal with colors.
Convert tags in a documents
Convert tags in a documents, possibly removing some tags.
Convenience functions
paragraph s
is hovbox (text s)
. This is useful to preserve the structure of a paragraph of text without worrying about it being broken by a vbox
.
paragraphf s
is textf s
followed by a hovbox
. The textf
version of paragraph
.
enumerate l ~f
produces an enumeration of the form:
- item1 - item2 - item3 ...
chain l ~f
is used to print a succession of items that follow each other. It produces an output of this form:
item1 -> item2 -> item3 ...
Operators
Rendering
Render a document to a classic formatter
val to_fmt_with_tags :
Format.formatter ->
'tag t ->
tag_handler:(Format.formatter -> 'tag -> 'tag t -> unit) ->
unit