Use err(3) insteadof local redefinition. Sync usage string with man page.

This commit is contained in:
Philippe Charnier 1997-08-18 07:27:59 +00:00
parent 14aebc178d
commit 71346dd104
8 changed files with 73 additions and 76 deletions

@ -41,7 +41,6 @@ extern int erasechar, intrchar, killchar;
void add_mapping __P((char *, char *));
void cat __P((char *));
void err __P((const char *, ...));
char *get_termcap_entry __P((char *, char **));
char *mapped __P((char *));
int outc __P((int));

@ -32,14 +32,18 @@
*/
#ifndef lint
#if 0
static char sccsid[] = "@(#)map.c 8.1 (Berkeley) 6/9/93";
#endif
static const char rcsid[] =
"$Id$";
#endif /* not lint */
#include <sys/types.h>
#include <termios.h>
#include <errno.h>
#include <err.h>
#include <stdlib.h>
#include <string.h>
#include <termios.h>
#include "extern.h"
extern speed_t Ospeed;
@ -78,7 +82,7 @@ add_mapping(port, arg)
copy = strdup(arg);
mapp = malloc((u_int)sizeof(MAP));
if (copy == NULL || mapp == NULL)
err("%s", strerror(errno));
errx(1, "malloc");
mapp->next = NULL;
if (maplist == NULL)
cur = maplist = mapp;
@ -154,7 +158,7 @@ next: if (*arg == ':') {
/* If user specified a port with an option flag, set it. */
done: if (port) {
if (mapp->porttype)
badmopt: err("illegal -m option format: %s", copy);
badmopt: errx(1, "illegal -m option format: %s", copy);
mapp->porttype = port;
}
@ -247,6 +251,6 @@ baudrate(rate)
return (sp->speed);
speed = atol(rate);
if (speed == 0)
err("unknown baud rate %s", rate);
errx(1, "unknown baud rate %s", rate);
return speed;
}

@ -32,11 +32,15 @@
*/
#ifndef lint
#if 0
static char sccsid[] = "@(#)misc.c 8.1 (Berkeley) 6/9/93";
#endif
static const char rcsid[] =
"$Id$";
#endif /* not lint */
#include <fcntl.h>
#include <errno.h>
#include <err.h>
#include <unistd.h>
#include <stdio.h>
#include <stdlib.h>
@ -51,13 +55,13 @@ cat(file)
char buf[1024];
if ((fd = open(file, O_RDONLY, 0)) < 0)
err("%s: %s", file, strerror(errno));
err(1, "%s", file);
while ((nr = read(fd, buf, sizeof(buf))) > 0)
if ((nw = write(STDERR_FILENO, buf, nr)) == -1)
err("write to stderr: %s", strerror(errno));
err(1, "write to stderr");
if (nr != 0)
err("%s: %s", file, strerror(errno));
err(1, "%s", file);
(void)close(fd);
}
@ -67,32 +71,3 @@ outc(c)
{
return putc(c, stderr);
}
#if __STDC__
#include <stdarg.h>
#else
#include <varargs.h>
#endif
void
#if __STDC__
err(const char *fmt, ...)
#else
err(fmt, va_alist)
char *fmt;
va_dcl
#endif
{
va_list ap;
#if __STDC__
va_start(ap, fmt);
#else
va_start(ap);
#endif
(void)fprintf(stderr, "tset: ");
(void)vfprintf(stderr, fmt, ap);
va_end(ap);
(void)fprintf(stderr, "\n");
exit(1);
/* NOTREACHED */
}

@ -32,7 +32,11 @@
*/
#ifndef lint
#if 0
static char sccsid[] = "@(#)set.c 8.2 (Berkeley) 2/28/94";
#endif
static const char rcsid[] =
"$Id$";
#endif /* not lint */
#include <termios.h>

@ -32,16 +32,21 @@
*/
#ifndef lint
#if 0
static char sccsid[] = "@(#)term.c 8.1 (Berkeley) 6/9/93";
#endif
static const char rcsid[] =
"$Id$";
#endif /* not lint */
#include <sys/types.h>
#include <err.h>
#include <errno.h>
#include <ttyent.h>
#include <unistd.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <ttyent.h>
#include "extern.h"
char tbuf[1024]; /* Termcap entry. */
@ -67,12 +72,12 @@ get_termcap_entry(userarg, tcapbufp)
}
/* Try the environment. */
if (ttype = getenv("TERM"))
if ((ttype = getenv("TERM")))
goto map;
/* Try ttyname(3); check for dialup or other mapping. */
if (ttypath = ttyname(STDERR_FILENO)) {
if (p = rindex(ttypath, '/'))
if ((ttypath = ttyname(STDERR_FILENO))) {
if ((p = rindex(ttypath, '/')))
++p;
else
p = ttypath;
@ -107,12 +112,11 @@ found: if ((p = getenv("TERMCAP")) != NULL && *p != '/')
/* Find the termcap entry. If it doesn't exist, ask the user. */
while ((rval = tgetent(tbuf, ttype)) == 0) {
(void)fprintf(stderr,
"tset: terminal type %s is unknown\n", ttype);
warnx("terminal type %s is unknown", ttype);
ttype = askuser(NULL);
}
if (rval == -1)
err("termcap: %s", strerror(errno ? errno : ENOENT));
errx(1, "termcap: %s", strerror(errno ? errno : ENOENT));
*tcapbufp = tbuf;
return (ttype);
}
@ -145,7 +149,7 @@ askuser(dflt)
return (dflt);
}
if (p = index(answer, '\n'))
if ((p = index(answer, '\n')))
*p = '\0';
if (answer[0])
return (answer);

@ -70,7 +70,7 @@ argument specified on the command line.
.It
The value of the
.Ev TERM
environmental variable.
environment variable.
.It
The terminal type associated with the standard error output device in the
.Pa /etc/ttys
@ -100,7 +100,7 @@ standard error output.
.Pp
When invoked as
.Nm reset ,
.Nm tset
.Nm
sets cooked and echo modes, turns off cbreak and raw modes, turns on
newline translation and resets any unset special characters to their
default values before doing the terminal initialization described above.
@ -183,7 +183,7 @@ option is specified, the commands to enter the information into the
shell's environment are written to the standard output.
If the
.Ev SHELL
environmental variable ends in ``csh'', the commands are for the
environment variable ends in ``csh'', the commands are for the
.Nm csh ,
otherwise, they are for
.Xr sh .
@ -220,13 +220,13 @@ information is incorrect) the terminal type derived from the
.Pa /etc/ttys
file or the
.Ev TERM
environmental variable is often something generic like
environment variable is often something generic like
.Dq network ,
.Dq dialup ,
or
.Dq unknown .
When
.Nm tset
.Nm
is used in a startup script
.Pf ( Pa .profile
for
@ -243,7 +243,7 @@ option is to
.Dq map
from some set of conditions to a terminal type, that is, to
tell
.Nm tset
.Nm
``If I'm on this port at a particular speed, guess that I'm on that
kind of terminal''.
.Pp
@ -320,7 +320,7 @@ users insert a backslash character (``\e'') before any exclamation
marks (``!'').
.Sh ENVIRONMENT
The
.Nm tset
.Nm
command utilizes the
.Ev SHELL
and
@ -343,7 +343,7 @@ terminal capability database
.Xr environ 7
.Sh HISTORY
The
.Nm tset
.Nm
command appeared in
.Bx 3.0 .
.Sh COMPATIBILITY
@ -355,7 +355,7 @@ The
and
.Fl v
options have been deleted from the
.Nm tset
.Nm
utility.
None of them were documented in 4.3BSD and all are of limited utility at
best.
@ -382,7 +382,7 @@ options without arguments, although it is strongly recommended that such
usage be fixed to explicitly specify the character.
.Pp
Executing
.Nm tset
.Nm
as
.Nm reset
no longer implies the
@ -393,11 +393,11 @@ Also, the interaction between the
option and the
.Ar terminal
argument in some historic implementations of
.Nm tset
.Nm
has been removed.
.Pp
Finally, the
.Nm tset
.Nm
implementation has been completely redone (as part of the addition to the
system of a
.St -p1003.1-88

@ -32,24 +32,28 @@
*/
#ifndef lint
static char copyright[] =
static const char copyright[] =
"@(#) Copyright (c) 1980, 1991, 1993\n\
The Regents of the University of California. All rights reserved.\n";
#endif /* not lint */
#ifndef lint
#if 0
static char sccsid[] = "@(#)tset.c 8.1 (Berkeley) 6/9/93";
#endif
static const char rcdif[] =
"$Id$";
#endif /* not lint */
#include <sys/types.h>
#include <sys/ioctl.h>
#include <termios.h>
#include <errno.h>
#include <unistd.h>
#include <stdlib.h>
#include <stdio.h>
#include <ctype.h>
#include <err.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <termios.h>
#include "extern.h"
void obsolete __P((char *[]));
@ -74,15 +78,15 @@ main(argc, argv)
struct winsize win;
#endif
int ch, noinit, noset, quiet, Sflag, sflag, showterm, usingupper;
char savech, *p, *t, *tcapbuf, *ttype;
char *p, *t, *tcapbuf, *ttype;
if (tcgetattr(STDERR_FILENO, &mode) < 0)
err("standard error: %s", strerror(errno));
err(1, "standard error");
oldmode = mode;
Ospeed = cfgetospeed(&mode);
if (p = strrchr(*argv, '/'))
if ((p = strrchr(*argv, '/')))
++p;
else
p = *argv;
@ -262,9 +266,9 @@ obsolete(argv)
char *argv[];
{
for (; *argv; ++argv) {
if (argv[0][0] != '-' || argv[1] && argv[1][0] != '-' ||
argv[0][1] != 'e' && argv[0][1] != 'i' &&
argv[0][1] != 'k' || argv[0][2] != '\0')
if (argv[0][0] != '-' || (argv[1] && argv[1][0] != '-') ||
(argv[0][1] != 'e' && argv[0][1] != 'i' && argv[0][1] != 'k') ||
argv[0][2] != '\0')
continue;
switch(argv[0][1]) {
case 'e':
@ -283,7 +287,9 @@ obsolete(argv)
void
usage()
{
(void)fprintf(stderr,
"usage: tset [-IQrSs] [-] [-e ch] [-i ch] [-k ch] [-m mapping] [terminal]\n");
(void)fprintf(stderr, "%s\n%s\n",
"usage: tset [-IQrSs] [-] [-e ch] [-i ch] [-k ch] [-m mapping] [terminal]",
" reset [-IQrSs] [-] [-e ch] [-i ch] [-k ch] [-m mapping] [terminal]");
exit(1);
}

@ -32,12 +32,17 @@
*/
#ifndef lint
#if 0
static char sccsid[] = "@(#)wrterm.c 8.1 (Berkeley) 6/9/93";
#endif
static const char rcsid[] =
"$Id$";
#endif /* not lint */
#include <sys/types.h>
#include <stdio.h>
#include <ctype.h>
#include <err.h>
#include <stdio.h>
#include <string.h>
#include "extern.h"
@ -55,7 +60,7 @@ wrtermcap(bp)
/* Find the end of the terminal names. */
if ((t = index(bp, ':')) == NULL)
err("termcap names not colon terminated");
errx(1, "termcap names not colon terminated");
*t++ = '\0';
/* Output terminal names that don't have whitespace. */