Source file print_table_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
64
65
66
67
68
69
70
71
72
73
open! Import
type t = Print_table_ast.t
let repeat c n = List.init ~len:n ~f:(fun _ -> c) |> String.concat ""
let to_string_non_empty ?(enable_style = true) t =
let box = Box.of_print_table t in
let buffer = Buffer.create 128 in
let columns = box.columns in
let columns_count = Array.length columns in
let draw_line left sep right fill =
Buffer.add_string buffer left;
Array.iteri columns ~f:(fun i (column : Box.Column.t) ->
if i > 0 then Buffer.add_string buffer sep;
Buffer.add_string buffer (repeat fill (column.length + 2)));
Buffer.add_string buffer right;
Buffer.add_char buffer '\n'
in
draw_line "┌" "┬" "┐" "─";
Buffer.add_string buffer "│";
Array.iter columns ~f:(fun { ; align; cells = _; length } ->
Buffer.add_char buffer ' ';
Buffer.add_string buffer (Box.pad header ~len:length ~align);
Buffer.add_char buffer ' ';
Buffer.add_string buffer "│");
Buffer.add_char buffer '\n';
draw_line "├" "┼" "┤" "─";
let num_rows =
if columns_count = 0
then assert false [@coverage off]
else Array.length columns.(0).cells
in
for i = 0 to num_rows - 1 do
Buffer.add_string buffer "│";
Array.iter columns ~f:(fun { Box.Column.header = _; align; cells; length } ->
let { Print_table_ast.Cell.text; style } = cells.(i) in
Buffer.add_char buffer ' ';
let add_colored_text ~ansi_code =
Buffer.add_string buffer (Box.pad text ~ansi_code ~len:length ~align)
in
(match if enable_style then style else Print_table_ast.Style.Default with
| Default -> Buffer.add_string buffer (Box.pad text ~len:length ~align)
| Fg_red -> add_colored_text ~ansi_code:31
| Fg_green -> add_colored_text ~ansi_code:32
| Fg_yellow -> add_colored_text ~ansi_code:33
| Dim -> add_colored_text ~ansi_code:2
| Underscore -> add_colored_text ~ansi_code:4);
Buffer.add_char buffer ' ';
Buffer.add_string buffer "│");
Buffer.add_char buffer '\n'
done;
draw_line "└" "┴" "┘" "─";
Buffer.contents buffer
;;
let to_string ?enable_style (Print_table_ast.T { rows; columns } as t) =
if List.is_empty columns || List.is_empty rows
then ""
else to_string_non_empty ?enable_style t
;;