Determines how groups should have linebreaks inserted when the text would overfill its remaining space.
allOrNone
will make a linebreak on everyFormat.line
in the group or none of them.[1, 2, 3]
fill
will only make linebreaks on as fewFormat.line
s as possible:[1, 2, 3]
- allOrNone: Std.Format.FlattenBehavior
- fill: Std.Format.FlattenBehavior
Instances For
Equations
A string with pretty-printing information for rendering in a column-width-aware way.
The pretty-printing algorithm is based on Wadler's paper A Prettier Printer.
- nil: Std.Format
The empty format.
- line: Std.Format
A position where a newline may be inserted if the current group does not fit within the allotted column width.
- align: Bool → Std.Format
- text: String → Std.Format
A node containing a plain string.
- nest: Int → Std.Format → Std.Format
nest n f
tells the formatter thatf
is nested inside something with lengthn
so that it is pretty-printed with the correct indentation on a line break. For example, we can define a formatter for listl : List Format
as:let f := join <| l.intersperse <| ", " ++ Format.line group (nest 1 <| "[" ++ f ++ "]")
This will be written all on one line, but if the text is too large, the formatter will put in linebreaks after the commas and indent later lines by 1.
- append: Std.Format → Std.Format → Std.Format
Concatenation of two Formats.
- group: Std.Format → optParam Std.Format.FlattenBehavior Std.Format.FlattenBehavior.allOrNone → Std.Format
Creates a new flattening group for the given inner format.
- tag: Nat → Std.Format → Std.Format
Used for associating auxiliary information (e.g.
Expr
s) withFormat
objects.
Instances For
Equations
- Std.instInhabitedFormat = { default := Std.Format.nil }
Check whether the given format contains no characters.
Equations
- Std.Format.nil.isEmpty = true
- Std.Format.line.isEmpty = false
- (Std.Format.align force).isEmpty = true
- (Std.Format.text msg).isEmpty = (msg == "")
- (Std.Format.nest indent f).isEmpty = f.isEmpty
- (f₁.append f₂).isEmpty = (f₁.isEmpty && f₂.isEmpty)
- (f.group behavior).isEmpty = f.isEmpty
- (Std.Format.tag a f).isEmpty = f.isEmpty
Instances For
Alias for a group with FlattenBehavior
set to fill
.
Equations
- f.fill = f.group Std.Format.FlattenBehavior.fill
Instances For
Equations
- Std.Format.instAppend = { append := Std.Format.append }
Equations
- Std.Format.instCoeString = { coe := Std.Format.text }
Equations
- Std.Format.join xs = List.foldl (fun (x1 x2 : Std.Format) => x1 ++ x2) (Std.Format.text "") xs
Instances For
Equations
- Std.Format.nil.isNil = true
- x.isNil = false
Instances For
Equations
- Std.Format.instInhabitedSpaceResult = { default := { foundLine := default, foundFlattenedHardLine := default, space := default } }
Render the given f : Format
with a line width of w
.
indent
is the starting amount to indent each line by.
Equations
- f.prettyM w indent = Std.Format.be✝ w [{ flatten := false, flb := Std.Format.FlattenBehavior.allOrNone, items := [{ f := f, indent := ↑indent, activeTags := 0 }] }]
Instances For
Create a format l ++ f ++ r
with a flatten group.
FlattenBehaviour is allOrNone
; for fill
use bracketFill
.
Equations
- Std.Format.bracket l f r = (Std.Format.nest (↑l.length) (Std.Format.text l ++ f ++ Std.Format.text r)).group
Instances For
Creates the format "(" ++ f ++ ")"
with a flattening group.
Equations
- f.paren = Std.Format.bracket "(" f ")"
Instances For
Creates the format "[" ++ f ++ "]"
with a flattening group.
Equations
- f.sbracket = Std.Format.bracket "[" f "]"
Instances For
Same as bracket
except uses the fill
flattening behaviour.
Equations
- Std.Format.bracketFill l f r = (Std.Format.nest (↑l.length) (Std.Format.text l ++ f ++ Std.Format.text r)).fill
Instances For
Default indentation.
Equations
Instances For
Nest with the default indentation amount.
Equations
- f.nestD = Std.Format.nest (↑Std.Format.defIndent) f
Instances For
Insert a newline and then f
, all nested by the default indent amount.
Equations
- f.indentD = (Std.Format.line ++ f).nestD
Instances For
Equations
- One or more equations did not get rendered due to their size.
Renders a Format
to a string.
width
: the total widthindent
: the initial indentation to use for wrapped lines (subsequent wrapping may increase the indentation)column
: begin the first line wrapcolumn
characters earlier than usual (this is useful when the output String will be printed starting atcolumn
)
Equations
- f.pretty width indent column = (f.prettyM width indent { out := "", column := column }).snd.out
Instances For
Class for converting a given type α to a Format
object for pretty-printing.
See also Repr
, which also outputs a Format
object.
- format : α → Std.Format
Instances
Equations
- Std.instToFormatFormat = { format := fun (f : Std.Format) => f }
Equations
- Std.instToFormatString = { format := fun (s : String) => Std.Format.text s }
Intersperse the given list (each item printed with format
) with the given sep
format.
Equations
- Std.Format.joinSep [] x = Std.Format.nil
- Std.Format.joinSep [a] x = Std.format a
- Std.Format.joinSep (a :: as) x = List.foldl (fun (x1 : Std.Format) (x2 : α) => x1 ++ x ++ Std.format x2) (Std.format a) as
Instances For
Format each item in items
and prepend prefix pre
.
Equations
- pre.prefixJoin [] = Std.Format.nil
- pre.prefixJoin (a :: as) = List.foldl (fun (x1 : Std.Format) (x2 : α) => x1 ++ pre ++ Std.format x2) (pre ++ Std.format a) as
Instances For
Format each item in items
and append suffix
.
Equations
- Std.Format.joinSuffix [] x = Std.Format.nil
- Std.Format.joinSuffix (a :: as) x = List.foldl (fun (x1 : Std.Format) (x2 : α) => x1 ++ Std.format x2 ++ x) (Std.format a ++ x) as