[comp.sources.d] using curses from a script?

pokey@well.UUCP (Jef Poskanzer) (11/17/88)

Has anyone written a tool to perform curses functions from a shell script?
Something like "curse so" to enter stand-out mode, or "curse cm 14 3" to
do cursor addressing.  If no one can point me to something like this, I'll
hack it up and post it.
---
Jef

             Jef Poskanzer   jef@rtsg.ee.lbl.gov   ...well!pokey
                           "The ideal brain tonic."

dls@mace.cc.purdue.edu (David L Stevens) (11/18/88)

	This is something I wrote a few years ago that does most termcap
things. We have newer versions and a tgoto that need some work, but this
gives you most of what you want, I believe.

<<<<<<< begin term.c

/*
 * Copyright (c) 1986, David L Stevens.
 * Distribution unlimited, with inclusion of this copyright notice.
 */

#include <stdio.h>

char *scap[] =
{
"ae", "al", "as", "bc", "bt", "CC", "cd", "ce", "ch", "cl", "cm", "cr", "cs",
"cv", "dc", "dl", "dm", "do", "ed", "ei", "eo", "ff", "hd", "ho", "hu", "hz",
"ic", "if", "ip", "is", "kb", "kd", "ke", "kh", "kl", "ko", "kr", "ks", "ku",
"ll", "ma", "ml", "mu", "nd", "nl", "pc", "se", "sf", "so", "sr", "ta", "tc",
"te", "ti", "uc", "ue", "up", "us", "vb", "ve", "vs", 0 };

char *ncap[] =
{
"co", "db", "dc", "df", "dn", "dt", "kn", "li", "ug", 0 };

char *fcap[] =
{
"am", "bw", "da", "db", "hc", "im", "in", "ms", "nc", "ns", "os", "pt", "ul",
"xb", "xn", "xr", "xs", "xt", 0 };

#define IsFlag(s)	IsCap(s, fcap)
#define IsNumber(s)	IsCap(s, ncap)
#define IsString(s)	IsCap(s, scap)


main(argc, argv)
int argc;
char *argv[];
{
	char tbuf[1024], buf[1024], *bp = buf;
	char *term;
	int an, rv;
	char *sv, *getenv(), *tgetstr();
	int eflag;

	term = getenv("TERM");
	if (term == NULL) {
		fprintf(stderr, "term: Terminal type not specified.\n");
		exit(1);
	}

	rv = tgetent(&tbuf[0], term);
	switch (rv) {
	case -1:
		fprintf(stderr, "term: Can't open termcap.\n");
		exit(1);
	case  0:
		fprintf(stderr, "term: no termcap entry for \"%s\"\n", term);
		exit(1);
	case  1:
		break;
	default:
		fprintf(stderr, "term: termcap error-- tgetent returned %d\n",
			rv);
		exit(1);
	}

	eflag = 0;
	for (an = 1; an < argc; an++) {
		char *stmp;

		stmp = argv[an];

		if (IsString(stmp)) {
			sv = tgetstr(stmp, &bp);
			if (sv == NULL) {
				fprintf(stderr, "term: No \"%s\" defined for %s\n",
					stmp, term);
				eflag++;
				continue;
			}
			fprintf(stdout, "%s", sv);
		} else if (IsNumber(stmp)) {
			rv = tgetnum(stmp);
			if (rv == -1) {
				fprintf(stderr, "term: No \"%s\" defined for %s\n",
					stmp, term);
				eflag++;
				continue;
			}
			fprintf(stdout, "%d", rv);
		} else if (IsFlag(stmp)) {
			fprintf(stdout, "%d", tgetflag(stmp));
		} else {
			fprintf(stderr, "term: Unknown capability, \"%s\"\n",
				stmp);
			eflag++;
			continue;
		}
	}
	exit(eflag != 0);
}


IsCap(s, cap)
char *s;
char *cap[];
{
	char **tc;

	tc = &cap[0];
	while (*tc != 0) {
		if (strcmp(*tc, s) == 0) {
			return 1;
		}
		tc++;
	}
	return 0;
}
>>>>>>> end term.c
-- 
					+-DLS  (dls@mace.cc.purdue.edu)

ok@quintus.uucp (Richard A. O'Keefe) (11/18/88)

In article <7668@well.UUCP> Jef Poskanzer <jef@rtsg.ee.lbl.gov> writes:
>Has anyone written a tool to perform curses functions from a shell script?

System V has a command "tput [-T<termtype>] <capability>".
This doesn't, strictly speaking, perform _Curses_ functions, but sends
strings from the terminfo data-base.  (Since Curses relies on keeping
copies of window contents in memory, it is not clear that you _can_ do
Curses things without having a single process to do it.  You could try
creating a "curses server" which would create a named pipe and listen
for commands on it:
	curses=`make_pipe_and_fork_curses`
	...
	echo setscrreg 10 20 >$curses
Not for the faint of heart.)

rsalz@bbn.com (Rich Salz) (11/19/88)

>In article <7668@well.UUCP> Jef Poskanzer <jef@rtsg.ee.lbl.gov> writes:
>Has anyone written a tool to perform curses functions from a shell script?

In <700@quintus.UUCP> ok@quintus.UUCP (Richard A. O'Keefe) writes:
>System V has a command "tput [-T<termtype>] <capability>".
>This doesn't, strictly speaking, perform _Curses_ functions, but sends
>strings from the terminfo data-base.  (Since Curses relies on keeping
>copies of window contents in memory, it is not clear that you _can_ do
>Curses things without having a single process to do it.  You could try
>creating a "curses server" which would create a named pipe and listen
>for commands on it:
>	curses=`make_pipe_and_fork_curses`
>	...
>	echo setscrreg 10 20 >$curses
>Not for the faint of heart.)

I sent this on to Jef, as I think it's what he wants.

The idea of writing a Curses package to be used inside shell-scripts
is pretty mind-blowing, I can just see it now:
	/usr/curses/initscr
	/usr/curses/endwin
	/usr/curses/mvprintw
	...

Subject:  v07i072:  Public-domain TPUT (corrected implementation)
Newsgroups: mod.sources
Approved: mirror!rs

Submitted by: seismo!rochester!ur-valhalla!badri (Badri Lokanathan)
Mod.sources: Volume 7, Issue 72
Archive-name: tput2

After a lot of discussion with Mark Horton, I decided to make
modifications to the format of tput so that it would be compatible with
sys V shell scripts (my previous version unfortunately was not.) I am
reposting the source so that you can either redistribute it or just
archive it.

Sorry for all the confusion.
Badri Lokanathan
------------------------------------------
#! /bin/sh
# This is a shell archive, meaning:
# 1. Remove everything above the #! /bin/sh line.
# 2. Save the resulting text in a file.
# 3. Execute the file with /bin/sh (not csh) to create:
#	README
#	Makefile
#	tput.1
#	tput.h
#	tput.c
export PATH; PATH=/bin:/usr/bin:$PATH
if test -f 'README'
then
	echo shar: "will not over-write existing file 'README'"
else
cat << \xxTPUTxx > 'README'
From: rochester!ur-valhalla!badri Sep 19 17:31:33 EDT 1986
To: whom it may concern
Subject: Public domain tput release 2

This revision has undergone major changes after the first one, mainly
because the first release was not compatible with SV tput.
New features are:

(1) Totally different capability naming conventions from first
    release, but equivalent to SV conventions.

(2) Error messages are properly reported.

(3) Can be used to query for properties of other terminals also.

Problems still not properly handled:
Limited features: Handles almost all termcap features, but is still
only a subset of the latest version tput because terminfo has not been used.
On the other hand if terminfo was available, most probably tput would
be too!

Thanks to Mark Horton @ cbosgd for suggestions.
Badri Lokanathan
--------------------------------------------------------------------------------
From: rochester!ur-valhalla!badri  Aug 28 10:02
To: whom it may concern
Subject: tput instructions

This program is supposed to be equivalent to the system V utility
tput, which handles screen parameters from termcap. It may take inputs
in a slightly different format (basically because I wrote this program
without actually having worked on tput.) Any suggestions/modifications
are welcome.

Your system is assumed to have termlib and associated functions (I
wrote the program on BSD 4.2, assuming that termlib was fairly
standard.) There is one include file in the program - sgtty.h which
should be present. If not, I hope an equivalent exists.
Other than that, the code should be fairly portable.

The make file is delibrately trivial. It does not do any installation
- just compilation.

make

will make tput in the current directory.

make man

will make a man page in tput.doc.


tput, written by Badri Lokanathan, is in the public domain, and may be
used by any person or organization, in any way and for any purpose.
There is no warranty of merchantability nor any warranty of fitness for
a particular purpose nor any other warranty, either express or implied,
as to the accuracy of the enclosed materials or as to their suitability
for any particular purpose.  Accordingly, the author assumes no respon-
sibility for their use by the recipient.   Further, the author assumes
no obligation to furnish any assistance of any kind whatsoever, or to
furnish any additional information or documentation.
xxTPUTxx
fi
if test -f 'Makefile'
then
	echo shar: "will not over-write existing file 'Makefile'"
else
cat << \xxTPUTxx > 'Makefile'
tput: tput.c tput.h
	cc -o tput tput.c -ltermlib

man: tput.1
	nroff -man tput.1 > tput.doc

dtput: tput.c tput.h
	cc -g -o dtput tput.c -ltermlib

lint:
	lint -DLINT tput.c
xxTPUTxx
fi
if test -f 'tput.1'
then
	echo shar: "will not over-write existing file 'tput.1'"
else
cat << \xxTPUTxx > 'tput.1'
.TH tput 1local "UR EE GRADUATE VLSI LAB"
.SH NAME
tput \- query termcap data base
.SH SYNOPSIS
.B  tput
[
\fB-T\fRtype
]
[
\fB-e\fR
]
capname
[
.I x
.I y
]
.SH DESCRIPTION
.ad
.I tput
uses the \fItermcap(5)\fR data base to make terminal-dependent
capabilities and information available to the shell. \fITput\fR outputs
a string if the attribute (\fBcap\fRability \fBname\fR) is of type
string, or an integer if the attribute is of type integer. If the
attribute is of type Boolean, tput simply sets the exit code (0 for
TRUE, 1 for FALSE) and does no output.
.sp 1
.ta 1i
.fc #
#\fB-T\fRtype#indicates the type of terminal. Normally this flag
.br
##is unnecessary, as the default is taken from the
.br
##environment variable \fB$TERM.\fR
.br
#\fB-e\fR#suppresses the printing of error messages. In case
.br
##an error occurs, an error code is returned with or
.br
##without this flag.
.br
#Capname#indicates the attribute (mapping to an attribute
.br
##from the \f\Itermcap\f\R database.)
.sp 1
x and y are integer values for cursor movement.
.sp 1
Typical capname options are given below.
.SH REQUESTS
.in 0
.ll 8i
.ta .75i 1.5i 2.5i 
.B Option\tType\tTermcap\tExplanation
.br
am	bool	am	Terminal has automatic margins
.br
bw	bool	bw	cub1 wraps from column 0 to last column
.br
chts	bool	HC	Cursor is hard to see.
.br
da	bool	da	Display may be retained above the screen
.br
db	bool	db	Display may be retained below the screen
.br
eo	bool	eo	Can erase overstrikes with a blank
.br
eslok	bool	es	Escape can be used on the status line
.br
gn	bool	gn	Generic line type (e.g. dialup, switch).
.br
hc	bool	hc	Hardcopy terminal
.br
hs	bool	hs	Has extra "status line"
.br
hz	bool	hz	Hazeltine; can't print ~'s
.br
in	bool	in	Insert mode distinguishes nulls
.br
km	bool	km	Has a meta key (shift, sets parity bit)
.br
mc5i	bool	5i	Printer won't echo on screen.
.br
mir	bool	mi	Safe to move while in insert mode
.br
msgr	bool	ms	Safe to move in standout modes
.br
npc	bool	NP	Pad character doesn't exist.
.br
nrrmc	bool	NR	Smcup does not reverse rmcup.
.br
nxon	bool	nx	Padding won't work, xon/xoff required
.br
os	bool	os	Terminal overstrikes
.br
ul	bool	ul	underline character overstrikes
.br
xenl	bool	xn	newline ignored after 80 cols (Concept)
.br
xhp	bool	xs	Standout not erased by overwriting (hp)
.br
xon	bool	xo	Terminal uses xon/xoff handshaking
.br
xsb	bool	xb	Beehive (f1=escape, f2=ctrl C)
.br
xt	bool	xt	Tabs destructive, magic so char (t1061)
.br
cols	num	co	Number of columns in a line
.br
it	num	it	Tabs initially every \# spaces.
.br
lh	num	lh	\# rows in each label
.br
lines	num	li	Number of lines on screen or page
.br
lm	num	lm	Lines of memory if > lines.  0 => varies
.br
lw	num	lw	\# cols in each label
.br
nlab	num	Nl	\# of labels on screen (start at 1)
.br
pb	num	pb	Lowest baud rate where padding needed
.br
vt	num	vt	Virtual terminal number (CB/Unix)
.br
wsl	num	ws	\# columns in status line
.br
xmc	num	sg	Number blank chars left by smso or rmso
.br
acsc	str	ac	Graphic charset pairs aAbBcC - def=vt100
.br
bel	str	bl	Audible signal (bell)
.br
blink	str	mb	Turn on blinking
.br
bold	str	md	Turn on bold (extra bright) mode
.br
cbt	str	bt	Back tab
.br
civis	str	vi	Make cursor invisible
.br
clear	str	cl	Clear screen (*)
.br
cmdch	str	CC	Term. settable cmd char in prototype
.br
cnorm	str	ve	Make cursor appear normal (undo vs/vi)
.br
cr	str	cr	Carriage return (*)
.br
csr	str	cs	change to lines \#1 thru \#2 (vt100) (G)
.br
cub	str	LE	Move cursor left \#1 spaces (G)
.br
cub1	str	le	Move cursor left one space.
.br
cud	str	DO	Move cursor down \#1 lines. (G*)
.br
cud1	str	do	Down one line
.br
cuf	str	RI	Move cursor right \#1 spaces. (G*)
.br
cuf1	str	nd	Non-destructive space (cursor right)
.br
cup	str	cm	Cursor motion to row \#1 col \#2 (G)
.br
cuu	str	UP	Move cursor up \#1 lines. (G*)
.br
cuu1	str	up	Upline (cursor up)
.br
cvvis	str	vs	Make cursor very visible
.br
dch	str	DC	Delete \#1 chars (G*)
.br
dch1	str	dc	Delete character (*)
.br
dim	str	mh	Turn on half-bright mode
.br
dl	str	DL	Delete \#1 lines (G*)
.br
dl1	str	dl	Delete line (*)
.br
dsl	str	ds	Disable status line
.br
ech	str	ec	Erase \#1 characters (G)
.br
ed	str	cd	Clear to end of display (*)
.br
el	str	ce	Clear to end of line
.br
el1	str	cb	Clear to beginning of line, inclusive
.br
enacs	str	eA	Enable alternate char set
.br
ff	str	ff	Hardcopy terminal page eject (*)
.br
flash	str	vb	Visible bell (may not move cursor)
.br
fsl	str	fs	Return from status line
.br
hd	str	hd	Half-line down (forward 1/2 linefeed)
.br
home	str	ho	Home cursor (if no cup)
.br
hpa	str	ch	Set cursor column (G)
.br
ht	str	ta	Tab to next 8 space hardware tab stop.
.br
hts	str	st	Set a tab in all rows, current column.
.br
hu	str	hu	Half-line up (reverse 1/2 linefeed)
.br
ich	str	IC	Insert \#1 blank chars (G*)
.br
ich1	str	ic	Insert character
.br
if	str	if	Name of file containing is
.br
il	str	AL	Add \#1 new blank lines (G*)
.br
il1	str	al	Add new blank line (*)
.br
ind	str	sf	Scroll text up
.br
indn	str	SF	Scroll forward \#1 lines. (G)
.br
invis	str	mk	Turn on blank mode (chars invisible)
.br
ip	str	ip	Insert pad after character inserted (*)
.br
iprog	str	iP	Path name of program for init.
.br
is1	str	i1	Terminal initialization string
.br
is2	str	is	Terminal initialization string
.br
is3	str	i3	Terminal initialization string
.br
kBEG	str	&9	KEY_SBEG, 0572, shifted beginning key
.br
kCAN	str	&0	KEY_SCANCEL, 0573, shifted cancel key
.br
kCMD	str	*1	KEY_SCOMMAND, 0574, shifted command key
.br
kCPY	str	*2	KEY_SCOPY, 0575, shifted copy key
.br
kCRT	str	*3	KEY_SCREATE, 0576, shifted create key
.br
kDC	str	*4	KEY_SDC, 0577, shifted delete char key
.br
kDL	str	*5	KEY_SDL, 0600, shifted delete line key
.br
kEND	str	*7	KEY_SEND, 0602, shifted end key
.br
kEOL	str	*8	KEY_SEOL, 0603, shifted clear line key
.br
kEXT	str	*9	KEY_SEXIT, 0604, shifted exit key
.br
kFND	str	*0	KEY_SFIND, 0605, shifted find key
.br
kHLP	str	\#1	KEY_SHELP, 0606, shifted help key
.br
kHOM	str	\#2	KEY_SHOME, 0607, shifted home key
.br
kIC	str	\#3	KEY_SIC, 0610, shifted input key
.br
kLFT	str	\#4	KEY_SLEFT, 0611, shifted left arrow key
.br
kMOV	str	%b	KEY_SMOVE, 0613, shifted move key
.br
kMSG	str	%a	KEY_SMESSAGE, 0612, shifted message key
.br
kNXT	str	%c	KEY_SNEXT, 0614, shifted next key
.br
kOPT	str	%d	KEY_SOPTIONS, 0615, shifted options key
.br
kPRT	str	%f	KEY_SPRINT, 0617, shifted print key
.br
kPRV	str	%e	KEY_SPREVIOUS, 0616, shifted prev key
.br
kRDO	str	%g	KEY_SREDO, 0620, shifted redo key
.br
kRES	str	%j	KEY_SRSUME, 0623, shifted resume key
.br
kRIT	str	%i	KEY_SRIGHT, 0622, shifted right arrow
.br
kRPL	str	%h	KEY_SREPLACE, 0621, shifted replace key
.br
kSAV	str	!1	KEY_SSAVE, 0624, shifted save key
.br
kSPD	str	!2	KEY_SSUSPEND, 0625, shifted suspend key
.br
kUND	str	!3	KEY_SUNDO, 0626, shifted undo key
.br
ka1	str	K1	KEY_A1, 0534, Upper left of keypad
.br
ka3	str	K3	KEY_A3, 0535, Upper right of keypad
.br
kb2	str	K2	KEY_B2, 0536, Center of keypad
.br
kbeg	str	@1	KEY_BEG, 0542, beg(inning) key
.br
kbs	str	kb	KEY_BACKSPACE, 0407, Sent by backspace key
.br
kc1	str	K4	KEY_C1, 0537, Lower left of keypad
.br
kc3	str	K5	KEY_C3, 0540, Lower right of keypad
.br
kcan	str	@2	KEY_CANCEL, 0543, cancel key
.br
kcbt	str	kB	KEY_BTAB, 0541, Back tab key
.br
kclo	str	@3	KEY_CLOSE, 0544, close key
.br
kclr	str	kC	KEY_CLEAR, 0515, Sent by clear screen or erase key.
.br
kcmd	str	@4	KEY_COMMAND, 0545, cmd (command) key
.br
kcpy	str	@5	KEY_COPY, 0546, copy key
.br
kcrt	str	@6	KEY_CREATE, 0547, create key
.br
kctab	str	kt	KEY_CTAB, 0525, Sent by clear-tab key
.br
kcub1	str	kl	KEY_LEFT, 0404, Sent by terminal left arrow key
.br
kcud1	str	kd	KEY_DOWN, 0402, Sent by terminal down arrow key
.br
kcuf1	str	kr	KEY_RIGHT, 0405, Sent by terminal right arrow key
.br
kcuu1	str	ku	KEY_UP, 0403, Sent by terminal up arrow key
.br
kdch1	str	kD	KEY_DC, 0512, Sent by delete character key.
.br
kdl1	str	kL	KEY_DL, 0510, Sent by delete line key.
.br
ked	str	kS	KEY_EOS, 0516, Sent by clear-to-end-of-screen key.
.br
kel	str	kE	KEY_EOL, 0517, Sent by clear-to-end-of-line key.
.br
kend	str	@7	KEY_END, 0550, end key
.br
kent	str	@8	KEY_ENTER, 0527, Enter/send (unreliable)
.br
kext	str	@9	KEY_EXIT, 0551, exit key
.br
kf0	str	k0	KEY_F(0), 0410, function key f0.
.br
kf1	str	k1	KEY_F(1), 0411, function key f1.
.br
kf10	str	k;	KEY_F(10), 0422, function key f10.
.br
kf11	str	F1	KEY_F(11), 0423, function key f11.
.br
kf12	str	F2	KEY_F(12), 0424, function key f12.
.br
kf13	str	F3	KEY_F(13), 0425, function key f13.
.br
kf14	str	F4	KEY_F(14), 0426, function key f14.
.br
kf15	str	F5	KEY_F(15), 0427, function key f15.
.br
kf16	str	F6	KEY_F(16), 0430, function key f16.
.br
kf17	str	F7	KEY_F(17), 0431, function key f17.
.br
kf18	str	F8	KEY_F(18), 0432, function key f18.
.br
kf19	str	F9	KEY_F(19), 0433, function key f19.
.br
kf2	str	k2	KEY_F(2), 0412, function key f2.
.br
kf20	str	FA	KEY_F(20), 0434, function key f20.
.br
kf21	str	FB	KEY_F(21), 0435, function key f21.
.br
kf22	str	FC	KEY_F(22), 0436, function key f22.
.br
kf23	str	FD	KEY_F(23), 0437, function key f23.
.br
kf24	str	FE	KEY_F(24), 0440, function key f24.
.br
kf25	str	FF	KEY_F(25), 0441, function key f25.
.br
kf26	str	FG	KEY_F(26), 0442, function key f26.
.br
kf27	str	FH	KEY_F(27), 0443, function key f27.
.br
kf28	str	FI	KEY_F(28), 0444, function key f28.
.br
kf29	str	FJ	KEY_F(29), 0445, function key f29.
.br
kf3	str	k3	KEY_F(3), 0413, function key f3.
.br
kf30	str	FK	KEY_F(30), 0446, function key f30.
.br
kf31	str	FL	KEY_F(31), 0447, function key f31.
.br
kf32	str	FM	KEY_F(32), 0450, function key f32.
.br
kf33	str	FN	KEY_F(13), 0451, function key f13.
.br
kf34	str	FO	KEY_F(34), 0452, function key f34.
.br
kf35	str	FP	KEY_F(35), 0453, function key f35.
.br
kf36	str	FQ	KEY_F(36), 0454, function key f36.
.br
kf37	str	FR	KEY_F(37), 0455, function key f37.
.br
kf38	str	FS	KEY_F(38), 0456, function key f38.
.br
kf39	str	FT	KEY_F(39), 0457, function key f39.
.br
kf4	str	k4	KEY_F(4), 0414, function key f4.
.br
kf40	str	FU	KEY_F(40), 0460, function key f40.
.br
kf41	str	FV	KEY_F(41), 0461, function key f41.
.br
kf42	str	FW	KEY_F(42), 0462, function key f42.
.br
kf43	str	FX	KEY_F(43), 0463, function key f43.
.br
kf44	str	FY	KEY_F(44), 0464, function key f44.
.br
kf45	str	FZ	KEY_F(45), 0465, function key f45.
.br
kf46	str	Fa	KEY_F(46), 0466, function key f46.
.br
kf47	str	Fb	KEY_F(47), 0467, function key f47.
.br
kf48	str	Fc	KEY_F(48), 0470, function key f48.
.br
kf49	str	Fd	KEY_F(49), 0471, function key f49.
.br
kf5	str	k5	KEY_F(5), 0415, function key f5.
.br
kf50	str	Fe	KEY_F(50), 0472, function key f50.
.br
kf51	str	Ff	KEY_F(51), 0473, function key f51.
.br
kf52	str	Fg	KEY_F(52), 0474, function key f52.
.br
kf53	str	Fh	KEY_F(53), 0475, function key f53.
.br
kf54	str	Fi	KEY_F(54), 0476, function key f54.
.br
kf55	str	Fj	KEY_F(55), 0477, function key f55.
.br
kf56	str	Fk	KEY_F(56), 0500, function key f56.
.br
kf57	str	Fl	KEY_F(57), 0501, function key f57.
.br
kf58	str	Fm	KEY_F(58), 0502, function key f58.
.br
kf59	str	Fn	KEY_F(59), 0503, function key f59.
.br
kf6	str	k6	KEY_F(6), 0416, function key f6.
.br
kf60	str	Fo	KEY_F(60), 0504, function key f60.
.br
kf61	str	Fp	KEY_F(61), 0505, function key f61.
.br
kf62	str	Fq	KEY_F(62), 0506, function key f62.
.br
kf63	str	Fr	KEY_F(63), 0507, function key f63.
.br
kf7	str	k7	KEY_F(7), 0417, function key f7.
.br
kf8	str	k8	KEY_F(8), 0420, function key f8.
.br
kf9	str	k9	KEY_F(9), 0421, function key f9.
.br
kfnd	str	@0	KEY_FIND, 0552, find key
.br
khlp	str	%1	KEY_HELP, 0553, help key
.br
khome	str	kh	KEY_HOME, 0406, Sent by home key.
.br
khts	str	kT	KEY_STAB, 0524, Sent by set-tab key
.br
kich1	str	kI	KEY_IC, 0513, Sent by ins char/enter ins mode key.
.br
kil1	str	kA	KEY_IL, 0511, Sent by insert line.
.br
kind	str	kF	KEY_SF, 0520, Sent by scroll-forward/down key
.br
kll	str	kH	KEY_LL, 0533, Sent by home-down key
.br
kmov	str	%4	KEY_MOVE, 0556, move key
.br
kmrk	str	%2	KEY_MARK, 0554, mark key
.br
kmsg	str	%3	KEY_MESSAGE, 0555, message key
.br
knp	str	kN	KEY_NPAGE, 0522, Sent by next-page key
.br
knxt	str	%5	KEY_NEXT, 0557, next object key
.br
kopn	str	%6	KEY_OPEN, 0560, open key
.br
kopt	str	%7	KEY_OPTIONS, 0561, options key
.br
kpp	str	kP	KEY_PPAGE, 0523, Sent by previous-page key
.br
kprt	str	%9	KEY_PRINT, 0532, print or copy
.br
kprv	str	%8	KEY_PREVIOUS, 0562, previous object key
.br
krdo	str	%0	KEY_REDO, 0563, redo key
.br
kref	str	&1	KEY_REFERENCE, 0564, ref(erence) key
.br
kres	str	&5	KEY_RESUME, 0570, resume key
.br
krfr	str	&2	KEY_REFRESH, 0565, refresh key
.br
kri	str	kR	KEY_SR, 0521, Sent by scroll-backward/up key
.br
krmir	str	kM	KEY_EIC, 0514, Sent by rmir or smir in insert mode.
.br
krpl	str	&3	KEY_REPLACE, 0566, replace key
.br
krst	str	&4	KEY_RESTART, 0567, restart key
.br
ksav	str	&6	KEY_SAVE, 0571, save key
.br
kslt	str	*6	KEY_SELECT, 0601, select key
.br
kspd	str	&7	KEY_SUSPEND, 0627, suspend key
.br
ktbc	str	ka	KEY_CATAB, 0526, Sent by clear-all-tabs key.
.br
kund	str	&8	KEY_UNDO, 0630, undo key
.br
lf0	str	l0	Labels on function key f0 if not f0
.br
lf1	str	l1	Labels on function key f1 if not f1
.br
lf10	str	la	Labels on function key f10 if not f10
.br
lf2	str	l2	Labels on function key f2 if not f2
.br
lf3	str	l3	Labels on function key f3 if not f3
.br
lf4	str	l4	Labels on function key f4 if not f4
.br
lf5	str	l5	Labels on function key f5 if not f5
.br
lf6	str	l6	Labels on function key f6 if not f6
.br
lf7	str	l7	Labels on function key f7 if not f7
.br
lf8	str	l8	Labels on function key f8 if not f8
.br
lf9	str	l9	Labels on function key f9 if not f9
.br
ll	str	ll	Last line, first column (if no cup)
.br
mc0	str	ps	Print contents of the screen
.br
mc4	str	pf	Turn off the printer
.br
mc5	str	po	Turn on the printer
.br
mc5p	str	pO	Turn on the printer for \#1 bytes.
.br
mgc	str	MC	Clear left and right soft margins
.br
mrcup	str	CM	Memory relative cursor addressing.
.br
nel	str	nw	Newline (behaves like cr followed by lf)
.br
pad	str	pc	Pad character (rather than null)
.br
pfkey	str	pk	Prog funct key \#1 to type string \#2
.br
pfloc	str	pl	Prog funct key \#1 to execute string \#2
.br
pfx	str	px	Prog funct key \#1 to xmit string \#2
.br
pln	str	pn	Prog label \#1 to show string \#2
.br
prot	str	mp	Turn on protected mode
.br
rc	str	rc	Restore cursor to position of last sc.
.br
rep	str	rp	Repeat char \#1 \#2 times.  (G*)
.br
rev	str	mr	Turn on reverse video mode
.br
rf	str	rf	Name of file containing reset string.
.br
rfi	str	RF	send next input char (for ptys)
.br
ri	str	sr	Scroll text down
.br
rin	str	SR	Scroll backward \#1 lines. (G)
.br
rmacs	str	ae	End alternate character set
.br
rmam	str	RA	Turn off automatic margins
.br
rmcup	str	te	String to end programs that use cup
.br
rmdc	str	ed	End delete mode
.br
rmir	str	ei	End insert mode;
.br
rmkx	str	ke	Out of "keypad transmit" mode
.br
rmln	str	LF	Turn off soft labels
.br
rmm	str	mo	Turn off "meta mode"
.br
rmp	str	rP	Like ip but when in replace mode
.br
rmso	str	se	End stand out mode
.br
rmul	str	ue	End underscore mode
.br
rmxon	str	RX	Turn off xon/xoff handshaking
.br
rs1	str	r1	Reset terminal completely to sane modes.
.br
rs2	str	r2	Reset terminal completely to sane modes.
.br
rs3	str	r3	Reset terminal completely to sane modes.
.br
sc	str	sc	Save cursor position.
.br
sgr	str	sa	Define the video attributes (G9)
.br
sgr0	str	me	Turn off all attributes
.br
smacs	str	as	Start alternate character set
.br
smam	str	SA	Turn on automatic margins
.br
smcup	str	ti	String to begin programs that use cup
.br
smdc	str	dm	Delete mode (enter)
.br
smgl	str	ML	Set soft left margin
.br
smgr	str	MR	Set soft right margin
.br
smir	str	im	Insert mode (enter);
.br
smkx	str	ks	Put terminal in "keypad transmit" mode
.br
smln	str	LO	Turn on soft labels
.br
smm	str	mm	Turn on "meta mode" (8th bit)
.br
smso	str	so	Begin stand out mode
.br
smul	str	us	Start underscore mode
.br
smxon	str	SX	Turn on xon/xoff handshaking
.br
tbc	str	ct	Clear all tab stops.
.br
tsl	str	ts	Go to status line, col \#1
.br
uc	str	uc	Underscore one char and move past it
.br
vpa	str	cv	Like hpa but sets row. (G)
.br
wind	str	wi	Current window is lines \#1-\#2 cols \#3-\#4
.br
xoffc	str	XF	X-off character
.br
xonc	str	XN	X-on character
.br
.ad
.ll 6.5i
.in .5i
.SH FILES
/etc/termcap
.SH SEE ALSO
termcap(3X), termcap(5)
.SH DIAGNOSTICS
Tput prints error messages (unless suppressed using -e) and returns
the following error codes on error:
.br
#-1#Usage error.
.br
#-2#Bad terminal type.
.br
#-3#Bad capname.
.sp 1
.SH BUGS
Complex capnames with many auxiliary parameters (such as sgr) do
not work properly because curses has not been used - this program
is based entirely on termcap (and that too from BSD4.2 manuals!)
.PP
-n option does not work for most capnames, so it has not been
mentioned in this page.
xxTPUTxx
fi
if test -f 'tput.h'
then
	echo shar: "will not over-write existing file 'tput.h'"
else
cat << \xxTPUTxx > 'tput.h'
/*
 * Copyright (C) $Date: 86/09/19 17:01:07 $
 * by $Author: badri $
 * University of Rochester,
 * Department of Electrical Engineering.
 *
 * CoNtEnTs   This file contains various definitions for tput.
 *
 * $Locker:  $
 * $Source: /u/users/badri/usr/src/local/tput/RCS/tput.h,v $
 * $Revision: 1.2 $
 *
 * History of this release:
 * $Log:	tput.h,v $
 * Revision 1.2  86/09/19  17:01:07  badri
 * Did some rearranging of things. Also incorporated error messages.
 * 
 * Revision 1.1  86/09/18  15:48:24  badri
 * Initial revision
 * 
 */
#include <sgtty.h>
#include <stdio.h>

#ifndef XTABS
#define XTABS 0006000
#endif  XTABS

#define LARGEBUF 1024
#define SMALLBUF   64

#define SYSTEM    666
#define FAILURE     1
#define SUCCESS     0
#define BADUSE     -1
#define BADTERM    -2
#define BADCAP     -3
/*
 * To add new capabilities, increment table size and define the
 * capability in the appropriate slot in the structure. Note that 
 * the capabilities are lexicographically ordered. This ordering
 * must be maintained for the binary search to work.
 * Format for entry is 
 * {"capability", "termcap_key"},
 */
#define TABLESIZE 310
struct {char *key, *value} table[TABLESIZE] = {
	{"acsc", "ac"},
	{"am", "am"},
	{"bel", "bl"},
	{"blink", "mb"},
	{"bold", "md"},
	{"bw", "bw"},
	{"cbt", "bt"},
	{"chts", "HC"},
	{"civis", "vi"},
	{"clear", "cl"},
	{"cmdch", "CC"},
	{"cnorm", "ve"},
	{"cols", "co"},
	{"cr", "cr"},
	{"csr", "cs"},
	{"cub", "LE"},
	{"cub1", "le"},
	{"cud", "DO"},
	{"cud1", "do"},
	{"cuf", "RI"},
	{"cuf1", "nd"},
	{"cup", "cm"},
	{"cuu", "UP"},
	{"cuu1", "up"},
	{"cvvis", "vs"},
	{"da", "da"},
	{"db", "db"},
	{"dch", "DC"},
	{"dch1", "dc"},
	{"dim", "mh"},
	{"dl", "DL"},
	{"dl1", "dl"},
	{"dsl", "ds"},
	{"ech", "ec"},
	{"ed", "cd"},
	{"el", "ce"},
	{"el1", "cb"},
	{"enacs", "eA"},
	{"eo", "eo"},
	{"eslok", "es"},
	{"ff", "ff"},
	{"flash", "vb"},
	{"fsl", "fs"},
	{"gn", "gn"},
	{"hc", "hc"},
	{"hd", "hd"},
	{"home", "ho"},
	{"hpa", "ch"},
	{"hs", "hs"},
	{"ht", "ta"},
	{"hts", "st"},
	{"hu", "hu"},
	{"hz", "hz"},
	{"ich", "IC"},
	{"ich1", "ic"},
	{"if", "if"},
	{"il", "AL"},
	{"il1", "al"},
	{"in", "in"},
	{"ind", "sf"},
	{"indn", "SF"},
	{"invis", "mk"},
	{"ip", "ip"},
	{"iprog", "iP"},
	{"is1", "i1"},
	{"is2", "is"},
	{"is3", "i3"},
	{"it", "it"},
	{"kBEG", "&9"},
	{"kCAN", "&0"},
	{"kCMD", "*1"},
	{"kCPY", "*2"},
	{"kCRT", "*3"},
	{"kDC", "*4"},
	{"kDL", "*5"},
	{"kEND", "*7"},
	{"kEOL", "*8"},
	{"kEXT", "*9"},
	{"kFND", "*0"},
	{"kHLP", "#1"},
	{"kHOM", "#2"},
	{"kIC", "#3"},
	{"kLFT", "#4"},
	{"kMOV", "%b"},
	{"kMSG", "%a"},
	{"kNXT", "%c"},
	{"kOPT", "%d"},
	{"kPRT", "%f"},
	{"kPRV", "%e"},
	{"kRDO", "%g"},
	{"kRES", "%j"},
	{"kRIT", "%i"},
	{"kRPL", "%h"},
	{"kSAV", "!1"},
	{"kSPD", "!2"},
	{"kUND", "!3"},
	{"ka1", "K1"},
	{"ka3", "K3"},
	{"kb2", "K2"},
	{"kbeg", "@1"},
	{"kbs", "kb"},
	{"kc1", "K4"},
	{"kc3", "K5"},
	{"kcan", "@2"},
	{"kcbt", "kB"},
	{"kclo", "@3"},
	{"kclr", "kC"},
	{"kcmd", "@4"},
	{"kcpy", "@5"},
	{"kcrt", "@6"},
	{"kctab", "kt"},
	{"kcub1", "kl"},
	{"kcud1", "kd"},
	{"kcuf1", "kr"},
	{"kcuu1", "ku"},
	{"kdch1", "kD"},
	{"kdl1", "kL"},
	{"ked", "kS"},
	{"kel", "kE"},
	{"kend", "@7"},
	{"kent", "@8"},
	{"kext", "@9"},
	{"kf0", "k0"},
	{"kf1", "k1"},
	{"kf10", "k;"},
	{"kf11", "F1"},
	{"kf12", "F2"},
	{"kf13", "F3"},
	{"kf14", "F4"},
	{"kf15", "F5"},
	{"kf16", "F6"},
	{"kf17", "F7"},
	{"kf18", "F8"},
	{"kf19", "F9"},
	{"kf2", "k2"},
	{"kf20", "FA"},
	{"kf21", "FB"},
	{"kf22", "FC"},
	{"kf23", "FD"},
	{"kf24", "FE"},
	{"kf25", "FF"},
	{"kf26", "FG"},
	{"kf27", "FH"},
	{"kf28", "FI"},
	{"kf29", "FJ"},
	{"kf3", "k3"},
	{"kf30", "FK"},
	{"kf31", "FL"},
	{"kf32", "FM"},
	{"kf33", "FN"},
	{"kf34", "FO"},
	{"kf35", "FP"},
	{"kf36", "FQ"},
	{"kf37", "FR"},
	{"kf38", "FS"},
	{"kf39", "FT"},
	{"kf4", "k4"},
	{"kf40", "FU"},
	{"kf41", "FV"},
	{"kf42", "FW"},
	{"kf43", "FX"},
	{"kf44", "FY"},
	{"kf45", "FZ"},
	{"kf46", "Fa"},
	{"kf47", "Fb"},
	{"kf48", "Fc"},
	{"kf49", "Fd"},
	{"kf5", "k5"},
	{"kf50", "Fe"},
	{"kf51", "Ff"},
	{"kf52", "Fg"},
	{"kf53", "Fh"},
	{"kf54", "Fi"},
	{"kf55", "Fj"},
	{"kf56", "Fk"},
	{"kf57", "Fl"},
	{"kf58", "Fm"},
	{"kf59", "Fn"},
	{"kf6", "k6"},
	{"kf60", "Fo"},
	{"kf61", "Fp"},
	{"kf62", "Fq"},
	{"kf63", "Fr"},
	{"kf7", "k7"},
	{"kf8", "k8"},
	{"kf9", "k9"},
	{"kfnd", "@0"},
	{"khlp", "%1"},
	{"khome", "kh"},
	{"khts", "kT"},
	{"kich1", "kI"},
	{"kil1", "kA"},
	{"kind", "kF"},
	{"kll", "kH"},
	{"km", "km"},
	{"kmov", "%4"},
	{"kmrk", "%2"},
	{"kmsg", "%3"},
	{"knp", "kN"},
	{"knxt", "%5"},
	{"kopn", "%6"},
	{"kopt", "%7"},
	{"kpp", "kP"},
	{"kprt", "%9"},
	{"kprv", "%8"},
	{"krdo", "%0"},
	{"kref", "&1"},
	{"kres", "&5"},
	{"krfr", "&2"},
	{"kri", "kR"},
	{"krmir", "kM"},
	{"krpl", "&3"},
	{"krst", "&4"},
	{"ksav", "&6"},
	{"kslt", "*6"},
	{"kspd", "&7"},
	{"ktbc", "ka"},
	{"kund", "&8"},
	{"lf0", "l0"},
	{"lf1", "l1"},
	{"lf10", "la"},
	{"lf2", "l2"},
	{"lf3", "l3"},
	{"lf4", "l4"},
	{"lf5", "l5"},
	{"lf6", "l6"},
	{"lf7", "l7"},
	{"lf8", "l8"},
	{"lf9", "l9"},
	{"lh", "lh"},
	{"lines", "li"},
	{"ll", "ll"},
	{"lm", "lm"},
	{"lw", "lw"},
	{"mc0", "ps"},
	{"mc4", "pf"},
	{"mc5", "po"},
	{"mc5i", "5i"},
	{"mc5p", "pO"},
	{"mgc", "MC"},
	{"mir", "mi"},
	{"mrcup", "CM"},
	{"msgr", "ms"},
	{"nel", "nw"},
	{"nlab", "Nl"},
	{"npc", "NP"},
	{"nrrmc", "NR"},
	{"nxon", "nx"},
	{"os", "os"},
	{"pad", "pc"},
	{"pb", "pb"},
	{"pfkey", "pk"},
	{"pfloc", "pl"},
	{"pfx", "px"},
	{"pln", "pn"},
	{"prot", "mp"},
	{"rc", "rc"},
	{"rep", "rp"},
	{"rev", "mr"},
	{"rf", "rf"},
	{"rfi", "RF"},
	{"ri", "sr"},
	{"rin", "SR"},
	{"rmacs", "ae"},
	{"rmam", "RA"},
	{"rmcup", "te"},
	{"rmdc", "ed"},
	{"rmir", "ei"},
	{"rmkx", "ke"},
	{"rmln", "LF"},
	{"rmm", "mo"},
	{"rmp", "rP"},
	{"rmso", "se"},
	{"rmul", "ue"},
	{"rmxon", "RX"},
	{"rs1", "r1"},
	{"rs2", "r2"},
	{"rs3", "r3"},
	{"sc", "sc"},
	{"sgr", "sa"},
	{"sgr0", "me"},
	{"smacs", "as"},
	{"smam", "SA"},
	{"smcup", "ti"},
	{"smdc", "dm"},
	{"smgl", "ML"},
	{"smgr", "MR"},
	{"smir", "im"},
	{"smkx", "ks"},
	{"smln", "LO"},
	{"smm", "mm"},
	{"smso", "so"},
	{"smul", "us"},
	{"smxon", "SX"},
	{"tbc", "ct"},
	{"tsl", "ts"},
	{"uc", "uc"},
	{"ul", "ul"},
	{"vpa", "cv"},
	{"vt", "vt"},
	{"wind", "wi"},
	{"wsl", "ws"},
	{"xenl", "xn"},
	{"xhp", "xs"},
	{"xmc", "sg"},
	{"xoffc", "XF"},
	{"xon", "xo"},
	{"xonc", "XN"},
	{"xsb", "xb"},
	{"xt", "xt"}
};

int errno;
unsigned short errsup = 0;
xxTPUTxx
fi
if test -f 'tput.c'
then
	echo shar: "will not over-write existing file 'tput.c'"
else
cat << \xxTPUTxx > 'tput.c'
#ifndef LINT
static char rcsid[] = "$Header: tput.c,v 1.6 86/09/19 17:01:00 badri Exp $" ;
#endif LINT
/*
 * Copyright (C) $Date: 86/09/19 17:01:00 $
 * by $Author: badri $
 * University of Rochester,
 * Department of Electrical Engineering.
 *
 * CoNtEnTs   This file contains a program to emulate the system V
 * CoNtEnTs   version of tput.
 *
 * $Locker:  $
 * $Source: /u/users/badri/usr/src/local/tput/RCS/tput.c,v $
 * $Revision: 1.6 $
 *
 * History of this release:
 * $Log:	tput.c,v $
 * Revision 1.6  86/09/19  17:01:00  badri
 * Updated to incorporate -e flag etc.
 * 
 * Revision 1.5  86/09/18  20:58:09  badri
 * Rewrote match, which had a bug in it!
 * 
 * Revision 1.4  86/09/18  15:43:34  badri
 * Updated to incorporate all flags of the old SV tput plus cursor movement
 * plus -n flag to affect number of lines (if permitted.)
 * 
 * Revision 1.3  86/09/18  15:34:51  badri
 * This is an interim version to make tput more compatible with SV.
 * Mods suggested by mark@cbosgd (Mark Horton)
 * 
 * Revision 1.2  86/08/22  13:39:27  badri
 * 1. Corrected a bug that would cause %d to fail after %%.
 * 2. Included XTABS handling.
 * 3. General cleanup of code.
 * 1. Corrected a bug that would cause %d to fail after %%.
 * 2. Included XTABS handling.
 * 3. General cleanup of code.
 * 
 * Revision 1.1  86/08/21  19:23:33  badri
 * Initial revision
 * 
 */
#include "tput.h"

main(argc,argv)
int argc;
char *argv[];
{
	char bp[LARGEBUF], *getenv(), *tgetstr(), *tgoto(),
	     buf[SMALLBUF], *id, *area, *ptr;
	int outc();
	struct sgttyb ttyprm;
	unsigned short ttyflg, arg, start, pos, end;
	long affcnt, val;

	if (argc < 2) quit(BADUSE,"fubar");

	arg = 1;
	affcnt = 1;
	val = -1;	/* This is used for examining if type of
			 * terminal is explicitly specified.
			 */

	while (argv[arg][0] == '-')
	{
		switch (argv[arg][1])
		{
			case 'T':	/* Terminal type */
			if (argv[arg][2] == '\0' || argc < 3)
				quit(BADUSE,"fubar");

			if (tgetent(bp,&argv[arg][2]) < 1)
				quit(BADTERM,&argv[arg][2]);
			val = 0;
			break;

			case 'e':	/* Suppress printing of error message */
			errsup = 1;
			break;

			case 'n':	/* No. of affected lines */
			affcnt = atoi(&argv[arg][2]); 
			break;

			default:
				quit(BADUSE,"fubar");
		}
		arg++;
	}
	if (val < 0)
		if (tgetent(bp,getenv("TERM")) < 1)
			quit(BADTERM,"in environment variable TERM");

	/* Begin a binary search for capability in table */ 
	for (start = 0, end = TABLESIZE - 1, pos = (end - start) >> 1;
	     end - start > 1; pos = start + ((end - start) >> 1))
	{
		switch (match(argv[arg],table[pos].key))
		{
			case -1:    /* Lexicographically less than pos */
			end = pos;
			continue;

			case  0:	/* A hit! */
			id = table[pos].value;
			goto WORK;

			case  1:    /* Lexicographically greater than pos. */
			start = pos;
			continue;
		}			
	}

	/* Examine the current start and end positions of table for match */
	if (!match(argv[arg],table[start].key)) id = table[start].value;
	else if (!match(argv[arg],table[end].key)) id = table[end].value;
	else quit(BADCAP,argv[arg]);  /* Could not find capability in table */

	WORK:
	/* At this point we know that the capability exists in our
	 * table, but we do not know if it is of type boolean, string
	 * or has a numeric value (or does not exist.)
	 */
	if ((val = tgetnum(id)) != -1)
	{
		/* It has a numeric value. Print it and quit. */
		fprintf(stdout, "%d\n",val);
		quit(SUCCESS,"tput");
	}

	/* It is of type string (or boolean) */
	area = buf;
	if (!tgetstr(id,&area))
	{
		/* Boolean */
	 	if (tgetflag(id)) quit(SUCCESS,"tput");
		else quit(FAILURE,"tput");
	}
	/*
	 * It is of type string.
	 * Examine if cursor movement specified. This is done
	 * by looking for % followed by any but %. Since %%
	 * is a single %, we have to make sure that %% followed
	 * by any but % is not interpreted as a format.
	 * If cursor movement is specified then tgoto needs
	 * to be invoked. Else put as is.
	 */
	ptr = buf;
	while (*ptr != '\0')
	{
		if (*(ptr++) != '%') continue;
		if (*ptr != '\0' && *(ptr++) != '%')
		{
			/* This string is a cm string. Increment arg to
			 * position it over the numeric argument (if specified!)
			 */
			if (argc - ++arg < 2) quit(BADUSE,"fubar");

			if (*(ptr=tgoto(buf,atoi(argv[arg+1]),atoi(argv[arg])))
				== 'O' && *(ptr+1) == 'O' &&
			    *(ptr+2) == 'P' && *(ptr+3) == 'S')
				quit(BADUSE,"fubar");

			/* Turn off XTABS, but save old flags first. */
			if (gtty(fileno(stdout),&ttyprm) < 0)
				quit(SYSTEM,"fubar");
			ttyflg = ttyprm.sg_flags;

			ttyprm.sg_flags &= ~XTABS;
			if (stty(fileno(stdout),&ttyprm) < 0)
				quit(SYSTEM,"fubar");

			tputs(ptr,affcnt,outc);

			/* Restore old flags. */
			ttyprm.sg_flags = ttyflg;
			if (stty(fileno(stdout),&ttyprm) < 0)
				quit(SYSTEM,"fubar");
			quit(SUCCESS,"tput");
		}
	quit(BADUSE,"fubar");
	}
	tputs(buf,affcnt,outc);
	quit(SUCCESS,"tput");
}

outc(c)
char c;
{
	if (write(fileno(stdout),&c,sizeof(char)) < 0)
		quit(SYSTEM,"fubar");
	return(SUCCESS);
}

match(s1,s2)
char *s1, *s2;
{
	while (*s1 == *s2)
	{
		if (*s1 == '\0') return(0);
		s1++, s2++;
	}
	return(*s1 > *s2 ? 1:-1);
}

quit(i,s)
int i;
char *s;
{
	if (errsup)
	{
		if (i < SYSTEM) exit(i);
		else exit(errno);
	}
	switch(i)
	{
		case SUCCESS:
		case FAILURE:
		exit(i);

		case BADUSE:
		fprintf(stderr,
		"Usage: tput [ -Ttype ] [ -e ] [ -nlines ] capname [ x y ]\n");
		exit(i);
	
		case BADTERM:
		fprintf(stderr, "Bad terminal type: %s\n",s);
		exit(i);

		case BADCAP:
		fprintf(stderr, "Bad capability: %s\n",s);
		exit(i);

		case SYSTEM:
		fprintf(stderr, "Terminal I/O error - examine exit status\n");
		exit(errno);
	}
}
xxTPUTxx
fi
exit 0
#	End of shell archive

-- 
Please send comp.sources.unix-related mail to rsalz@uunet.uu.net.

jpr@dasys1.UUCP (Jean-Pierre Radley) (11/19/88)

In article <7668@well.UUCP> Jef Poskanzer <jef@rtsg.ee.lbl.gov> writes:
>Has anyone written a tool to perform curses functions from a shell script?
>Something like "curse so" to enter stand-out mode, or "curse cm 14 3" to
>do cursor addressing.

My practice is to create environment variables for stand-out,
clear-screen, etc, upon login. I have a routine in .login (or .profile)
that reads termcap or terminfo stuff into these variables.

You could also look back about half a year ago into one of Swartz'
articles in UnixWorld. He had just such procedures which he used in
creating user menus. Lines would be neatly placed at deired positions on
the user's screen, some of them highlighted, etc. I don't have my back
issues handy, but e-mail me if you can't locate the article.
-- 
Jean-Pierre Radley		Honi soit		jpr@dasys1.UUCP
New York, New York		qui mal			...!hombre!jpradley!jpr
CIS: 76120,1341			y pense			...!hombre!trigere!jpr

pokey@well.UUCP (Jef Poskanzer) (11/19/88)

In the referenced message, I asked:
>Has anyone written a tool to perform curses functions from a shell script?

Response has been quite enthusiastic.  Aside from the copy of "tput" posted
by Rich Salz and the copy of "term" posted by David L Stevens, I got the
following mail:

    Alfred Correira mailed me a copy of "getcap", from UNIX/World in 12/86.
    Greg Lee mailed a copy of "tput".
    David Elliot, Jeff Lo, David Connet, and Guy Harris all mailed pointers
      to "tput".
    Tim Rosmus mailed a copy of "kurses", which came from Marc Reis in 11/86.
    Jon M. Allingham and "somewhere!francis" mailed pointers to "kurses".
    Frank Rahmani mailed two copies of "tc", from mod.sources in 11/85!
    t patterson mailed a copy of "curse", from Jonathan Bowen in 02/85!!
    And John P. Nelson mailed the amusing comment, "About once every 6 to
      12 months, someone reinvents this wheel."

Anyway, as far as my original question goes, I think this qualifies as a "yes".
---
Jef

             Jef Poskanzer   jef@rtsg.ee.lbl.gov   ...well!pokey
                      "Has everybody got their mustard?"

peter@ficc.uu.net (Peter da Silva) (11/21/88)

Maybe someone with a 3b1 can post the specs on the script-based menu
system. A portable version of that would be pretty useful.
-- 
Peter da Silva  `-_-'  Ferranti International Controls Corporation
"Have you hugged  U  your wolf today?"     uunet.uu.net!ficc!peter
Disclaimer: My typos are my own damn business.   peter@ficc.uu.net

bes@holin.ATT.COM (Bradley Smith) (11/22/88)

In article <2276@ficc.uu.net>, peter@ficc.uu.net (Peter da Silva) writes:
> Maybe someone with a 3b1 can post the specs on the script-based menu
> system. A portable version of that would be pretty useful.
Try faces(1) it comes with rel 3 of unix system v
-- 
Bradley Smith				att!holin!bes
AT&T Bell Labs, Holmdel, NJ			bes@holin.att.com
OIL
201-949-0090 / Cornet 233-0090

logan@vsedev.VSE.COM (James Logan III) (11/23/88)

In article <7668@well.UUCP> Jef Poskanzer <jef@rtsg.ee.lbl.gov> writes:
>Has anyone written a tool to perform curses functions from a shell script?
>Something like "curse so" to enter stand-out mode, or "curse cm 14 3" to
>do cursor addressing.  If no one can point me to something like this, I'll
>hack it up and post it.

Have you ever heard of tput(1) under System V?  It almost does
what you want with the exception that you can't give it screen
addressing arguments.  Instead you can say "tput cup" and it will
give you something like:  

	^[[%i%p1%d;%p2%dH

that you can parse pretty easily.


It will let you do this kind of thing in a shell script:

CLEAR=`tput clear`;
BOLD=`tput bold`;
NORM=`tput sgr0`;

	.
	.
	.

echo "${CLEAR}This is an ${BOLD}IMPORTANT${NORM} message!";

			-Jim
-- 
Jim Logan		logan@vsedev.vse.com
(703) 892-0002		uucp:	..!uunet!vsedev!logan
			inet:	logan%vsedev.vse.com@uunet.uu.net

wu@spot.Colorado.EDU (WU SHI-KUEI) (11/24/88)

In article <1247@vsedev.VSE.COM> logan@vsedev.VSE.COM (James Logan III) writes:
>In article <7668@well.UUCP> Jef Poskanzer <jef@rtsg.ee.lbl.gov> writes:
>>Has anyone written a tool to perform curses functions from a shell script?
>Have you ever heard of tput(1) under System V?  It almost does
>what you want with the exception that you can't give it screen
>addressing arguments.  Instead you can say "tput cup" and it will
>give you something like:  
>
>	^[[%i%p1%d;%p2%dH
>
>that you can parse pretty easily.

On my 3B2 running SVR3.1, I can write 

	tput cup 10 10

and the cursor will be positioned as expected.  No further parsing is
required.

Just a guest here - in reality
Carl Brandauer
uunet!nbires!bdaemon!carl

friedl@vsi.COM (Stephen J. Friedl) (11/24/88)

In article <7668@well.UUCP> Jef Poskanzer <jef@rtsg.ee.lbl.gov> writes:
>Has anyone written a tool to perform curses functions from a shell script?

In article <1247@vsedev.VSE.COM>, logan@vsedev.VSE.COM (James Logan III) writes:
> Have you ever heard of tput(1) under System V?  It almost does
> what you want with the exception that you can't give it screen
> addressing arguments.

System V Release 3.1 (maybe 3.0?) has a tput that does
parameterization the right way:

	$ tput 12 37 ; echo foobar

centers our favorite phrase on most screens (the general case,
using `tput lines` and such is left as an exercise to the reader).

     Steve
-- 
Steve Friedl    V-Systems, Inc.  +1 714 545 6442    3B2-kind-of-guy
friedl@vsi.com     {backbones}!vsi.com!friedl    attmail!vsi!friedl
------------Nancy Reagan on climaxes: "Just say moan!"-------------
:wq!

dce@mips.COM (David Elliott) (11/26/88)

In article <949@vsi.COM> friedl@vsi.COM (Stephen J. Friedl) writes:
>System V Release 3.1 (maybe 3.0?) has a tput that does
>parameterization the right way:
>
>	$ tput 12 37 ; echo foobar

My System V.3.1 source doesn't work this way, but if you say

	tput cup 12 37 ; echo foobar

it works just fine.

In general, tput takes a capability name and acts upon it based on
what kind of capability it is:

	* INTs are printed on stdout.

	* BOOLEANs cause the exit code of tput to be set the same way
	  the boolean value is set.

	* STRINGs are printed with all arguments given handled as
	  parameters.  Numeric parameters are converted to numbers
	  and others are passed as strings.  This allows both cursor
	  motion type things and function key program type things.

Tput is quite useful.  With it, I was able to rewrite the hgrep filter
posted to comp.sources.unix last week as a sed script:

#!/bin/sh
#
# hgrep - Run grep and hilite the pattern searched
#

PATH=/bin:/usr/bin
Pattern=""
H_on=`tput smso`
H_off=`tput rmso`

main()
{

	for i
	{
		case "$i" in
			-*)
				continue
				;;
			*)
				Pattern="$i"
				break
				;;
		esac
	}

	if [ -t 1 ]
	then
		grep ${1+"$@"} | hilite
	else
		exec grep ${1+"$@"}
	fi
}

hilite()
{
	sed 's/\('"$Pattern"'\)/'"$H_on"'\1'"$H_off"'/g'
}

main ${1+"$@"}

-- 
David Elliott		dce@mips.com  or  {ames,prls,pyramid,decwrl}!mips!dce
"Did you see his eyes?  Did you see his crazy eyes?" -- Iggy (who else?)

pokey@well.UUCP (Jef Poskanzer) (11/26/88)

In the referenced message, dce@mips.COM (David Elliott) wrote:
>Tput is quite useful.  With it, I was able to rewrite the hgrep filter
>posted to comp.sources.unix last week as a sed script:

Yes, that's exactly what I was thinking of when I posted my query about
curses from scripts.  However, it turns out that the various script
versions of hgrep are noticably slower than the C version.  Oh well.

By the way, if you want a script version that handles -i, see below.
---
Jef

             Jef Poskanzer   jef@rtsg.ee.lbl.gov   ...well!pokey
                                  "SCIENCE!"

#!/bin/csh -f
#
# hgrep - highlight results of grep
#
# By Jef Poskanzer - an elaboration of Amos Shapir's version.

# Figure out which grep to use.
set fname="$0"
set name="${fname:t}"
switch ( "$name" )
    case hgrep:
    set grep=grep
    breaksw

    case hegrep:
    set grep=egrep
    breaksw

    case hfgrep:
    set grep=fgrep
    breaksw

    case hngrep:
    set grep=ngrep
    breaksw

    default:
    set grep=grep
endsw

# Scan args.
foreach i ( $argv )
    switch ( "$i" )
	case -i:
	set iflag
	breaksw

	case -*:
	breaksw

	default:
	set word="$i"
	goto out
    endsw
end

out:

# Case insensitive?
if ( $?iflag ) then
    set word="`echo "$word" | sed -e 's/[Aa]/[Aa]/g' -e 's/[Bb]/[Bb]/g' -e 's/[Cc]/[Cc]/g' -e 's/[Dd]/[Dd]/g' -e 's/[Ee]/[Ee]/g' -e 's/[Ff]/[Ff]/g' -e 's/[Gg]/[Gg]/g' -e 's/[Hh]/[Hh]/g' -e 's/[Ii]/[Ii]/g' -e 's/[Jj]/[Jj]/g' -e 's/[Kk]/[Kk]/g' -e 's/[Ll]/[Ll]/g' -e 's/[Mm]/[Mm]/g' -e 's/[Nn]/[Nn]/g' -e 's/[Oo]/[Oo]/g' -e 's/[Pp]/[Pp]/g' -e 's/[Qq]/[Qq]/g' -e 's/[Rr]/[Rr]/g' -e 's/[Ss]/[Ss]/g' -e 's/[Tt]/[Tt]/g' -e 's/[Uu]/[Uu]/g' -e 's/[Vv]/[Vv]/g' -e 's/[Ww]/[Ww]/g' -e 's/[Xx]/[Xx]/g' -e 's/[Yy]/[Yy]/g' -e 's/[Zz]/[Zz]/g'`"
endif

# Here be terminal dependencies.
set so="[7m" se="[m"

# And do it.
$grep ${argv[1-]} | sed -e "s/$word/$so&$se/g"