]> git.cameronkatri.com Git - bsdgames-darwin.git/blobdiff - worms/worms.c
cgram: conform to lint's strict bool mode, KNF
[bsdgames-darwin.git] / worms / worms.c
index f56aaaf8325756357d44898bc7dc930309270fbc..7b63d7bf40195bae62d4b7a613d6fb3f2de09567 100644 (file)
@@ -1,4 +1,4 @@
-/*     $NetBSD: worms.c,v 1.11 1999/07/30 02:23:27 hubertf Exp $       */
+/*     $NetBSD: worms.c,v 1.23 2020/10/14 07:32:53 nia Exp $   */
 
 /*
  * Copyright (c) 1980, 1993
  * 2. Redistributions in binary form must reproduce the above copyright
  *    notice, this list of conditions and the following disclaimer in the
  *    documentation and/or other materials provided with the distribution.
- * 3. All advertising materials mentioning features or use of this software
- *    must display the following acknowledgement:
- *     This product includes software developed by the University of
- *     California, Berkeley and its contributors.
- * 4. Neither the name of the University nor the names of its contributors
+ * 3. Neither the name of the University nor the names of its contributors
  *    may be used to endorse or promote products derived from this software
  *    without specific prior written permission.
  *
 
 #include <sys/cdefs.h>
 #ifndef lint
-__COPYRIGHT("@(#) Copyright (c) 1980, 1993\n\
      The Regents of the University of California.  All rights reserved.\n");
+__COPYRIGHT("@(#) Copyright (c) 1980, 1993\
The Regents of the University of California.  All rights reserved.");
 #endif /* not lint */
 
 #ifndef lint
 #if 0
 static char sccsid[] = "@(#)worms.c    8.1 (Berkeley) 5/31/93";
 #else
-__RCSID("$NetBSD: worms.c,v 1.11 1999/07/30 02:23:27 hubertf Exp $");
+__RCSID("$NetBSD: worms.c,v 1.23 2020/10/14 07:32:53 nia Exp $");
 #endif
 #endif /* not lint */
 
@@ -181,16 +177,14 @@ static struct     worm {
        short *xpos, *ypos;
 } *worm;
 
-volatile sig_atomic_t sig_caught = 0;
+static volatile sig_atomic_t sig_caught = 0;
 
-int     main __P((int, char **));
-void    nomem __P((void)) __attribute__((__noreturn__));
-void    onsig __P((int));
+int     main(int, char **);
+static void nomem(void) __dead;
+static void onsig(int);
 
 int
-main(argc, argv)
-       int argc;
-       char *argv[];
+main(int argc, char *argv[])
 {
        int x, y, h, n;
        struct worm *w;
@@ -200,7 +194,7 @@ main(argc, argv)
        short **ref;
        const char *field;
        char *mp;
-       unsigned int delay = 0;
+       unsigned int delay = 20000;
 
        mp = NULL;
        length = 16;
@@ -210,7 +204,7 @@ main(argc, argv)
        while ((ch = getopt(argc, argv, "d:fl:n:t")) != -1)
                switch(ch) {
                case 'd':
-                       if ((delay = (unsigned int)strtoul(optarg, (char **)NULL, 10)) < 1 || delay > 1000)
+                       if ((delay = (unsigned int)strtoul(optarg, NULL, 10)) < 1 || delay > 1000)
                                errx(1, "invalid delay (1-1000)");
                        delay *= 1000;  /* ms -> us */
                        break;
@@ -241,7 +235,9 @@ main(argc, argv)
        if (!(worm = malloc((size_t)number *
            sizeof(struct worm))) || !(mp = malloc((size_t)1024)))
                nomem();
-       initscr();
+       if (!initscr())
+               errx(0, "couldn't initialize screen");
+       curs_set(0);
        CO = COLS;
        LI = LINES;
        last = CO - 1;
@@ -273,7 +269,6 @@ main(argc, argv)
        (void)signal(SIGHUP, onsig);
        (void)signal(SIGINT, onsig);
        (void)signal(SIGQUIT, onsig);
-       (void)signal(SIGSTOP, onsig);
        (void)signal(SIGTSTP, onsig);
        (void)signal(SIGTERM, onsig);
 
@@ -295,7 +290,12 @@ main(argc, argv)
                        endwin();
                        exit(0);
                }
-               if (delay) usleep(delay);
+               if (delay) {
+                       if (delay % 1000000 != 0)
+                               usleep(delay % 1000000);
+                       if (delay >= 1000000)
+                               sleep(delay / 1000000);
+               }
                for (n = 0, w = &worm[0]; n < number; n++, w++) {
                        if ((x = w->xpos[h = w->head]) < 0) {
                                mvaddch(y = w->ypos[h] = bottom,
@@ -337,15 +337,14 @@ main(argc, argv)
        }
 }
 
-void
-onsig(signo)
-       int signo __attribute__((__unused__));
+static void
+onsig(int signo __unused)
 {
        sig_caught = 1;
 }
 
-void
-nomem()
+static void
+nomem(void)
 {
        errx(1, "not enough memory.");
 }