Node:getpass, Next:crypt, Previous:Legal Problems, Up:Cryptographic Functions
When reading in a password, it is desirable to avoid displaying it on the screen, to help keep it secret. The following function handles this in a convenient way.
| char * getpass (const char *prompt) | Function | 
| 
 In other C libraries,  The prototype for this function is in  | 
This precise set of operations may not suit all possible situations.  In
this case, it is recommended that users write their own getpass
substitute.  For instance, a very simple substitute is as follows:
#include <termios.h>
#include <stdio.h>
ssize_t
my_getpass (char **lineptr, size_t *n, FILE *stream)
{
  struct termios old, new;
  int nread;
  /* Turn echoing off and fail if we can't. */
  if (tcgetattr (fileno (stream), &old) != 0)
    return -1;
  new = old;
  new.c_lflag &= ~ECHO;
  if (tcsetattr (fileno (stream), TCSAFLUSH, &new) != 0)
    return -1;
  /* Read the password. */
  nread = getline (lineptr, n, stream);
  /* Restore terminal. */
  (void) tcsetattr (fileno (stream), TCSAFLUSH, &old);
  return nread;
}
The substitute takes the same parameters as getline
(see Line Input); the user must print any prompt desired.