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
53
54
55
56
57
58
59
60
61
62
63
open Prelude
open 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 -> Printer.t =
function
| Sem.Text txt ->
Printer.text txt
| Sem.Math (_, xs) ->
render xs
| Sem.Tag (name, _, body) ->
render body
| Sem.Link {title = None; dest} ->
render @@
Option.value ~default:[Sem.Text dest] @@
Option.bind (E.get_doc dest) @@ fun doc ->
doc.title
| Sem.Link {title = Some title; dest} ->
render title
| Sem.Transclude (_, addr) ->
Printer.seq
[Printer.text "\\transclude{";
Printer.text addr;
Printer.text "}"]
| Sem.If_tex (_, y) ->
render y
| node ->
Format.eprintf "missing case: %a@." Sem.pp_node node;
failwith "Render_text.render_node"
and render xs =
Printer.iter render_node xs
and render_arg delim (arg : Sem.t) : Printer.t =
match arg with
| [] -> Printer.nil
| _ ->
let l, r =
match delim with
| Braces -> "{", "}"
| Squares -> "[", "]"
| Parens -> "(", ")"
in
Printer.seq
[Printer.text l;
render arg;
Printer.text r]