File: mk-termcap.escript

package info (click to toggle)
erlang-cf 0.3.1-1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm, bullseye, buster, forky, sid, trixie
  • size: 128 kB
  • sloc: erlang: 496; makefile: 21
file content (99 lines) | stat: -rwxr-xr-x 2,807 bytes parent folder | download
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
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
#!/usr/bin/env escript
main([In]) ->
    {ok, File} = file:open(In, [read]),
    case io:get_line(File, "") of
        eof ->
            file:close(File);
        Cap ->
            io:format("-module(cf_term).~n"),
            io:format("-export([has_color/1]).~n"),
            Terms = read_lines(File, {parse_name(Cap), ""}, []),
            Terms1 = [{T, has_color(Vs, Terms)} || {T, Vs} <- Terms],
            [io:format("has_color(~p) -> true;~n", [T]) || {T, true} <- Terms1],
            io:format("has_color(_) -> false.~n")
    end.

read_lines(File, {H, Acc}, FAcc) ->
    case io:get_line(File, "") of
        eof  ->
            file:close(File),
            lists:sort([{H, parse_caps(Acc)} | FAcc]);
        " " ++ Rest ->
            case Acc of
                "" ->
                    read_lines(File, {H, remove_newline(strip_ws(Rest))}, FAcc);
                _ ->
                    read_lines(File, {H, [Acc, " ", remove_newline(strip_ws(Rest))]}, FAcc)
            end;
        "\t" ++ Rest ->
            case Acc of
                "" ->
                    read_lines(File, {H, remove_newline(strip_ws(Rest))}, FAcc);
                _ ->
                    read_lines(File, {H, [Acc, " ", remove_newline(strip_ws(Rest))]}, FAcc)
            end;
        Cap ->
            read_lines(File, {parse_name(Cap), ""}, [{H, parse_caps(Acc)} | FAcc])
    end.

has_color([], _Ts) ->
    false;
has_color([{colors, _} | _], _Ts) ->
    true;
has_color([{use, T} | R], Ts) ->
    case orddict:find(T, Ts) of
        error ->
            has_color(R, Ts);
        {ok, V} ->
            has_color(V, Ts) orelse
                has_color(R, Ts)
    end.

remove_newline(S) ->
    remove_newline(S, []).

remove_newline("\n", Acc) ->
    lists:reverse(Acc);

remove_newline("", Acc) ->
    lists:reverse(Acc);
remove_newline([C | R], Acc) ->
    remove_newline(R, [C | Acc]).

strip_ws([$\s | R]) ->
    strip_ws(R);
strip_ws([$\t | R]) ->
    strip_ws(R);
strip_ws(R) ->
    R.

filter_caps([]) ->
    [];
filter_caps([{colors, _} = C | R]) ->
    [C | filter_caps(R)];
filter_caps([{use, _} = C | R]) ->
    [C | filter_caps(R)];
filter_caps([_ | R]) ->
    filter_caps(R).


remove_colon(S) ->
    re:replace(S, ",[\\s\\n\\t]*$", "", [{return,list}]).

parse_name(S) ->
    [Term | _Rest] = re:split(remove_colon(S), "\\|", [{return,list}]),
    Term.

parse_caps(S) ->
    Caps = re:split(remove_colon(S), ",[\\s\\t]+", [{return,list}]),
    filter_caps([parse_cap(C, []) || C <- Caps, C =/= ""]).

parse_cap([], Name) ->
    list_to_atom(lists:reverse(Name));
parse_cap([$= | V], Name) ->
    {list_to_atom(lists:reverse(Name)), V};
parse_cap([$# | V], Name) ->
    {list_to_atom(lists:reverse(Name)), list_to_integer(V)};
parse_cap([C | R], Name) ->
    parse_cap(R, [ C | Name]).