]> git.cameronkatri.com Git - bsdgames-darwin.git/blobdiff - battlestar/com2.c
Don't try to wear anything that isn't OBJECT or NOUNS. Don't try to
[bsdgames-darwin.git] / battlestar / com2.c
index 96748eba4a83c757465ea5d21b944d05513fe491..634d4e3dd0aa2c56bf597595c678065c9df33fa1 100644 (file)
@@ -1,4 +1,4 @@
-/*     $NetBSD: com2.c,v 1.9 2000/09/10 10:51:16 jsm Exp $     */
+/*     $NetBSD: com2.c,v 1.12 2000/09/21 10:38:50 jsm Exp $    */
 
 /*
  * Copyright (c) 1983, 1993
@@ -38,7 +38,7 @@
 #if 0
 static char sccsid[] = "@(#)com2.c     8.2 (Berkeley) 4/28/95";
 #else
-__RCSID("$NetBSD: com2.c,v 1.9 2000/09/10 10:51:16 jsm Exp $");
+__RCSID("$NetBSD: com2.c,v 1.12 2000/09/21 10:38:50 jsm Exp $");
 #endif
 #endif                         /* not lint */
 
@@ -52,8 +52,11 @@ wearit()
 
        firstnumber = wordnumber;
        while (wordtype[++wordnumber] == ADJS);
-       while (wordnumber <= wordcount) {
+       while (wordnumber <= wordcount && (wordtype[wordnumber] == OBJECT ||
+           wordtype[wordnumber] == NOUNS) && wordvalue[wordnumber] != DOOR) {
                value = wordvalue[wordnumber];
+               if (objsht[value] == NULL)
+                       break;
                for (n = 0; objsht[value][n]; n++);
                switch (value) {
 
@@ -159,20 +162,16 @@ use()
                ourtime++;
                notes[CANTSEE] = 0;
                return (0);
-       } else
-               if (position == FINAL)
-                       puts("The amulet won't work in here.");
-               else
-                       if (wordvalue[wordnumber] == COMPASS && testbit(inven, COMPASS))
-                               printf("Your compass points %s.\n", truedirec(NORTH, '-'));
-                       else
-                               if (wordvalue[wordnumber] == COMPASS)
-                                       puts("You aren't holding the compass.");
-                               else
-                                       if (wordvalue[wordnumber] == AMULET)
-                                               puts("You aren't holding the amulet.");
-                                       else
-                                               puts("There is no apparent use.");
+       } else if (position == FINAL)
+               puts("The amulet won't work in here.");
+       else if (wordvalue[wordnumber] == COMPASS && testbit(inven, COMPASS))
+               printf("Your compass points %s.\n", truedirec(NORTH, '-'));
+       else if (wordvalue[wordnumber] == COMPASS)
+               puts("You aren't holding the compass.");
+       else if (wordvalue[wordnumber] == AMULET)
+               puts("You aren't holding the amulet.");
+       else
+               puts("There is no apparent use.");
        return (-1);
 }
 
@@ -182,9 +181,35 @@ murder()
        int     n;
 
        for (n = 0; !((n == SWORD || n == KNIFE || n == TWO_HANDED || n == MACE || n == CLEAVER || n == BROAD || n == CHAIN || n == SHOVEL || n == HALBERD) && testbit(inven, n)) && n < NUMOFOBJECTS; n++);
-       if (n == NUMOFOBJECTS)
-               puts("You don't have suitable weapons to kill.");
-       else {
+       if (n == NUMOFOBJECTS) {
+               if (testbit(inven, LASER)) {
+                       printf("Your laser should do the trick.\n");
+                       n = wordnumber;
+                       while (wordtype[++n] == ADJS)
+                               ;
+                       switch(wordvalue[n]) {
+                       case NORMGOD:
+                       case TIMER:
+                       case NATIVE:
+                       case MAN:
+                               wordvalue[wordnumber] = SHOOT;
+                               cypher();
+                               break;
+                       case -1:
+                               puts("Kill what?");
+                               break;
+                       default:
+                               if (wordtype[n] != OBJECT ||
+                                   wordvalue[wordnumber] == EVERYTHING)
+                                       puts("You can't kill that!");
+                               else
+                                       printf("You can't kill the %s!\n",
+                                           objsht[wordvalue[n]]);
+                               break;
+                       }
+               } else
+                       puts("You don't have suitable weapons to kill.");
+       } else {
                printf("Your %s should do the trick.\n", objsht[n]);
                while (wordtype[++wordnumber] == ADJS);
                switch (wordvalue[wordnumber]) {