tput
radzi sobie z wyrażeniami (na przykład w sgr
i setaf
), które typowy skrypt-shell uznałby za mało użyteczne. Aby zorientować się, co jest zaangażowany, zobaczymy wyniku infocmp
z -f
stosowana (formatowanie) opcja. Oto jeden z przykładów użycia tych ciągów z opisów terminfo xterm :
xterm-16color|xterm with 16 colors,
colors#16,
pairs#256,
setab=\E[
%?
%p1%{8}%<
%t%p1%{40}%+
%e
%p1%{92}%+
%;%dm,
setaf=\E[
%?
%p1%{8}%<
%t%p1%{30}%+
%e
%p1%{82}%+
%;%dm,
setb=
%p1%{8}%/%{6}%*%{4}%+\E[%d%p1%{8}%m%Pa
%?%ga%{1}%=
%t4
%e%ga%{3}%=
%t6
%e%ga%{4}%=
%t1
%e%ga%{6}%=
%t3
%e%ga%d
%;
m,
setf=
%p1%{8}%/%{6}%*%{3}%+\E[%d%p1%{8}%m%Pa
%?%ga%{1}%=
%t4
%e%ga%{3}%=
%t6
%e%ga%{4}%=
%t1
%e%ga%{6}%=
%t3
%e%ga%d
%;
m,
use=xterm+256color,
use=xterm-new,
Formatowanie dzieli rzeczy - skrypt lub program, aby zrobić to samo, musiałby podążać za tymi zwrotami akcji. Większość ludzi poddaje się i używa najłatwiejszych ciągów.
Funkcja 16 kolorów została zapożyczona z IBM aixterm, która mapuje 16 kodów dla każdego planu pierwszego i tła na dwa zakresy;
- na pierwszym planie na 30-37 i 90-97
- tło na 40-47 i 100-107
Prosty skrypt
#!/bin/sh
TERM=xterm-16color
export TERM
printf ' %12s %12s\n' Foreground Background
for n in $(seq 0 15)
do
F=$(tput setaf $n | cat -v)
B=$(tput setab $n | cat -v)
printf '%2d %12s %12s\n' $n "$F" "$B"
done
a dane wyjściowe pokazują, jak to działa:
Foreground Background
0 ^[[30m ^[[40m
1 ^[[31m ^[[41m
2 ^[[32m ^[[42m
3 ^[[33m ^[[43m
4 ^[[34m ^[[44m
5 ^[[35m ^[[45m
6 ^[[36m ^[[46m
7 ^[[37m ^[[47m
8 ^[[90m ^[[100m
9 ^[[91m ^[[101m
10 ^[[92m ^[[102m
11 ^[[93m ^[[103m
12 ^[[94m ^[[104m
13 ^[[95m ^[[105m
14 ^[[96m ^[[106m
15 ^[[97m ^[[107m
Liczby są podzielone, ponieważ aixterm używa zakresów 30–37 i 40–47, aby dopasować kolory ECMA-48 (znane również jako „ANSI”), i używa zakresu 90–107 dla kodów nie zdefiniowanych w standardzie.
Oto zrzut ekranu z użyciem Xterm TERM=xterm-16color
, gdzie możesz zobaczyć efekt.
Dalsza lektura:
printf
sekwencjami ucieczki ANSI, aletput
zawodzi (przynajmniej w moim pudełku).