]> git.cameronkatri.com Git - bsdgames-darwin.git/blobdiff - worms/worms.c
Avoid common symbols. Use __dead.
[bsdgames-darwin.git] / worms / worms.c
index 23c0e178301882347685d4dc36e475f293204442..7b63d7bf40195bae62d4b7a613d6fb3f2de09567 100644 (file)
@@ -1,4 +1,4 @@
-/*     $NetBSD: worms.c,v 1.13 2004/01/27 20:30:31 jsm Exp $   */
+/*     $NetBSD: worms.c,v 1.23 2020/10/14 07:32:53 nia Exp $   */
 
 /*
  * Copyright (c) 1980, 1993
 
 #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.13 2004/01/27 20:30:31 jsm Exp $");
+__RCSID("$NetBSD: worms.c,v 1.23 2020/10/14 07:32:53 nia Exp $");
 #endif
 #endif /* not lint */
 
@@ -177,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(int, char **);
-void    nomem(void) __attribute__((__noreturn__));
-void    onsig(int);
+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;
@@ -196,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;
@@ -206,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;
@@ -237,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;
@@ -269,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);
 
@@ -291,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,
@@ -333,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.");
 }