blob: 9d71c4f6187561c6db3c5bc04ed571527bf208a8 [file] [log] [blame]
micky3879b9f5e72025-07-08 18:04:53 -04001#!/bin/sh
2##############################################################################
3# Copyright 2020 Thomas E. Dickey #
4# Copyright 2016 Free Software Foundation, Inc. #
5# #
6# Permission is hereby granted, free of charge, to any person obtaining a #
7# copy of this software and associated documentation files (the "Software"), #
8# to deal in the Software without restriction, including without limitation #
9# the rights to use, copy, modify, merge, publish, distribute, distribute #
10# with modifications, sublicense, and/or sell copies of the Software, and to #
11# permit persons to whom the Software is furnished to do so, subject to the #
12# following conditions: #
13# #
14# The above copyright notice and this permission notice shall be included in #
15# all copies or substantial portions of the Software. #
16# #
17# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR #
18# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, #
19# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL #
20# THE ABOVE COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER #
21# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING #
22# FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER #
23# DEALINGS IN THE SOFTWARE. #
24# #
25# Except as contained in this notice, the name(s) of the above copyright #
26# holders shall not be used in advertising or otherwise to promote the sale, #
27# use or other dealings in this Software without prior written #
28# authorization. #
29##############################################################################
30# $Id: tput-initc,v 1.6 2020/02/02 23:34:34 tom Exp $
31# Some of the ".dat" files in ncurses' test-directory give r/g/b numbers for
32# default palettes of xterm and Linux console. This script reads the numbers
33# and (assuming the same or compatible terminal) uses tput to (re)initialize
34# the palette using those numbers.
35
36failed() {
37 printf "?? $*\n" >&2
38 exit 1
39}
40
41usage() {
42 cat >&2 <<-EOF
43 usage: $0 [-r] [-s] [palette-data]
44
45 Use this script with a palette data-file to (re)initialize colors with
46 tput. This script assumes arrangements for 16-, 88- and 256-colors
47 like the xterm 88colors2.pl and 256colors2.pl scripts.
48
49 Options:
50 -r reverse palette
51 -s reverse system colors (first 16 if more than 16 colors)
52EOF
53 exit 1
54}
55
56opt_r=no
57opt_s=no
58
59while getopts "rs" option "$@"
60do
61 case $option in
62 (r)
63 opt_r=yes
64 ;;
65 (s)
66 opt_s=yes
67 ;;
68 (*)
69 usage
70 ;;
71 esac
72done
73shift $(expr $OPTIND - 1)
74
75if [ $# = 1 ]
76then
77 file=$1
78elif [ $# = 0 ]
79then
80 file=$TERM.dat
81else
82 failed "expected one parameter or none"
83fi
84
85if [ ! -f "$file" ]
86then
87 if [ -f "$file.dat" ]
88 then
89 file="$file.dat"
90 else
91 failed "no such file: $file"
92 fi
93fi
94
95myterm=${file%%.dat}
96colors=$(tput -T $myterm colors 2>/dev/null)
97if [ ${colors:-0} -le 0 ]
98then
99 myterm=${myterm%%-color}
100 colors=$(tput -T $myterm colors 2>/dev/null)
101fi
102if [ ${colors:-0} -le 0 ]
103then
104 failed "terminal $myterm does not support color"
105fi
106
107cat $file |\
108awk -v opt_r=$opt_r \
109 -v opt_s=$opt_s \
110 -v colors=$colors \
111 -v myterm=$myterm '
112BEGIN {
113 limit = 1000;
114 range = -1;
115 cramp = -1;
116 if ( colors == 88 ) {
117 cramp = 80;
118 } else if ( colors = 256 ) {
119 cramp = 232;
120 }
121}
122function scaled(n) {
123 return (n * 1000)/limit;
124}
125
126/^scale:[0-9]+/{
127 sub("^scale:","",$0);
128 limit = $0;
129}
130
131/^[0-9]+:/{
132 sub(":","",$1);
133 item = $1 + 0;
134 if (range < item) {
135 range = item;
136 }
137 params[$1] = sprintf ("%d %d %d", scaled($2),scaled($3),scaled($4));
138}
139END {
140 for (n = 0; n <= range; ++n) {
141 m = n;
142 if ( opt_r == "yes" ) {
143 if ( colors <= 16 ) {
144 m = range - n;
145 } else if ( ( opt_s == "yes" ) && ( n < 16 ) ) {
146 m = 15 - n;
147 } else if ( n >= cramp ) {
148 m = cramp + colors - 1 - n;
149 } else {
150 m = 16 + cramp - 1 - n;
151 }
152 }
153 printf "tput -T%s initc %d %s\n", myterm, m, params[n];
154 }
155}
156' |sh -