diff --git a/src/getpass.c b/src/getpass.c index 77e950c9d..975ce1dde 100644 --- a/src/getpass.c +++ b/src/getpass.c @@ -1,5 +1,4 @@ /* ============================================================================ - * Copyright (C) 1998 - 2002, Daniel Stenberg, , et al. * * Redistribution and use are freely permitted provided that: * @@ -30,8 +29,6 @@ * * Author(s): * Angus Mackay - * - * Contributor(s): * Daniel Stenberg */ @@ -49,19 +46,25 @@ #include iosbdef char *getpass_r(const char *prompt, char *buffer, size_t buflen) { - long sts; - short chan; - struct _iosb iosb; - $DESCRIPTOR(ttdesc, "TT"); + long sts; + short chan; + struct _iosb iosb; + $DESCRIPTOR(ttdesc, "TT"); - buffer[0]='\0'; - if ((sts = sys$assign(&ttdesc, &chan,0,0)) & 1) { - if (((sts = sys$qiow(0, chan, IO$_READPROMPT | IO$M_NOECHO, &iosb, 0, 0, buffer, buflen, 0, 0, prompt, strlen(prompt))) & 1) && (iosb.iosb$w_status&1)) { - buffer[iosb.iosb$w_bcnt] = '\0'; - } - sts = sys$dassgn(chan); - } - return buffer; /* we always return success */ + buffer[0]='\0'; + sts = sys$assign(&ttdesc, &chan,0,0); + if (sts & 1) { + sts = sys$qiow(0, chan, + IO$_READPROMPT | IO$M_NOECHO, + &iosb, 0, 0, buffer, buflen, 0, 0, + prompt, strlen(prompt)); + + if((sts & 1) && (iosb.iosb$w_status&1)) + buffer[iosb.iosb$w_bcnt] = '\0'; + + sts = sys$dassgn(chan); + } + return buffer; /* we always return success */ } #else /* VMS */ #ifdef HAVE_TERMIOS_H