]> git.cameronkatri.com Git - bsdgames-darwin.git/blobdiff - quiz/quiz.c
deprecate register, fixup .Nm usage
[bsdgames-darwin.git] / quiz / quiz.c
index 1d0b1d851aee3de601d88f806a6387117b53fd4c..a2463b1252360ef8eec9c48e1152f04b95246fbf 100644 (file)
@@ -1,3 +1,5 @@
+/*     $NetBSD: quiz.c,v 1.12 1997/09/20 14:28:18 lukem Exp $  */
+
 /*-
  * Copyright (c) 1991, 1993
  *     The Regents of the University of California.  All rights reserved.
  * SUCH DAMAGE.
  */
 
+#include <sys/cdefs.h>
 #ifndef lint
-static char copyright[] =
-"@(#) Copyright (c) 1991, 1993\n\
-       The Regents of the University of California.  All rights reserved.\n";
+__COPYRIGHT("@(#) Copyright (c) 1991, 1993\n\
+       The Regents of the University of California.  All rights reserved.\n");
 #endif /* not lint */
 
 #ifndef lint
-static char sccsid[] = "@(#)quiz.c     8.2 (Berkeley) 1/3/94";
+#if 0
+static char sccsid[] = "@(#)quiz.c     8.3 (Berkeley) 5/4/95";
+#else
+__RCSID("$NetBSD: quiz.c,v 1.12 1997/09/20 14:28:18 lukem Exp $");
+#endif
 #endif /* not lint */
 
 #include <sys/types.h>
+
+#include <ctype.h>
 #include <errno.h>
-#include <time.h>
 #include <stdio.h>
 #include <stdlib.h>
 #include <string.h>
 #include <ctype.h>
 #include <err.h>
+#include <time.h>
+#include <unistd.h>
 #include "quiz.h"
 #include "pathnames.h"
 
@@ -64,6 +73,7 @@ char  *appdstr __P((char *, char *, size_t));
 void    downcase __P((char *));
 void    get_cats __P((char *, char *));
 void    get_file __P((char *));
+int     main __P((int, char *[]));
 char   *next_cat __P((char *));
 void    quiz __P((void));
 void    score __P((u_int, u_int, u_int));
@@ -75,11 +85,11 @@ main(argc, argv)
        int argc;
        char *argv[];
 {
-       register int ch;
+       int ch;
        char *indexfile;
 
        indexfile = _PATH_QUIZIDX;
-       while ((ch = getopt(argc, argv, "i:t")) != EOF)
+       while ((ch = getopt(argc, argv, "i:t")) != -1)
                switch(ch) {
                case 'i':
                        indexfile = optarg;
@@ -114,8 +124,8 @@ void
 get_file(file)
        char *file;
 {
-       register FILE *fp;
-       register QE *qp;
+       FILE *fp;
+       QE *qp;
        size_t len;
        char *lp;
 
@@ -130,15 +140,18 @@ get_file(file)
        qp = &qlist;
        qsize = 0;
        while ((lp = fgetln(fp, &len)) != NULL) {
-               lp[--len] = '\0';
+               if (lp[len - 1] == '\n')
+                       lp[--len] = '\0';
                if (qp->q_text && qp->q_text[strlen(qp->q_text) - 1] == '\\')
                        qp->q_text = appdstr(qp->q_text, lp, len);
                else {
                        if ((qp->q_next = malloc(sizeof(QE))) == NULL)
-                               err(1, NULL);
+                               errx(1, "malloc");
                        qp = qp->q_next;
-                       if ((qp->q_text = strdup(lp)) == NULL)
-                               err(1, NULL);
+                       if ((qp->q_text = malloc(len + 1)) == NULL)
+                               errx(1, "malloc");
+                       strncpy(qp->q_text, lp, len);
+                       qp->q_text[len] = '\0';
                        qp->q_asked = qp->q_answered = FALSE;
                        qp->q_next = NULL;
                        ++qsize;
@@ -150,8 +163,8 @@ get_file(file)
 void
 show_index()
 {
-       register QE *qp;
-       register char *p, *s;
+       QE *qp;
+       char *p, *s;
        FILE *pf;
 
        if ((pf = popen(_PATH_PAGER, "w")) == NULL)
@@ -161,7 +174,7 @@ show_index()
                for (s = next_cat(qp->q_text); s; s = next_cat(s)) {
                        if (!rxp_compile(s))
                                errx(1, "%s", rxperr);
-                       if (p = rxp_expand())
+                       if ((p = rxp_expand()) != NULL)
                                (void)fprintf(pf, "%s ", p);
                }
                (void)fprintf(pf, "\n");
@@ -177,7 +190,7 @@ void
 get_cats(cat1, cat2)
        char *cat1, *cat2;
 {
-       register QE *qp;
+       QE *qp;
        int i;
        char *s;
 
@@ -209,8 +222,8 @@ get_cats(cat1, cat2)
 void
 quiz()
 {
-       register QE *qp;
-       register int i;
+       QE *qp;
+       int i;
        size_t len;
        u_int guesses, rights, wrongs;
        int next;
@@ -262,7 +275,8 @@ quiz()
                qp->q_asked = TRUE;
                (void)printf("%s?\n", question);
                for (;; ++guesses) {
-                       if ((answer = fgetln(stdin, &len)) == NULL) {
+                       if ((answer = fgetln(stdin, &len)) == NULL ||
+                           answer[len - 1] != '\n') {
                                score(rights, wrongs, guesses);
                                exit(0);
                        }
@@ -289,16 +303,24 @@ quiz()
 
 char *
 next_cat(s)
-       register char * s;
+       char *  s;
 {
+       int esc;
+
+       esc = 0;
        for (;;)
                switch (*s++) {
                case '\0':
                        return (NULL);
                case '\\':
+                       esc = 1;
                        break;
                case ':':
-                       return (s);
+                       if (!esc)
+                               return (s);
+               default:
+                       esc = 0;
+                       break;
                }
        /* NOTREACHED */
 }
@@ -306,21 +328,23 @@ next_cat(s)
 char *
 appdstr(s, tp, len)
        char *s;
-       register char *tp;
+       char *tp;
        size_t len;
 {
-       register char *mp, *sp;
-       register int ch;
+       char *mp, *sp;
+       int ch;
        char *m;
 
        if ((m = malloc(strlen(s) + len + 1)) == NULL)
-               err(1, NULL);
-       for (mp = m, sp = s; *mp++ = *sp++;);
+               errx(1, "malloc");
+       for (mp = m, sp = s; (*mp++ = *sp++) != NULL; )
+               ;
        --mp;
        if (*(mp - 1) == '\\')
                --mp;
 
-       while ((ch = *mp++ = *tp++) && ch != '\n');
+       while ((ch = *mp++ = *tp++) && ch != '\n')
+               ;
        *mp = '\0';
 
        free(s);
@@ -339,11 +363,11 @@ score(r, w, g)
 
 void
 downcase(p)
-       register char *p;
+       char *p;
 {
-       register int ch;
+       int ch;
 
-       for (; ch = *p; ++p)
+       for (; (ch = *p) != '\0'; ++p)
                if (isascii(ch) && isupper(ch))
                        *p = tolower(ch);
 }