]> git.cameronkatri.com Git - bsdgames-darwin.git/blobdiff - battlestar/com6.c
Use defined constant FINAL instead of hardcoded 275. From OpenBSD.
[bsdgames-darwin.git] / battlestar / com6.c
index 50939f8eaf4814aeacbb346f27c25e8285a11c77..5f4c8562e5f61fe9d8f4b496942a0a326768142b 100644 (file)
@@ -1,4 +1,4 @@
-/*     $NetBSD: com6.c,v 1.11 1999/07/21 03:56:53 hubertf Exp $        */
+/*     $NetBSD: com6.c,v 1.20 2000/09/24 14:20:24 jsm Exp $    */
 
 /*
  * Copyright (c) 1983, 1993
@@ -38,7 +38,7 @@
 #if 0
 static char sccsid[] = "@(#)com6.c     8.2 (Berkeley) 4/28/95";
 #else
-__RCSID("$NetBSD: com6.c,v 1.11 1999/07/21 03:56:53 hubertf Exp $");
+__RCSID("$NetBSD: com6.c,v 1.20 2000/09/24 14:20:24 jsm Exp $");
 #endif
 #endif                         /* not lint */
 
@@ -92,7 +92,7 @@ die()
 
 void
 diesig(dummy)
-       int     dummy;
+       int     dummy __attribute__((__unused__));
 {
        die();
 }
@@ -113,26 +113,26 @@ open_score_file()
        score_fp = fopen(_PATH_SCORE, "a");
        if (score_fp == NULL)
                warn("open %s for append", _PATH_SCORE);
+       if (score_fp != NULL && fileno(score_fp) < 3)
+               exit(1);
 }
 
 void
 post(ch)
        char    ch;
 {
-       struct timeval tv;
-       time_t tvsec;
+       time_t tv;
        char   *date;
        sigset_t sigset, osigset;
 
        sigemptyset(&sigset);
        sigaddset(&sigset, SIGINT);
        sigprocmask(SIG_BLOCK, &sigset, &osigset);
-       gettimeofday(&tv, (struct timezone *) 0);       /* can't call time */
-       tvsec = (time_t) tv.tv_sec;
-       date = ctime(&tvsec);
+       tv = time(NULL);
+       date = ctime(&tv);
        date[24] = '\0';
        if (score_fp != NULL) {
-               fprintf(score_fp, "%s  %8s  %c%20s", date, uname, ch, rate());
+               fprintf(score_fp, "%s  %8s  %c%20s", date, username, ch, rate());
                if (wiz)
                        fprintf(score_fp, "   wizard\n");
                else
@@ -153,41 +153,33 @@ rate()
        if (score == pleasure) {
                if (score < 5)
                        return ("novice");
+               else if (score < 20)
+                       return ("junior voyeur");
+               else if (score < 35)
+                       return ("Don Juan");
                else
-                       if (score < 20)
-                               return ("junior voyeur");
-                       else
-                               if (score < 35)
-                                       return ("Don Juan");
-                               else
-                                       return ("Marquis De Sade");
-       } else
-               if (score == power) {
-                       if (score < 5)
-                               return ("serf");
-                       else
-                               if (score < 8)
-                                       return ("Samurai");
-                               else
-                                       if (score < 13)
-                                               return ("Klingon");
-                                       else
-                                               if (score < 22)
-                                                       return ("Darth Vader");
-                                               else
-                                                       return ("Sauron the Great");
-               } else {
-                       if (score < 5)
-                               return ("Polyanna");
-                       else
-                               if (score < 10)
-                                       return ("philanthropist");
-                               else
-                                       if (score < 20)
-                                               return ("Tattoo");
-                                       else
-                                               return ("Mr. Roarke");
-               }
+                       return ("Marquis De Sade");
+       } else if (score == power) {
+               if (score < 5)
+                       return ("serf");
+               else if (score < 8)
+                       return ("Samurai");
+               else if (score < 13)
+                       return ("Klingon");
+               else if (score < 22)
+                       return ("Darth Vader");
+               else
+                       return ("Sauron the Great");
+       } else {
+               if (score < 5)
+                       return ("Polyanna");
+               else if (score < 10)
+                       return ("philanthropist");
+               else if (score < 20)
+                       return ("Tattoo");
+               else
+                       return ("Mr. Roarke");
+       }
 }
 
 int
@@ -212,20 +204,19 @@ ride()
 {
        if (testbit(location[position].objects, HORSE)) {
                puts("You climb onto the stallion and kick it in the guts.  The stupid steed launches");
-               puts("forward through bush and fern.  You are thrown and the horse gallups off.");
+               puts("forward through bush and fern.  You are thrown and the horse gallops off.");
                clearbit(location[position].objects, HORSE);
-               while (!(position = rnd(NUMOFROOMS + 1)) || !OUTSIDE || !beenthere[position] || location[position].flyhere);
+               while (!(position = rnd(NUMOFROOMS + 1)) || !OUTSIDE || !beenthere[position] || location[position].flyhere)
+                       continue;
                setbit(location[position].objects, HORSE);
                if (location[position].north)
                        position = location[position].north;
+               else if (location[position].south)
+                       position = location[position].south;
+               else if (location[position].east)
+                       position = location[position].east;
                else
-                       if (location[position].south)
-                               position = location[position].south;
-                       else
-                               if (location[position].east)
-                                       position = location[position].east;
-                               else
-                                       position = location[position].west;
+                       position = location[position].west;
                return (0);
        } else
                puts("There is no horse here.");
@@ -248,3 +239,36 @@ light()
        } else
                puts("You're out of matches.");
 }
+
+void
+dooropen()
+{                              /* synonyms = {open, unlock} */
+       wordnumber++;
+       if (wordnumber <= wordcount && wordtype[wordnumber] == NOUNS
+           && wordvalue[wordnumber] == DOOR) {
+               switch(position) {
+               case 189:
+               case 231:
+                       if (location[189].north == 231)
+                               puts("The door is already open.");
+                       else
+                               puts("The door does not budge.");
+                       break;
+               case 30:
+                       if (location[30].west == 25)
+                               puts("The door is gone.");
+                       else
+                               puts("The door is locked tight.");
+                       break;
+               case 31:
+                       puts("That's one immovable door.");
+                       break;
+               case 20:
+                       puts("The door is already ajar.");
+                       break;
+               default:
+                       puts("What door?");
+               }
+       } else
+               puts("That doesn't open.");
+}