send error messages & password prompt to stderr, as proposed by Simon Gerraty.

Note that this is not necessarily correct for the password prompt: ideally,
libc/gen/getpass.c should be cloned into the password reading routine in
libskey, and it should be extended to take a prompt string, so that the prompt
and input are taken from /dev/tty, a la passwd(1).
Also, make usage() exit as is standard style, and delete the redundant exits.
This commit is contained in:
cgd 1994-12-28 23:17:52 +00:00
parent 7b8535b554
commit 6e77815dff

View File

@ -18,7 +18,7 @@
* OMEN US HORN OMIT BACK AHOY * OMEN US HORN OMIT BACK AHOY
* > * >
* *
* $Id: skey.c,v 1.1 1994/05/24 06:48:02 deraadt Exp $ * $Id: skey.c,v 1.2 1994/12/28 23:17:52 cgd Exp $
*/ */
#include <stdio.h> #include <stdio.h>
@ -59,36 +59,30 @@ main(argc, argv)
if (argc <= optind + 1) { if (argc <= optind + 1) {
/* look for / in it */ /* look for / in it */
if (argc <= optind) { if (argc <= optind)
usage(argv[0]); usage(argv[0]);
exit(1);
}
slash = strchr(argv[optind], '/'); slash = strchr(argv[optind], '/');
if (slash == NULL) { if (slash == NULL)
usage(argv[0]); usage(argv[0]);
exit(1);
}
*slash++ = '\0'; *slash++ = '\0';
seed = slash; seed = slash;
if ((n = atoi(argv[optind])) < 0) { if ((n = atoi(argv[optind])) < 0) {
printf("%s not positive\n", argv[optind]); fprintf(stderr, "%s not positive\n", argv[optind]);
usage(argv[0]); usage(argv[0]);
exit(1);
} }
} else { } else {
if ((n = atoi(argv[optind])) < 0) { if ((n = atoi(argv[optind])) < 0) {
printf("%s not positive\n", argv[optind]); fprintf(stderr, "%s not positive\n", argv[optind]);
usage(argv[0]); usage(argv[0]);
exit(1);
} }
seed = argv[++optind]; seed = argv[++optind];
} }
/* Get user's secret password */ /* Get user's secret password */
if (!pass) { if (!pass) {
printf("Enter secret password: "); fprintf(stderr, "Enter secret password: ");
readpass(passwd, sizeof(passwd)); readpass(passwd, sizeof(passwd));
} }
rip(passwd); rip(passwd);
@ -124,5 +118,8 @@ void
usage(s) usage(s)
char *s; char *s;
{ {
printf("Usage: %s [-n count] [-p password ] sequence# [/] key\n", s);
fprintf(stderr,
"Usage: %s [-n count] [-p password ] sequence# [/] key\n", s);
exit(1);
} }