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
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: Lean.Format
The empty format.
- line: Lean.Format
A position where a newline may be inserted if the current group does not fit within the allotted column width.
- align: Bool → Lean.Format
- text: String → Lean.Format
A node containing a plain string.
- nest: Int → Lean.Format → Lean.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: Lean.Format → Lean.Format → Lean.Format
Concatenation of two Formats.
- group: Lean.Format → optParam Std.Format.FlattenBehavior Std.Format.FlattenBehavior.allOrNone → Lean.Format
Creates a new flattening group for the given inner format.
- tag: Nat → Lean.Format → Lean.Format
Used for associating auxiliary information (e.g.
Expr
s) withFormat
objects.
Instances For
Check whether the given format contains no characters.
Equations
- Lean.Format.nil.isEmpty = true
- Lean.Format.line.isEmpty = false
- (Lean.Format.align force).isEmpty = true
- (Std.Format.text msg).isEmpty = (msg == "")
- (Lean.Format.nest indent f).isEmpty = f.isEmpty
- (f₁.append f₂).isEmpty = (f₁.isEmpty && f₂.isEmpty)
- (f.group behavior).isEmpty = f.isEmpty
- (Lean.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
- Lean.Format.nil.isNil = true
- x.isNil = false
Instances For
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
- Lean.Format.bracket l f r = (Lean.Format.nest (↑l.length) (Std.Format.text l ++ f ++ Std.Format.text r)).group
Instances For
Creates the format "(" ++ f ++ ")"
with a flattening group.
Instances For
Creates the format "[" ++ f ++ "]"
with a flattening group.
Equations
- f.sbracket = Lean.Format.bracket "[" f "]"
Instances For
Default indentation.
Equations
Instances For
Nest with the default indentation amount.
Equations
- f.nestD = Lean.Format.nest (↑Std.Format.defIndent) f
Instances For
Insert a newline and then f
, all nested by the default indent amount.
Equations
- f.indentD = (Lean.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
)
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 : α → Lean.Format
Instances
Intersperse the given list (each item printed with format
) with the given sep
format.
Instances For
Format each item in items
and prepend prefix pre
.
Equations
- pre.prefixJoin [] = Lean.Format.nil
- pre.prefixJoin (a :: as) = List.foldl (fun (x1 : Lean.Format) (x2 : α) => x1 ++ pre ++ Lean.format x2) (pre ++ Lean.format a) as
Instances For
Format each item in items
and append suffix
.
Equations
- Std.Format.joinSuffix [] x = Lean.Format.nil
- Std.Format.joinSuffix (a :: as) x = List.foldl (fun (x1 : Lean.Format) (x2 : α) => x1 ++ Lean.format x2 ++ x) (Lean.format a ++ x) as