Use up to date termcap file
This commit is contained in:
parent
3e7a95d8af
commit
269e69e522
6 changed files with 32026 additions and 7 deletions
2
.gitignore
vendored
2
.gitignore
vendored
|
@ -17,3 +17,5 @@ _plugins
|
||||||
_tdeps
|
_tdeps
|
||||||
logs
|
logs
|
||||||
_build
|
_build
|
||||||
|
termtypes.master
|
||||||
|
termtypes.master.clean
|
||||||
|
|
18
Makefile
Normal file
18
Makefile
Normal file
|
@ -0,0 +1,18 @@
|
||||||
|
TERMCAP_FILE=http://code.metager.de/source/raw/OpenBSD/src/share/termtypes/termtypes.master
|
||||||
|
|
||||||
|
compile:
|
||||||
|
rebar3 compile
|
||||||
|
|
||||||
|
src/termcap.erl: termtypes.master.clean
|
||||||
|
cp termcap.erl src/termcap.erl
|
||||||
|
./mk-termcap.escript termtypes.master.clean >> src/termcap.erl
|
||||||
|
|
||||||
|
clean:
|
||||||
|
[ -f termtypes.master ] && rm termtypes.master || true
|
||||||
|
[ -f termtypes.master.clean ] && rm termtypes.master.clean || true
|
||||||
|
|
||||||
|
termtypes.master.clean: termtypes.master
|
||||||
|
cat termtypes.master | grep -v '^#' | grep -v '^\s*$$' > termtypes.master.clean
|
||||||
|
|
||||||
|
termtypes.master:
|
||||||
|
curl -O $(TERMCAP_FILE)
|
93
mk-termcap.escript
Executable file
93
mk-termcap.escript
Executable file
|
@ -0,0 +1,93 @@
|
||||||
|
#!/usr/bin/env escript
|
||||||
|
main([In]) ->
|
||||||
|
{ok, File} = file:open(In, [read]),
|
||||||
|
case io:get_line(File, "") of
|
||||||
|
eof ->
|
||||||
|
file:close(File);
|
||||||
|
Cap ->
|
||||||
|
read_lines(File, {parse_name(Cap), ""})
|
||||||
|
end.
|
||||||
|
|
||||||
|
read_lines(File, {H, Acc}) ->
|
||||||
|
case io:get_line(File, "") of
|
||||||
|
eof ->
|
||||||
|
file:close(File),
|
||||||
|
print_term(H, parse_caps(Acc)),
|
||||||
|
io:format("cap_(_) -> [].\n");
|
||||||
|
" " ++ Rest ->
|
||||||
|
case Acc of
|
||||||
|
"" ->
|
||||||
|
read_lines(File, {H, remove_newline(strip_ws(Rest))});
|
||||||
|
_ ->
|
||||||
|
read_lines(File, {H, [Acc, " ", remove_newline(strip_ws(Rest))]})
|
||||||
|
end;
|
||||||
|
"\t" ++ Rest ->
|
||||||
|
case Acc of
|
||||||
|
"" ->
|
||||||
|
read_lines(File, {H, remove_newline(strip_ws(Rest))});
|
||||||
|
_ ->
|
||||||
|
read_lines(File, {H, [Acc, " ", remove_newline(strip_ws(Rest))]})
|
||||||
|
end;
|
||||||
|
Cap ->
|
||||||
|
print_term(H, parse_caps(Acc)),
|
||||||
|
read_lines(File, {parse_name(Cap), ""})
|
||||||
|
end.
|
||||||
|
|
||||||
|
print_term({Term, _Desc, _Aliases}, Caps) ->
|
||||||
|
io:format("cap_(~p) -> ~p;~n", [Term, Caps]).
|
||||||
|
|
||||||
|
|
||||||
|
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.
|
||||||
|
remove_colon(S) ->
|
||||||
|
remove_colon(S, []).
|
||||||
|
|
||||||
|
remove_colon(", \n", Acc) ->
|
||||||
|
lists:reverse(Acc);
|
||||||
|
remove_colon(",\n", Acc) ->
|
||||||
|
lists:reverse(Acc);
|
||||||
|
remove_colon("\n", Acc) ->
|
||||||
|
lists:reverse(Acc);
|
||||||
|
remove_colon("", Acc) ->
|
||||||
|
lists:reverse(Acc);
|
||||||
|
remove_colon([C | R], Acc) ->
|
||||||
|
remove_colon(R, [C | Acc]).
|
||||||
|
|
||||||
|
|
||||||
|
parse_name(S) ->
|
||||||
|
[Term | Rest] = re:split(remove_colon(S), "\\|", [{return,list}]),
|
||||||
|
case lists:reverse(Rest) of
|
||||||
|
[] ->
|
||||||
|
{Term, [], []};
|
||||||
|
[Title | Aliases] ->
|
||||||
|
{Term, Title, Aliases}
|
||||||
|
end.
|
||||||
|
|
||||||
|
parse_caps(S) ->
|
||||||
|
Caps = re:split(S, ",[\\s\\t]*", [{return,list}]),
|
||||||
|
[parse_cap(C, []) || C <- Caps, C =/= ""].
|
||||||
|
|
||||||
|
parse_cap([], Name) ->
|
||||||
|
lists:reverse(Name);
|
||||||
|
parse_cap([$= | V], Name) ->
|
||||||
|
{lists:reverse(Name), V};
|
||||||
|
parse_cap([$# | V], Name) ->
|
||||||
|
{lists:reverse(Name), V};
|
||||||
|
parse_cap([C | R], Name) ->
|
||||||
|
parse_cap(R, [ C | Name]).
|
||||||
|
|
|
@ -101,12 +101,9 @@ colour_term() ->
|
||||||
{ok, V} ->
|
{ok, V} ->
|
||||||
V;
|
V;
|
||||||
undefined ->
|
undefined ->
|
||||||
V = case os:getenv("TERM") of
|
Term = os:getenv("TERM"),
|
||||||
"xterm" ++ _ ->
|
Caps = termcap:cap(Term),
|
||||||
true;
|
V = proplists:is_defined("colors", Caps),
|
||||||
_ ->
|
|
||||||
false
|
|
||||||
end,
|
|
||||||
application:set_env(cf, colour_term, V),
|
application:set_env(cf, colour_term, V),
|
||||||
V
|
V
|
||||||
end.
|
end.
|
||||||
|
|
31895
src/termcap.erl
Normal file
31895
src/termcap.erl
Normal file
File diff suppressed because it is too large
Load diff
14
termcap.erl
Normal file
14
termcap.erl
Normal file
|
@ -0,0 +1,14 @@
|
||||||
|
-module(termcap).
|
||||||
|
|
||||||
|
-export([cap/1]).
|
||||||
|
|
||||||
|
cap(Term) ->
|
||||||
|
resolve(cap_(Term)).
|
||||||
|
|
||||||
|
resolve([]) ->
|
||||||
|
[];
|
||||||
|
resolve([{"use", Cap1} | R]) ->
|
||||||
|
cap(Cap1) ++ resolve(R);
|
||||||
|
resolve([C | R]) ->
|
||||||
|
[C | resolve(R)].
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue