summaryrefslogtreecommitdiff
path: root/usr/src/lib/libc/port/stdio/getpass.c
diff options
context:
space:
mode:
authorcraigm <none@none>2007-02-07 14:12:12 -0800
committercraigm <none@none>2007-02-07 14:12:12 -0800
commitb952dcaaf805e7c797b236434862b1bd6718fd68 (patch)
treee424c02389885c49a0846758597e41f90c156415 /usr/src/lib/libc/port/stdio/getpass.c
parentbf1f3d9222ae6fcadd490d70a03838f7a2d30bb0 (diff)
downloadillumos-joyent-b952dcaaf805e7c797b236434862b1bd6718fd68.tar.gz
6515653 __getpass function outputs to stderr rather than tty
Diffstat (limited to 'usr/src/lib/libc/port/stdio/getpass.c')
-rw-r--r--usr/src/lib/libc/port/stdio/getpass.c10
1 files changed, 4 insertions, 6 deletions
diff --git a/usr/src/lib/libc/port/stdio/getpass.c b/usr/src/lib/libc/port/stdio/getpass.c
index b25ef5efa6..1e4ce5e38f 100644
--- a/usr/src/lib/libc/port/stdio/getpass.c
+++ b/usr/src/lib/libc/port/stdio/getpass.c
@@ -19,7 +19,7 @@
* CDDL HEADER END
*/
/*
- * Copyright 2006 Sun Microsystems, Inc. All rights reserved.
+ * Copyright 2007 Sun Microsystems, Inc. All rights reserved.
* Use is subject to license terms.
*/
@@ -80,7 +80,7 @@ __getpass(const char *prompt, int size)
rmutex_t *lk;
if (pbuf == NULL ||
- (fi = fopen("/dev/tty", "rF")) == NULL)
+ (fi = fopen("/dev/tty", "r+F")) == NULL)
return (NULL);
setbuf(fi, NULL);
sig = signal(SIGINT, catch);
@@ -89,8 +89,7 @@ __getpass(const char *prompt, int size)
flags = ttyb.c_lflag;
ttyb.c_lflag &= ~(ECHO | ECHOE | ECHOK | ECHONL);
(void) ioctl(FILENO(fi), TCSETAF, &ttyb);
- FLOCKFILE(lk, stderr);
- (void) fputs(prompt, stderr);
+ (void) fputs(prompt, fi);
p = pbuf;
while (!intrupt &&
(c = GETC(fi)) != '\n' && c != '\r' && c != EOF) {
@@ -98,10 +97,9 @@ __getpass(const char *prompt, int size)
*p++ = (char)c;
}
*p = '\0';
+ (void) PUTC('\n', fi);
ttyb.c_lflag = flags;
(void) ioctl(FILENO(fi), TCSETAW, &ttyb);
- (void) PUTC('\n', stderr);
- FUNLOCKFILE(lk);
(void) signal(SIGINT, sig);
(void) fclose(fi);
if (intrupt)