diff options
author | Todd C. Miller <millert@cvs.openbsd.org> | 2001-08-07 19:29:21 +0000 |
---|---|---|
committer | Todd C. Miller <millert@cvs.openbsd.org> | 2001-08-07 19:29:21 +0000 |
commit | 3a158cf75f63a6a0c391e33ca40774087c3dcf0a (patch) | |
tree | c64dae13e07186ebb81cbb6c5642c08f1cd921b5 /lib | |
parent | 1149c88d33ef0261d5314058902151a9a431a58d (diff) |
Keep a verbatim copy of the old struct termios instead of using
flags to keep track of what we changed. Print a newline if echo
is off, even if we didn't turn it off ourselves. Fixes art's
problem with a newline not being printed when piping to less.
Diffstat (limited to 'lib')
-rw-r--r-- | lib/libc/gen/readpassphrase.c | 44 |
1 files changed, 15 insertions, 29 deletions
diff --git a/lib/libc/gen/readpassphrase.c b/lib/libc/gen/readpassphrase.c index f95a2f7f46a..2892f1f4ae4 100644 --- a/lib/libc/gen/readpassphrase.c +++ b/lib/libc/gen/readpassphrase.c @@ -26,7 +26,7 @@ */ #if defined(LIBC_SCCS) && !defined(lint) -static char rcsid[] = "$OpenBSD: readpassphrase.c,v 1.5 2001/06/27 13:23:30 djm Exp $"; +static const char rcsid[] = "$OpenBSD: readpassphrase.c,v 1.6 2001/08/07 19:29:20 millert Exp $"; #endif /* LIBC_SCCS and not lint */ #include <ctype.h> @@ -47,10 +47,9 @@ readpassphrase(prompt, buf, bufsiz, flags) size_t bufsiz; int flags; { - struct termios term; + struct termios term, oterm; char ch, *p, *end; - u_char status; - int echo, input, output; + int input, output; sigset_t oset, nset; /* I suppose we could alloc on demand in this case (XXX). */ @@ -83,26 +82,16 @@ readpassphrase(prompt, buf, bufsiz, flags) (void)sigprocmask(SIG_BLOCK, &nset, &oset); /* Turn off echo if possible. */ - echo = 0; - status = _POSIX_VDISABLE; - if (tcgetattr(input, &term) == 0) { - if (!(flags & RPP_ECHO_ON) && (term.c_lflag & ECHO)) { - echo = 1; + memset(&term, 0, sizeof(term)); + memset(&oterm, 0, sizeof(oterm)); + if (tcgetattr(input, &oterm) == 0) { + memcpy(&term, &oterm, sizeof(term)); + if (!(flags & RPP_ECHO_ON) && (term.c_lflag & ECHO)) term.c_lflag &= ~ECHO; - } - if (term.c_cc[VSTATUS] != _POSIX_VDISABLE) { - status = term.c_cc[VSTATUS]; + if (term.c_cc[VSTATUS] != _POSIX_VDISABLE) term.c_cc[VSTATUS] = _POSIX_VDISABLE; - } (void)tcsetattr(input, TCSAFLUSH|TCSASOFT, &term); } - if (!(flags & RPP_ECHO_ON)) { - if (tcgetattr(input, &term) == 0 && (term.c_lflag & ECHO)) { - echo = 1; - term.c_lflag &= ~ECHO; - (void)tcsetattr(input, TCSAFLUSH|TCSASOFT, &term); - } - } (void)write(output, prompt, strlen(prompt)); end = buf + bufsiz - 1; @@ -120,15 +109,12 @@ readpassphrase(prompt, buf, bufsiz, flags) } } *p = '\0'; - if (echo || status != _POSIX_VDISABLE) { - if (echo) { - (void)write(output, "\n", 1); - term.c_lflag |= ECHO; - } - if (status != _POSIX_VDISABLE) - term.c_cc[VSTATUS] = status; - (void)tcsetattr(input, TCSAFLUSH|TCSASOFT, &term); - } + if (!(term.c_lflag & ECHO)) + (void)write(output, "\n", 1); + + /* Restore old terminal settings and signal mask. */ + if (memcmp(&term, &oterm, sizeof(term)) != 0) + (void)tcsetattr(input, TCSAFLUSH|TCSASOFT, &oterm); (void)sigprocmask(SIG_SETMASK, &oset, NULL); if (input != STDIN_FILENO) (void)close(input); |