summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--usr.bin/ftp/cmds.c8
-rw-r--r--usr.bin/ftp/util.c18
2 files changed, 19 insertions, 7 deletions
diff --git a/usr.bin/ftp/cmds.c b/usr.bin/ftp/cmds.c
index 8f5c8808c8f..2867cce07cd 100644
--- a/usr.bin/ftp/cmds.c
+++ b/usr.bin/ftp/cmds.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: cmds.c,v 1.58 2008/05/13 02:09:38 ray Exp $ */
+/* $OpenBSD: cmds.c,v 1.59 2008/06/15 03:09:13 martynas Exp $ */
/* $NetBSD: cmds.c,v 1.27 1997/08/18 10:20:15 lukem Exp $ */
/*
@@ -60,7 +60,7 @@
*/
#if !defined(lint) && !defined(SMALL)
-static const char rcsid[] = "$OpenBSD: cmds.c,v 1.58 2008/05/13 02:09:38 ray Exp $";
+static const char rcsid[] = "$OpenBSD: cmds.c,v 1.59 2008/06/15 03:09:13 martynas Exp $";
#endif /* not lint and not SMALL */
/*
@@ -1259,8 +1259,10 @@ user(int argc, char *argv[])
if (argc < 4) {
(void)fputs("Account: ", ttyout);
(void)fflush(ttyout);
- if (fgets(acctname, sizeof(acctname), stdin) == NULL)
+ if (fgets(acctname, sizeof(acctname), stdin) == NULL) {
+ clearerr(stdin);
goto fail;
+ }
acctname[strcspn(acctname, "\n")] = '\0';
diff --git a/usr.bin/ftp/util.c b/usr.bin/ftp/util.c
index eb8452c4d43..99776bd2b02 100644
--- a/usr.bin/ftp/util.c
+++ b/usr.bin/ftp/util.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: util.c,v 1.48 2008/05/13 02:09:38 ray Exp $ */
+/* $OpenBSD: util.c,v 1.49 2008/06/15 03:09:13 martynas Exp $ */
/* $NetBSD: util.c,v 1.12 1997/08/18 10:20:27 lukem Exp $ */
/*-
@@ -71,7 +71,7 @@
*/
#if !defined(lint) && !defined(SMALL)
-static const char rcsid[] = "$OpenBSD: util.c,v 1.48 2008/05/13 02:09:38 ray Exp $";
+static const char rcsid[] = "$OpenBSD: util.c,v 1.49 2008/06/15 03:09:13 martynas Exp $";
#endif /* not lint and not SMALL */
/*
@@ -298,6 +298,8 @@ tryagain:
if (tmp[0] != '\0')
user = tmp;
}
+ else
+ exit(0);
}
n = command("USER %s", user);
if (n == CONTINUE) {
@@ -351,8 +353,10 @@ another(int *pargc, char ***pargv, const char *prompt)
}
fprintf(ttyout, "(%s) ", prompt);
line[len++] = ' ';
- if (fgets(&line[len], (int)(sizeof(line) - len), stdin) == NULL)
+ if (fgets(&line[len], (int)(sizeof(line) - len), stdin) == NULL) {
+ clearerr(stdin);
intr();
+ }
len += strlen(&line[len]);
if (len > 0 && line[len - 1] == '\n')
line[len - 1] = '\0';
@@ -459,13 +463,19 @@ confirm(const char *cmd, const char *file)
{
char str[BUFSIZ];
+ if (confirmrest == 2)
+ return (0);
+
if (!interactive || confirmrest)
return (1);
top:
fprintf(ttyout, "%s %s? ", cmd, file);
(void)fflush(ttyout);
- if (fgets(str, sizeof(str), stdin) == NULL)
+ if (fgets(str, sizeof(str), stdin) == NULL) {
+ confirmrest = 2;
+ clearerr(stdin);
return (0);
+ }
switch (tolower(*str)) {
case 'n':
return (0);