]> git.cameronkatri.com Git - bsdgames-darwin.git/blobdiff - dm/dm.c
Add (unsigned char) cast to ctype functions
[bsdgames-darwin.git] / dm / dm.c
diff --git a/dm/dm.c b/dm/dm.c
index c994618aeca0a2c37cfa9a64f28cefe0055791da..c131904a81951f3e77510f7a294caa299fd889fb 100644 (file)
--- a/dm/dm.c
+++ b/dm/dm.c
@@ -1,4 +1,4 @@
-/*     $NetBSD: dm.c,v 1.6 1997/04/21 11:11:47 mrg Exp $       */
+/*     $NetBSD: dm.c,v 1.21 2004/11/05 21:30:32 dsl Exp $      */
 
 /*
  * Copyright (c) 1987, 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.
  *
  * SUCH DAMAGE.
  */
 
+#include <sys/cdefs.h>
 #ifndef lint
-static char copyright[] =
-"@(#) Copyright (c) 1987, 1993\n\
-       The Regents of the University of California.  All rights reserved.\n";
+__COPYRIGHT("@(#) Copyright (c) 1987, 1993\n\
+       The Regents of the University of California.  All rights reserved.\n");
 #endif /* not lint */
 
 #ifndef lint
 #if 0
 static char sccsid[] = "@(#)dm.c       8.1 (Berkeley) 5/31/93";
 #else
-static char rcsid[] = "$NetBSD: dm.c,v 1.6 1997/04/21 11:11:47 mrg Exp $";
+__RCSID("$NetBSD: dm.c,v 1.21 2004/11/05 21:30:32 dsl Exp $");
 #endif
 #endif /* not lint */
 
@@ -52,16 +48,17 @@ static char rcsid[] = "$NetBSD: dm.c,v 1.6 1997/04/21 11:11:47 mrg Exp $";
 #include <sys/time.h>
 #include <sys/resource.h>
 
+#include <err.h>
 #include <ctype.h>
-#include <nlist.h>
+#include <errno.h>
 #include <pwd.h>
 #include <stdio.h>
+#include <stdlib.h>
 #include <string.h>
 #include <time.h>
 #include <unistd.h>
-#include <utmp.h>
-#include <errno.h>
 
+#include "utmpentry.h"
 #include "pathnames.h"
 
 static time_t  now;                    /* current time value */
@@ -69,20 +66,32 @@ static int  priority = 0;           /* priority game runs at */
 static char    *game,                  /* requested game */
                *gametty;               /* from tty? */
 
+void   c_day(const char *, const char *, const char *);
+void   c_game(const char *, const char  *, const char *, const char *);
+void   c_tty(const char *);
+const char *hour(int);
+double load(void);
+int    main(int, char *[]);
+void   nogamefile(void);
+void   play(char **) __attribute__((__noreturn__));
+void   read_config(void);
+int    users(void);
+
 int
 main(argc, argv)
-       int argc;
+       int argc __attribute__((__unused__));
        char *argv[];
 {
        char *cp;
 
        nogamefile();
-       game = (cp = rindex(*argv, '/')) ? ++cp : *argv;
+       game = (cp = strrchr(*argv, '/')) ? ++cp : *argv;
 
        if (!strcmp(game, "dm"))
                exit(0);
 
        gametty = ttyname(0);
+       unsetenv("TZ");
        (void)time(&now);
        read_config();
 #ifdef LOG
@@ -90,33 +99,31 @@ main(argc, argv)
 #endif
        play(argv);
        /*NOTREACHED*/
+       return (0);
 }
 
 /*
  * play --
  *     play the game
  */
+void
 play(args)
        char **args;
 {
        char pbuf[MAXPATHLEN];
 
-       (void)strncpy(pbuf, _PATH_HIDE, sizeof(pbuf) - 1);
-       (void)strncpy(pbuf + sizeof(_PATH_HIDE) - 1, game,
-           sizeof(pbuf) - sizeof(_PATH_HIDE) - 1);
-       pbuf[sizeof(pbuf) - 1] = '\0';
+       snprintf(pbuf, sizeof(pbuf), "%s%s", _PATH_HIDE, game);
        if (priority > 0)       /* < 0 requires root */
                (void)setpriority(PRIO_PROCESS, 0, priority);
-       setgid(getgid());       /* we run setgid kmem; lose it */
        execv(pbuf, args);
-       (void)fprintf(stderr, "dm: %s: %s\n", pbuf, strerror(errno));
-       exit(1);
+       err(1, "%s", pbuf);
 }
 
 /*
  * read_config --
  *     read through config file, looking for key words.
  */
+void
 read_config()
 {
        FILE *cfp;
@@ -125,7 +132,7 @@ read_config()
        if (!(cfp = fopen(_PATH_CONFIG, "r")))
                return;
        while (fgets(lbuf, sizeof(lbuf), cfp))
-               switch(*lbuf) {
+               switch (*lbuf) {
                case 'b':               /* badtty */
                        if (sscanf(lbuf, "%s%s", f1, f2) != 2 ||
                            strcasecmp(f1, "badtty"))
@@ -151,10 +158,11 @@ read_config()
  * c_day --
  *     if day is today, see if okay to play
  */
+void
 c_day(s_day, s_start, s_stop)
-       char *s_day, *s_start, *s_stop;
+       const char *s_day, *s_start, *s_stop;
 {
-       static char *days[] = {
+       static const char *const days[] = {
                "sunday", "monday", "tuesday", "wednesday",
                "thursday", "friday", "saturday",
        };
@@ -165,17 +173,16 @@ c_day(s_day, s_start, s_stop)
                ct = localtime(&now);
        if (strcasecmp(s_day, days[ct->tm_wday]))
                return;
-       if (!isdigit(*s_start) || !isdigit(*s_stop))
+       if (!isdigit((unsigned char)*s_start) || !isdigit((unsigned char)*s_stop))
                return;
        start = atoi(s_start);
        stop = atoi(s_stop);
        if (ct->tm_hour >= start && ct->tm_hour < stop) {
-               fputs("dm: Sorry, games are not available from ", stderr);
-               hour(start);
-               fputs(" to ", stderr);
-               hour(stop);
-               fputs(" today.\n", stderr);
-               exit(0);
+               if (start == 0 && stop == 24)
+                       errx(0, "Sorry, games are not available today.");
+               else
+                       errx(0, "Sorry, games are not available from %s to %s today.",
+                            hour(start), hour(stop));
        }
 }
 
@@ -183,47 +190,42 @@ c_day(s_day, s_start, s_stop)
  * c_tty --
  *     decide if this tty can be used for games.
  */
+void
 c_tty(tty)
-       char *tty;
+       const char *tty;
 {
        static int first = 1;
        static char *p_tty;
 
        if (first) {
-               p_tty = rindex(gametty, '/');
+               p_tty = strrchr(gametty, '/');
                first = 0;
        }
 
-       if (!strcmp(gametty, tty) || p_tty && !strcmp(p_tty, tty)) {
-               fprintf(stderr, "dm: Sorry, you may not play games on %s.\n", gametty);
-               exit(0);
-       }
+       if (!strcmp(gametty, tty) || (p_tty && !strcmp(p_tty, tty)))
+               errx(1, "Sorry, you may not play games on %s.", gametty);
 }
 
 /*
  * c_game --
  *     see if game can be played now.
  */
+void
 c_game(s_game, s_load, s_users, s_priority)
-       char *s_game, *s_load, *s_users, *s_priority;
+       const char *s_game, *s_load, *s_users, *s_priority;
 {
        static int found;
-       double load();
 
        if (found)
                return;
        if (strcmp(game, s_game) && strcasecmp("default", s_game))
                return;
        ++found;
-       if (isdigit(*s_load) && atoi(s_load) < load()) {
-               fputs("dm: Sorry, the load average is too high right now.\n", stderr);
-               exit(0);
-       }
-       if (isdigit(*s_users) && atoi(s_users) <= users()) {
-               fputs("dm: Sorry, there are too many users logged on right now.\n", stderr);
-               exit(0);
-       }
-       if (isdigit(*s_priority))
+       if (isdigit((unsigned char)*s_load) && atoi(s_load) < load())
+               errx(0, "Sorry, the load average is too high right now.");
+       if (isdigit((unsigned char)*s_users) && atoi(s_users) <= users())
+               errx(0, "Sorry, there are too many users logged on right now.");
+       if (isdigit((unsigned char)*s_priority))
                priority = atoi(s_priority);
 }
 
@@ -236,11 +238,9 @@ load()
 {
        double avenrun[3];
 
-       if (getloadavg(avenrun, sizeof(avenrun)/sizeof(avenrun[0])) < 0) {
-               fputs("dm: getloadavg() failed.\n", stderr);
-               exit(1);
-       }
-       return(avenrun[2]);
+       if (getloadavg(avenrun, sizeof(avenrun)/sizeof(avenrun[0])) < 0)
+               err(1, "getloadavg() failed");
+       return (avenrun[2]);
 }
 
 /*
@@ -249,26 +249,25 @@ load()
  *     todo: check idle time; if idle more than X minutes, don't
  *     count them.
  */
+int
 users()
 {
-       
-       register int nusers, utmp;
-       struct utmp buf;
+       static struct utmpentry *ohead = NULL;  
+       struct utmpentry *ep;
+       int nusers;
 
-       if ((utmp = open(_PATH_UTMP, O_RDONLY, 0)) < 0) {
-               (void)fprintf(stderr, "dm: %s: %s\n",
-                   _PATH_UTMP, strerror(errno));
-               exit(1);
+       nusers = getutentries(NULL, &ep);
+       if (ep != ohead) {
+               freeutentries(ep);
+               ohead = ep;
        }
-       for (nusers = 0; read(utmp, (char *)&buf, sizeof(struct utmp)) > 0;)
-               if (buf.ut_name[0] != '\0')
-                       ++nusers;
-       return(nusers);
+       return nusers;
 }
 
+void
 nogamefile()
 {
-       register int fd, n;
+       int fd, n;
        char buf[BUFSIZ];
 
        if ((fd = open(_PATH_NOGAMES, O_RDONLY, 0)) >= 0) {
@@ -284,22 +283,20 @@ nogamefile()
  * hour --
  *     print out the hour in human form
  */
+const char *
 hour(h)
        int h;
 {
-       switch(h) {
-       case 0:
-               fputs("midnight", stderr);
-               break;
-       case 12:
-               fputs("noon", stderr);
-               break;
-       default:
-               if (h > 12)
-                       fprintf(stderr, "%dpm", h - 12);
-               else
-                       fprintf(stderr, "%dam", h);
-       }
+       static const char *const hours[] = {
+           "midnight", "1am", "2am", "3am", "4am", "5am",
+           "6am", "7am", "8am", "9am", "10am", "11am",
+           "noon", "1pm", "2pm", "3pm", "4pm", "5pm",
+           "6pm", "7pm", "8pm", "9pm", "10pm", "11pm", "midnight" };
+
+       if (h < 0 || h > 24)
+               return ("BAD TIME");
+       else
+               return (hours[h]);
 }
 
 #ifdef LOG
@@ -319,7 +316,7 @@ logfile()
                        if (!flock(fileno(lp), LOCK_EX))
                                break;
                        if (lock_cnt == 4) {
-                               perror("dm: log lock");
+                               warnx("log lock");
                                (void)fclose(lp);
                                return;
                        }