1 /* $OpenBSD: tty_subs.c,v 1.17 2016/08/26 04:22:13 guenther Exp $ */
2 /* $NetBSD: tty_subs.c,v 1.5 1995/03/21 09:07:52 cgd Exp $ */
5 * Copyright (c) 1992 Keith Muller.
6 * Copyright (c) 1992, 1993
7 * The Regents of the University of California. All rights reserved.
9 * This code is derived from software contributed to Berkeley by
10 * Keith Muller of the University of California, San Diego.
12 * Redistribution and use in source and binary forms, with or without
13 * modification, are permitted provided that the following conditions
15 * 1. Redistributions of source code must retain the above copyright
16 * notice, this list of conditions and the following disclaimer.
17 * 2. Redistributions in binary form must reproduce the above copyright
18 * notice, this list of conditions and the following disclaimer in the
19 * documentation and/or other materials provided with the distribution.
20 * 3. Neither the name of the University nor the names of its contributors
21 * may be used to endorse or promote products derived from this software
22 * without specific prior written permission.
24 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
25 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
26 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
27 * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
28 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
29 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
30 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
31 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
32 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
33 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
37 #include <sys/types.h>
49 * routines that deal with I/O to and from the user
52 #define DEVTTY "/dev/tty" /* device for interactive i/o */
53 static FILE *ttyoutf
= NULL
; /* output pointing at control tty */
54 static FILE *ttyinf
= NULL
; /* input pointing at control tty */
58 * try to open the controlling terminal (if any) for this process. if the
59 * open fails, future ops that require user input will get an EOF
67 if ((ttyfd
= open(DEVTTY
, O_RDWR
| O_CLOEXEC
)) >= 0) {
68 if ((ttyoutf
= fdopen(ttyfd
, "w")) != NULL
) {
69 if ((ttyinf
= fdopen(ttyfd
, "r")) != NULL
)
71 (void)fclose(ttyoutf
);
77 paxwarn(1, "Fatal error, cannot open %s", DEVTTY
);
85 * print a message using the specified format to the controlling tty
86 * if there is no controlling terminal, just return.
90 tty_prnt(const char *fmt
, ...)
95 if (ttyoutf
== NULL
) {
99 (void)vfprintf(ttyoutf
, fmt
, ap
);
101 (void)fflush(ttyoutf
);
106 * read a string from the controlling terminal if it is open into the
109 * 0 if data was read, -1 otherwise.
113 tty_read(char *str
, int len
)
115 if (ttyinf
== NULL
|| fgets(str
, len
, ttyinf
) == NULL
)
119 * strip off that trailing newline
121 str
[strcspn(str
, "\n")] = '\0';
127 * write a warning message to stderr. if "set" the exit value of pax
132 paxwarn(int set
, const char *fmt
, ...)
140 * when vflag we better ship out an extra \n to get this message on a
143 if (vflag
&& vfpart
) {
145 (void)fputc('\n', stderr
);
148 (void)fprintf(stderr
, "%s: ", argv0
);
149 (void)vfprintf(stderr
, fmt
, ap
);
151 (void)fputc('\n', stderr
);
156 * write a warning message to stderr. if "set" the exit value of pax
161 syswarn(int set
, int errnum
, const char *fmt
, ...)
169 * when vflag we better ship out an extra \n to get this message on a
172 if (vflag
&& vfpart
) {
174 (void)fputc('\n', stderr
);
177 (void)fprintf(stderr
, "%s: ", argv0
);
178 (void)vfprintf(stderr
, fmt
, ap
);
182 * format and print the errno
185 (void)fprintf(stderr
, ": %s", strerror(errnum
));
186 (void)fputc('\n', stderr
);