package forester
A tool for tending mathematical forests
Install
Dune Dependency
Authors
Maintainers
Sources
4.1.0.tar.gz
md5=576a2fe0666a6bd9fbbf9a567c0aee79
sha512=af7666a0bcd8fb20497a8c0a0bc01cb57db0bde07d68952e40d37464efe81c3a3c8207a5e5dc88264a5f67b5815874e88f3aa31972dd5f0413d44f97e11b758e
doc/src/forester.render/Render_text.ml.html
Source file Render_text.ml
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
open Forester_prelude open Forester_core module E = Render_effect.Perform module Printer = struct module P0 = struct type out = Format.formatter let text txt fmt = Format.fprintf fmt "%s" txt end include Printer_kit.Kit (P0) let contents (printer : t) : string = Format.asprintf "%a" (fun fmt _ -> printer fmt) () end let rec render_node : Sem.node Range.located -> Printer.t = fun node -> match node.value with | Sem.Text txt | Sem.Verbatim txt -> Printer.text txt | Sem.Math (_, xs) -> render xs | Sem.Xml_tag (name, _, body) -> render body | Sem.Link (addr, None, modifier) -> render @@ Option.value ~default:[Range.locate_opt None @@ Sem.Text "Untitled"] @@ Option.bind (E.get_doc addr) @@ fun doc -> Option.map (Sem.apply_modifier modifier) doc.fm.title | Sem.Link (addr, Some title, modifier) -> render @@ Sem.apply_modifier modifier title | Sem.If_tex (_, y) -> render y | Sem.Prim (_, x) -> render x | Sem.TeX_cs _ -> Printer.nil | _ -> Reporter.fatal ?loc:node.loc Unhandled_case "unhandled case in plain text renderer" and render xs = Printer.iter render_node xs
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>