Source file text_table_markdown.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
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
type t = Text_table_ast.t
let to_string_non_empty t =
let buffer = Buffer.create 128 in
let box = Box.of_text_table t in
let columns = box.columns in
let columns_count = Array.length columns in
Buffer.add_char buffer '|';
Array.iter columns ~f:(fun col ->
Buffer.add_char buffer ' ';
Buffer.add_string buffer (Box.pad col.header ~len:col.length ~align:col.align);
Buffer.add_char buffer ' ';
Buffer.add_char buffer '|');
Buffer.add_char buffer '\n';
Buffer.add_char buffer '|';
Array.iter columns ~f:(fun col ->
let spec =
match col.align with
| Left -> ":" ^ String.make (col.length + 1) '-'
| Right -> String.make (col.length + 1) '-' ^ ":"
| Center -> ":" ^ String.make col.length '-' ^ ":"
in
Buffer.add_string buffer spec;
Buffer.add_char buffer '|');
Buffer.add_char buffer '\n';
let n_rows =
if columns_count = 0
then assert false [@coverage off]
else List.length columns.(0).cells
in
for i = 0 to n_rows - 1 do
Buffer.add_char buffer '|';
Array.iter columns ~f:(fun col ->
let { Text_table_ast.Cell.text; style } = List.nth_exn col.cells i in
let () =
match style with
| Default | Fg_red ->
()
in
Buffer.add_char buffer ' ';
Buffer.add_string buffer (Box.pad text ~len:col.length ~align:col.align);
Buffer.add_char buffer ' ';
Buffer.add_char buffer '|');
Buffer.add_char buffer '\n'
done;
Buffer.contents buffer
;;
let to_string (Text_table_ast.T { rows; columns } as t) =
if List.is_empty columns || List.is_empty rows then "" else to_string_non_empty t
;;