]> git.cameronkatri.com Git - bsdgames-darwin.git/blobdiff - sail/assorted.c
Generate <>& symbolically. I'm avoiding .../dist/... directories for now.
[bsdgames-darwin.git] / sail / assorted.c
index 9b9c4124b44b8be3328045dd580efe7d95ca8f43..a03b12e5db0d7697c8591e82fba2c5128948f9ae 100644 (file)
@@ -1,6 +1,8 @@
+/*     $NetBSD: assorted.c,v 1.14 2001/02/05 01:10:08 christos 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
  * SUCH DAMAGE.
  */
 
+#include <sys/cdefs.h>
 #ifndef lint
-/*static char sccsid[] = "from: @(#)assorted.c 5.4 (Berkeley) 6/1/90";*/
-static char rcsid[] = "$Id: assorted.c,v 1.2 1993/08/01 18:51:53 mycroft Exp $";
+#if 0
+static char sccsid[] = "@(#)assorted.c 8.2 (Berkeley) 4/28/95";
+#else
+__RCSID("$NetBSD: assorted.c,v 1.14 2001/02/05 01:10:08 christos Exp $");
+#endif
 #endif /* not lint */
 
-#include "externs.h"
+#include <stdlib.h>
+#include <err.h>
+#include "extern.h"
+
+static void    strike (struct ship *, struct ship *);
 
-table(rig, shot, hittable, on, from, roll)
-struct ship *on, *from;
-int rig, shot, hittable, roll;
+void
+table(struct ship *from, struct ship *on, int rig, int shot, int hittable, int roll)
 {
-       register int hhits = 0, chits = 0, ghits = 0, rhits = 0;
+       int hhits = 0, chits = 0, ghits = 0, rhits = 0;
        int Ghit = 0, Hhit = 0, Rhit = 0, Chit = 0;
        int guns, car, pc, hull;
        int crew[3];
-       register int n;
+       int n;
        int rigg[4];
-       char *message;
-       struct Tables *tp;
+       const char *message;
+       const struct Tables *tp;
 
        pc = on->file->pcrew;
        hull = on->specs->hull;
@@ -102,7 +111,7 @@ int rig, shot, hittable, roll;
                rigg[3] -= rhits;
        }
        if (rig && !rigg[2] && (!rigg[3] || rigg[3] == -1))
-               makesignal(on, "dismasted!", (struct ship *)0);
+               makemsg(on, "dismasted!");
        if (portside(from, on, 0)) {
                guns = on->specs->gunR;
                car = on->specs->carR;
@@ -127,32 +136,36 @@ int rig, shot, hittable, roll;
        hull -= ghits;
        if (Ghit)
                Write(portside(from, on, 0) ? W_GUNR : W_GUNL,
-                       on, 0, guns, car, 0, 0);
+                       on, guns, car, 0, 0);
        hull -= hhits;
        hull = hull < 0 ? 0 : hull;
        if (on->file->captured != 0 && Chit)
-               Write(W_PCREW, on, 0, pc, 0, 0, 0);
+               Write(W_PCREW, on, pc, 0, 0, 0);
        if (Hhit)
-               Write(W_HULL, on, 0, hull, 0, 0, 0);
+               Write(W_HULL, on, hull, 0, 0, 0);
        if (Chit)
-               Write(W_CREW, on, 0, crew[0], crew[1], crew[2], 0);
+               Write(W_CREW, on, crew[0], crew[1], crew[2], 0);
        if (Rhit)
-               Write(W_RIGG, on, 0, rigg[0], rigg[1], rigg[2], rigg[3]);
+               Write(W_RIGG, on, rigg[0], rigg[1], rigg[2], rigg[3]);
        switch (shot) {
        case L_ROUND:
-               message = "firing round shot on %s (%c%c)";
+               message = "firing round shot on $$";
                break;
        case L_GRAPE:
-               message = "firing grape shot on %s (%c%c)";
+               message = "firing grape shot on $$";
                break;
        case L_CHAIN:
-               message = "firing chain shot on %s (%c%c)";
+               message = "firing chain shot on $$";
                break;
        case L_DOUBLE:
-               message = "firing double shot on %s (%c%c)";
+               message = "firing double shot on $$";
                break;
        case L_EXPLODE:
-               message = "exploding shot on %s (%c%c)";
+               message = "exploding shot on $$";
+               break;
+       default:
+               errx(1, "Unknown shot type %d", shot);
+
        }
        makesignal(from, message, on);
        if (roll == 6 && rig) {
@@ -178,8 +191,10 @@ int rig, shot, hittable, roll;
                case 7:
                        message = "main topmast and mizzen mast shattered";
                        break;
+               default:
+                       errx(1, "Bad Rhit = %d", Rhit);
                }
-               makesignal(on, message, (struct ship *)0);
+               makemsg(on, message);
        } else if (roll == 6) {
                switch (Hhit) {
                case 0:
@@ -199,41 +214,42 @@ int rig, shot, hittable, roll;
                        break;
                case 5:
                        message = "rudder cables shot through";
-                       Write(W_TA, on, 0, 0, 0, 0, 0);
+                       Write(W_TA, on, 0, 0, 0, 0);
                        break;
                case 6:
                        message = "shot holes below the water line";
                        break;
+               default:
+                       errx(1, "Bad Hhit = %d", Hhit);
                }
-               makesignal(on, message, (struct ship *)0);
+               makemsg(on, message);
        }
        /*
        if (Chit > 1 && on->file->readyL&R_INITIAL && on->file->readyR&R_INITIAL) {
                on->specs->qual--;
                if (on->specs->qual <= 0) {
-                       makesignal(on, "crew mutinying!", (struct ship *)0);
+                       makemsg(on, "crew mutinying!");
                        on->specs->qual = 5;
-                       Write(W_CAPTURED, on, 0, on->file->index, 0, 0, 0);
+                       Write(W_CAPTURED, on, on->file->index, 0, 0, 0);
                } else 
-                       makesignal(on, "crew demoralized", (struct ship *)0);
-               Write(W_QUAL, on, 0, on->specs->qual, 0, 0, 0);
+                       makemsg(on, "crew demoralized");
+               Write(W_QUAL, on, on->specs->qual, 0, 0, 0);
        }
        */
        if (!hull)
                strike(on, from);
 }
 
-Cleansnag(from, to, all, flag)
-register struct ship *from, *to;
-char all, flag;
+void
+Cleansnag(struct ship *from, struct ship *to, int all, int flag)
 {
        if (flag & 1) {
-               Write(W_UNGRAP, from, 0, to->file->index, all, 0, 0);
-               Write(W_UNGRAP, to, 0, from->file->index, all, 0, 0);
+               Write(W_UNGRAP, from, to->file->index, all, 0, 0);
+               Write(W_UNGRAP, to, from->file->index, all, 0, 0);
        }
        if (flag & 2) {
-               Write(W_UNFOUL, from, 0, to->file->index, all, 0, 0);
-               Write(W_UNFOUL, to, 0, from->file->index, all, 0, 0);
+               Write(W_UNFOUL, from, to->file->index, all, 0, 0);
+               Write(W_UNFOUL, to, from->file->index, all, 0, 0);
        }
        if (!snagged2(from, to)) {
                if (!snagged(from)) {
@@ -249,27 +265,27 @@ char all, flag;
        }
 }
 
-strike(ship, from)
-register struct ship *ship, *from;
+static void
+strike(struct ship *ship, struct ship *from)
 {
        int points;
 
        if (ship->file->struck)
                return;
-       Write(W_STRUCK, ship, 0, 1, 0, 0, 0);
+       Write(W_STRUCK, ship, 1, 0, 0, 0);
        points = ship->specs->pts + from->file->points;
-       Write(W_POINTS, from, 0, points, 0, 0, 0);
+       Write(W_POINTS, from, points, 0, 0, 0);
        unboard(ship, ship, 0);         /* all offense */
        unboard(ship, ship, 1);         /* all defense */
-       switch (die()) {
+       switch (dieroll()) {
        case 3:
        case 4:         /* ship may sink */
-               Write(W_SINK, ship, 0, 1, 0, 0, 0);
+               Write(W_SINK, ship, 1, 0, 0, 0);
                break;
        case 5:
        case 6:         /* ship may explode */
-               Write(W_EXPLODE, ship, 0, 1, 0, 0, 0);
+               Write(W_EXPLODE, ship, 1, 0, 0, 0);
                break;
        }
-       Write(W_SIGNAL, ship, 1, (int) "striking her colours!", 0, 0, 0);
+       Writestr(W_SIGNAL, ship, "striking her colours!");
 }