diff options
author | Michael I. Bushnell <mib@gnu.org> | 1994-10-14 20:48:19 +0000 |
---|---|---|
committer | Michael I. Bushnell <mib@gnu.org> | 1994-10-14 20:48:19 +0000 |
commit | ecf2027d408e47c5be3c4a920fbd8c3ba01b6c08 (patch) | |
tree | 3d1d8c55ea54a008ca8a3ea71e8d4304eb61c668 | |
parent | 49105ac78372aa88489857e625e56e7d37698462 (diff) |
Formerly utilities.c.~4~
-rw-r--r-- | ufs-fsck/utilities.c | 87 |
1 files changed, 87 insertions, 0 deletions
diff --git a/ufs-fsck/utilities.c b/ufs-fsck/utilities.c index c80cfd57..7dacaa95 100644 --- a/ufs-fsck/utilities.c +++ b/ufs-fsck/utilities.c @@ -22,6 +22,7 @@ #include <fcntl.h> #include <sys/file.h> #include <unistd.h> +#include <stdarg.h> /* Read disk block ADDR into BUF of SIZE bytes. */ void @@ -145,3 +146,89 @@ check_range (daddr_t blk, int cnt) return 0; } +/* Like printf, but exit if we are preening. */ +int +pfatal (char *fmt, ...) +{ + va_list args; + int ret; + + va_start (args, fmt); + ret = vprintf (fmt, args); + va_end (args); + putchar ('\n'); + if (preen) + exit (1); + + return ret; +} + +/* Like printf, but exit after printing. */ +void +errexit (char *fmt, ...) +{ + va_list args; + + va_start (args, fmt); + vprintf (fmt, args); + va_end (args); + exit (1); +} + +/* Like printf, but give more information (when we fully support it) + when preening. */ +int +pwarn (char *fmt, ...) +{ + va_list args; + int ret; + + va_start (args, fmt); + ret = vprintf (fmt, args); + va_end (args); + return ret; +} + +/* Ask the user a question; return 1 if the user says yes, and 0 + if the user says no. */ +int +reply (char *question) +{ + int persevere; + char c; + + if (preen) + pfatal ("INTERNAL ERROR: GOT TO reply ()"); + + persevere = !strcmp (question, "CONTINUE"); + putchar ('\n'); + if (!persevere && (nowrite || writefd < 0)) + { + printf ("%s? no\n\n", question); + return 0; + } + else if (noquery || (persevere && nowrite)) + { + printf ("%s? yes\n\n", question); + return 1; + } + else + { + do + { + printf ("%s? [yn] ", question); + fflush (stdout); + c = getchar (); + while (c != '\n' && getchar () != '\n') + if (feof (stdin)) + return 0; + } + while (c != 'y' && c != 'Y' && c != 'n' && c != 'N'); + putchar ('\n'); + return c == 'y' || c == 'Y'; + } +} + + + + |