]> git.cameronkatri.com Git - bsdgames-darwin.git/blobdiff - sail/dr_1.c
Create some abstraction for sending messages.
[bsdgames-darwin.git] / sail / dr_1.c
index 43c8642408f0f7e09668bfefa23c4bf3b3710f6c..3a332410a0e7fbb491a985b37890b104da341c3c 100644 (file)
@@ -1,6 +1,8 @@
+/*     $NetBSD: dr_1.c,v 1.27 2009/03/14 22:52:52 dholland Exp $       */
+
 /*
- * Copyright (c) 1983 Regents of the University of California.
- * All rights reserved.
+ * Copyright (c) 1983, 1993
+ *     The Regents of the University of California.  All rights reserved.
  *
  * Redistribution and use in source and binary forms, with or without
  * modification, are permitted provided that the following conditions
  * 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 sccsid[] = "from: @(#)dr_1.c     5.4 (Berkeley) 6/1/90";*/
-static char rcsid[] = "$Id: dr_1.c,v 1.2 1993/08/01 18:51:52 mycroft Exp $";
+#if 0
+static char sccsid[] = "@(#)dr_1.c     8.1 (Berkeley) 5/31/93";
+#else
+__RCSID("$NetBSD: dr_1.c,v 1.27 2009/03/14 22:52:52 dholland Exp $");
+#endif
 #endif /* not lint */
 
+#include <ctype.h>
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
+#include "extern.h"
 #include "driver.h"
 
-unfoul()
+static int fightitout(struct ship *, struct ship *, int);
+
+void
+unfoul(void)
 {
-       register struct ship *sp;
+       struct ship *sp;
        struct ship *to;
-       register int nat;
-       register i;
+       int nat;
+       int i;
 
        foreachship(sp) {
                if (sp->file->captain[0])
@@ -51,19 +61,20 @@ unfoul()
                nat = capship(sp)->nationality;
                foreachship(to) {
                        if (nat != capship(to)->nationality &&
-                           !toughmelee(sp, to, 0, 0))
+                           !is_toughmelee(sp, to, 0, 0))
                                continue;
                        for (i = fouled2(sp, to); --i >= 0;)
-                               if (die() <= 2)
+                               if (dieroll() <= 2)
                                        cleanfoul(sp, to, 0);
                }
        }
 }
 
-boardcomp()
+void
+boardcomp(void)
 {
        int crew[3];
-       register struct ship *sp, *sq;
+       struct ship *sp, *sq;
 
        foreachship(sp) {
                if (*sp->file->captain)
@@ -91,7 +102,7 @@ boardcomp()
                                        /* OBP */
                                        sendbp(sp, sq, crew[0]*100, 0);
                                        crew[0] = 0;
-                               } else if (crew[1]){
+                               } else if (crew[1]) {
                                        /* OBP */
                                        sendbp(sp, sq, crew[1]*10, 0);
                                        crew[1] = 0;
@@ -124,15 +135,14 @@ boardcomp()
        }
 }
 
-fightitout(from, to, key)
-struct ship *from, *to;
-int key;
+static int
+fightitout(struct ship *from, struct ship *to, int key)
 {
        struct ship *fromcap, *tocap;
        int crewfrom[3], crewto[3], menfrom, mento;
        int pcto, pcfrom, fromstrength, strengthto, frominjured, toinjured;
        int topoints;
-       int index, totalfrom = 0, totalto = 0;
+       int indx, totalfrom = 0, totalto = 0;
        int count;
        char message[60];
 
@@ -157,18 +167,18 @@ int key;
        fromstrength = menfrom * fromcap->specs->qual;
        strengthto = mento * tocap->specs->qual;
        for (count = 0;
-            (fromstrength < strengthto * 3 && strengthto < fromstrength * 3
+            ((fromstrength < strengthto * 3 && strengthto < fromstrength * 3)
              || fromstrength == -1) && count < 4;
             count++) {
-               index = fromstrength/10;
-               if (index > 8)
-                       index = 8;
-               toinjured = MT[index][2 - die() / 3];
+               indx = fromstrength/10;
+               if (indx > 8)
+                       indx = 8;
+               toinjured = MT[indx][2 - dieroll() / 3];
                totalto += toinjured;
-               index = strengthto/10;
-               if (index > 8)
-                       index = 8;
-               frominjured = MT[index][2 - die() / 3];
+               indx = strengthto/10;
+               if (indx > 8)
+                       indx = 8;
+               frominjured = MT[indx][2 - dieroll() / 3];
                totalfrom += frominjured;
                menfrom -= frominjured;
                mento -= toinjured;
@@ -177,47 +187,44 @@ int key;
        }
        if (fromstrength >= strengthto * 3 || count == 4) {
                unboard(to, from, 0);
-               subtract(from, totalfrom, crewfrom, fromcap, pcfrom);
-               subtract(to, totalto, crewto, tocap, pcto);
-               makesignal(from, "boarders from %s repelled", to);
-               (void) sprintf(message, "killed in melee: %d.  %s: %d",
+               subtract(from, fromcap, totalfrom, crewfrom, pcfrom);
+               subtract(to, tocap, totalto, crewto, pcto);
+               makemsg(from, "boarders from %s repelled", to->shipname);
+               snprintf(message, sizeof(message),
+                       "killed in melee: %d.  %s: %d",
                        totalto, from->shipname, totalfrom);
-               Write(W_SIGNAL, to, 1, (int) message, 0, 0, 0);
+               send_signal(to, message);
                if (key)
                        return 1;
        } else if (strengthto >= fromstrength * 3) {
                unboard(from, to, 0);
-               subtract(from, totalfrom, crewfrom, fromcap, pcfrom);
-               subtract(to, totalto, crewto, tocap, pcto);
+               subtract(from, fromcap, totalfrom, crewfrom, pcfrom);
+               subtract(to, tocap, totalto, crewto, pcto);
                if (key) {
                        if (fromcap != from)
-                               Write(W_POINTS, fromcap, 0,
+                               send_points(fromcap,
                                        fromcap->file->points -
                                                from->file->struck
                                                ? from->specs->pts
-                                               : 2 * from->specs->pts,
-                                       0, 0, 0);
+                                               : 2 * from->specs->pts);
 
-/* ptr1 points to the shipspec for the ship that was just unboarded.
-   I guess that what is going on here is that the pointer is multiplied
-   or something. */
-
-                       Write(W_CAPTURED, from, 0, to->file->index, 0, 0, 0);
+                       send_captured(from, to->file->index);
                        topoints = 2 * from->specs->pts + to->file->points;
                        if (from->file->struck)
                                topoints -= from->specs->pts;
-                       Write(W_POINTS, to, 0, topoints, 0, 0, 0);
+                       send_points(to, topoints);
                        mento = crewto[0] ? crewto[0] : crewto[1];
                        if (mento) {
-                               subtract(to, mento, crewto, tocap, pcto);
-                               subtract(from, - mento, crewfrom, to, 0);
+                               subtract(to, tocap, mento, crewto, pcto);
+                               subtract(from, to, - mento, crewfrom, 0);
                        }
-                       (void) sprintf(message, "captured by the %s!",
-                               to->shipname);
-                       Write(W_SIGNAL, from, 1, (int) message, 0, 0, 0);
-                       (void) sprintf(message, "killed in melee: %d.  %s: %d",
+                       snprintf(message, sizeof(message),
+                               "captured by the %s!", to->shipname);
+                       send_signal(from, message);
+                       snprintf(message, sizeof(message),
+                               "killed in melee: %d.  %s: %d",
                                totalto, from->shipname, totalfrom);
-                       Write(W_SIGNAL, to, 1, (int) message, 0, 0, 0);
+                       send_signal(to, message);
                        mento = 0;
                        return 0;
                }
@@ -225,17 +232,19 @@ int key;
        return 0;
 }
 
-resolve()
+void
+resolve(void)
 {
        int thwart;
-       register struct ship *sp, *sq;
+       struct ship *sp, *sq;
 
        foreachship(sp) {
                if (sp->file->dir == 0)
                        continue;
                for (sq = sp + 1; sq < ls; sq++)
-                       if (sq->file->dir && meleeing(sp, sq) && meleeing(sq, sp))
-                               (void) fightitout(sp, sq, 0);
+                       if (sq->file->dir && meleeing(sp, sq) &&
+                           meleeing(sq, sp))
+                               fightitout(sp, sq, 0);
                thwart = 2;
                foreachship(sq) {
                        if (sq->file->dir && meleeing(sq, sp))
@@ -255,14 +264,15 @@ resolve()
        }
 }
 
-compcombat()
+void
+compcombat(void)
 {
-       register n;
-       register struct ship *sp;
+       int n;
+       struct ship *sp;
        struct ship *closest;
        int crew[3], men = 0, target, temp;
        int r, guns, ready, load, car;
-       int index, rakehim, sternrake;
+       int indx, rakehim, sternrake;
        int shootat, hit;
 
        foreachship(sp) {
@@ -279,7 +289,7 @@ compcombat()
                        if (sp->file->DBP[n].turnsent)
                                men += sp->file->DBP[n].mensent;
                }
-               if (men){
+               if (men) {
                        crew[0] = men/100 ? 0 : crew[0] != 0;
                        crew[1] = (men%100)/10 ? 0 : crew[1] != 0;
                        crew[2] = men%10 ? 0 : crew[2] != 0;
@@ -305,7 +315,8 @@ compcombat()
                        closest = closestenemy(sp, r ? 'r' : 'l', 0);
                        if (closest == 0)
                                continue;
-                       if (range(closest, sp) > range(sp, closestenemy(sp, r ? 'r' : 'l', 1)))
+                       if (range(closest, sp) >
+                           range(sp, closestenemy(sp, r ? 'r' : 'l', 1)))
                                continue;
                        if (closest->file->struck)
                                continue;
@@ -334,40 +345,43 @@ compcombat()
                        if (temp > 8)
                                temp -= 8;
                        sternrake = temp > 4 && temp < 6;
-                       index = guns;
+                       indx = guns;
                        if (target < 3)
-                               index += car;
-                       index = (index - 1) / 3;
-                       index = index > 8 ? 8 : index;
+                               indx += car;
+                       indx = (indx - 1) / 3;
+                       indx = indx > 8 ? 8 : indx;
                        if (!rakehim)
-                               hit = HDT[index][target-1];
+                               hit = HDT[indx][target-1];
                        else
-                               hit = HDTrake[index][target-1];
+                               hit = HDTrake[indx][target-1];
                        if (rakehim && sternrake)
                                hit++;
-                       hit += QUAL[index][capship(sp)->specs->qual - 1];
-                       for (n = 0; n < 3 && sp->file->captured == 0; n++)
-                               if (!crew[n])
-                                       if (index <= 5)
+                       hit += QUAL[indx][capship(sp)->specs->qual - 1];
+                       for (n = 0; n < 3 && sp->file->captured == 0; n++) {
+                               if (!crew[n]) {
+                                       if (indx <= 5)
                                                hit--;
                                        else
                                                hit -= 2;
+                               }
+                       }
                        if (ready & R_INITIAL) {
                                if (!r)
                                        sp->file->readyL &= ~R_INITIAL;
                                else
                                        sp->file->readyR &= ~R_INITIAL;
-                               if (index <= 3)
+                               if (indx <= 3)
                                        hit++;
                                else
                                        hit += 2;
                        }
-                       if (sp->file->captured != 0)
-                               if (index <= 1)
+                       if (sp->file->captured != 0) {
+                               if (indx <= 1)
                                        hit--;
                                else
                                        hit -= 2;
-                       hit += AMMO[index][load - 1];
+                       }
+                       hit += AMMO[indx][load - 1];
                        temp = sp->specs->class;
                        if ((temp >= 5 || temp == 1) && windspeed == 5)
                                hit--;
@@ -378,22 +392,25 @@ compcombat()
                        if (hit >= 0) {
                                if (load != L_GRAPE)
                                        hit = hit > 10 ? 10 : hit;
-                               table(shootat, load, hit, closest, sp, die());
+                               table(sp, closest, shootat, load, hit,
+                                     dieroll());
                        }
                }
        }
 }
 
-next()
+int
+next(void)
 {
-       if (++turn % 55 == 0)
+       if (++turn % 55 == 0) {
                if (alive)
                        alive = 0;
                else
                        people = 0;
+       }
        if (people <= 0 || windspeed == 7) {
-               register struct ship *s;
-               struct ship *bestship;
+               struct ship *s;
+               struct ship *bestship = NULL;
                float net, best = 0.0;
                foreachship(s) {
                        if (*s->file->captain)
@@ -404,23 +421,24 @@ next()
                                bestship = s;
                        }
                }
-               if (best > 0.0) {
-                       char *p = getenv("WOTD");
-                       if (p == 0)
+               if (best > 0.0 && bestship) {
+                       char *tp = getenv("WOTD");
+                       const char *p;
+                       if (tp == 0)
                                p = "Driver";
-                       if (islower(*p))
-                               *p = toupper(*p);
-                       (void) strncpy(bestship->file->captain, p,
+                       else {
+                               *tp = toupper((unsigned char)*tp);
+                               p = tp;
+                       }
+                       strlcpy(bestship->file->captain, p,
                                sizeof bestship->file->captain);
-                       bestship->file->captain
-                               [sizeof bestship->file->captain - 1] = 0;
-                       log(bestship);
+                       logger(bestship);
                }
                return -1;
        }
-       Write(W_TURN, SHIP(0), 0, turn, 0, 0, 0);
-       if (turn % 7 == 0 && (die() >= cc->windchange || !windspeed)) {
-               switch (die()) {
+       send_turn(turn);
+       if (turn % 7 == 0 && (dieroll() >= cc->windchange || !windspeed)) {
+               switch (dieroll()) {
                case 1:
                        winddir = 1;
                        break;
@@ -444,7 +462,7 @@ next()
                if (winddir < 1)
                        winddir += 8;
                if (windspeed)
-                       switch (die()) {
+                       switch (dieroll()) {
                        case 1:
                        case 2:
                                windspeed--;
@@ -456,7 +474,7 @@ next()
                        }
                else
                        windspeed++;
-               Write(W_WIND, SHIP(0), 0, winddir, windspeed, 0, 0);
+               send_wind( winddir, windspeed);
        }
        return 0;
 }