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: 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
Equations
- Std.instInhabitedFormat = { default := Lean.Format.nil }
Check whether the given format contains no characters.
Equations
- Std.Format.isEmpty Lean.Format.nil = true
- Std.Format.isEmpty Lean.Format.line = false
- Std.Format.isEmpty (Lean.Format.align force) = true
- Std.Format.isEmpty (Std.Format.text msg) = (msg == "")
- Std.Format.isEmpty (Lean.Format.nest indent f) = Std.Format.isEmpty f
- Std.Format.isEmpty (Std.Format.append f₁ f₂) = (Std.Format.isEmpty f₁ && Std.Format.isEmpty f₂)
- Std.Format.isEmpty (Lean.Format.group f behavior) = Std.Format.isEmpty f
- Std.Format.isEmpty (Lean.Format.tag a f) = Std.Format.isEmpty f
Instances For
Alias for a group with FlattenBehavior
set to fill
.
Instances For
Equations
- Std.Format.instAppendFormat = { append := Std.Format.append }
Equations
- Std.Format.instCoeStringFormat = { coe := Std.Format.text }
Equations
- Lean.Format.join xs = List.foldl (fun (x x_1 : Lean.Format) => x ++ x_1) (Std.Format.text "") xs
Instances For
Equations
- Std.Format.isNil x = match x with | Lean.Format.nil => true | x => 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
- Std.Format.prettyM f 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.group (Lean.Format.nest (↑(String.length l)) (Std.Format.text l ++ f ++ Std.Format.text r))
Instances For
Creates the format "(" ++ f ++ ")"
with a flattening group.
Equations
- Lean.Format.paren f = Lean.Format.bracket "(" f ")"
Instances For
Creates the format "[" ++ f ++ "]"
with a flattening group.
Equations
- Lean.Format.sbracket f = Lean.Format.bracket "[" f "]"
Instances For
Same as bracket
except uses the fill
flattening behaviour.
Equations
- Std.Format.bracketFill l f r = Lean.Format.fill (Lean.Format.nest (↑(String.length l)) (Std.Format.text l ++ f ++ Std.Format.text r))
Instances For
Default indentation.
Equations
Instances For
Nest with the default indentation amount.
Equations
Instances For
Insert a newline and then f
, all nested by the default indent amount.
Equations
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
- Lean.Format.pretty f width indent column = let act := Std.Format.prettyM f width indent; (act { 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 : α → Lean.Format
Instances
Equations
- Std.instToFormatFormat = { format := fun (f : Lean.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
- One or more equations did not get rendered due to their size.
Instances For
Format each item in items
and prepend prefix pre
.
Equations
- Std.Format.prefixJoin pre x = match x with | [] => Lean.Format.nil | a :: as => List.foldl (fun (x : Lean.Format) (x_1 : α) => x ++ pre ++ Std.format x_1) (pre ++ Std.format a) as
Instances For
Format each item in items
and append suffix
.
Equations
- One or more equations did not get rendered due to their size.