package forester
A tool for tending mathematical forests
Install
Dune Dependency
Authors
Maintainers
Sources
4.3.1.tar.gz
md5=d1623b2919d2984bfcd841b5e772abd1
sha512=5924c8822d7e5a7bc49eb2b451cfd06cb372415559bc5ff232a59395b0aa28eb9819e351426ab25510f7d96ffb85ec652fa1878478b046c61e51ff471c285710
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 49 50 51 52
open Forester_prelude open Forester_core 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 ~trees : 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 ~trees xs | Sem.Xml_tag (name, _, body) -> render ~trees body | Sem.Link (addr, None, modifier) -> render ~trees @@ let addr_string = Format.asprintf "[%a]" pp_addr addr in Option.value ~default:[Range.locate_opt None @@ Sem.Text addr_string] @@ Option.bind (Addr_map.find_opt addr trees) @@ fun (tree : Sem.tree) -> Option.map (Sem.apply_modifier modifier) tree.fm.title | Sem.Link (addr, Some title, modifier) -> render ~trees @@ Sem.apply_modifier modifier title | Sem.Ref addr -> let addr_string = Format.asprintf "[%a]" pp_addr addr in let taxon_string = match Option.bind (Addr_map.find_opt addr trees) (fun tree -> tree.fm.taxon) with | None -> "§" | Some taxon -> String_util.sentence_case taxon in Printer.seq ~sep:Printer.space [ Printer.text taxon_string; Printer.text addr_string ] | Sem.Prim (_, x) -> render ~trees x | Sem.TeX_cs _ | Sem.Transclude _ | Sem.Subtree _ | Sem.Query_tree _ | Sem.Resource _ | Sem.Img _ -> Printer.nil and render ~trees xs = Printer.iter (render_node ~trees) xs
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>