-/* $NetBSD: assorted.c,v 1.11 2001/01/04 01:53:24 jwise Exp $ */
+/* $NetBSD: assorted.c,v 1.19 2011/08/16 11:26:16 christos Exp $ */
/*
* Copyright (c) 1983, 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.
*
#if 0
static char sccsid[] = "@(#)assorted.c 8.2 (Berkeley) 4/28/95";
#else
-__RCSID("$NetBSD: assorted.c,v 1.11 2001/01/04 01:53:24 jwise Exp $");
+__RCSID("$NetBSD: assorted.c,v 1.19 2011/08/16 11:26:16 christos Exp $");
#endif
#endif /* not lint */
-#include "extern.h"
#include <stdlib.h>
-#include <unistd.h>
#include <err.h>
+#include "extern.h"
-void table(int, int, int, struct ship *, struct ship *, int);
-void Cleansnag(struct ship *, struct ship *, int, int);
-static void strike (struct ship *, struct ship *);
+static void strike(struct ship *, struct ship *);
void
-table(int rig, int shot, int hittable, struct ship *on, struct ship *from, int roll)
+table(struct ship *from, struct ship *on,
+ int rig, int shot, int hittable, int roll)
{
int hhits = 0, chits = 0, ghits = 0, rhits = 0;
int Ghit = 0, Hhit = 0, Rhit = 0, Chit = 0;
rigg[1] = on->specs->rig2;
rigg[2] = on->specs->rig3;
rigg[3] = on->specs->rig4;
- if (shot == L_GRAPE)
+ if (shot == L_GRAPE) {
Chit = chits = hittable;
- else {
+ } else {
tp = &(rig ? RigTable : HullTable)[hittable][roll-1];
Chit = chits = tp->C;
Rhit = rhits = tp->R;
pc -= (chits + 1) / 2;
chits /= 2;
}
- for (n = 0; n < 3; n++)
+ for (n = 0; n < 3; n++) {
if (chits > crew[n]) {
chits -= crew[n];
crew[n] = 0;
crew[n] -= chits;
chits = 0;
}
- for (n = 0; n < 3; n++)
- if (rhits > rigg[n]){
+ }
+ for (n = 0; n < 3; n++) {
+ if (rhits > rigg[n]) {
rhits -= rigg[n];
rigg[n] = 0;
} else {
rigg[n] -= rhits;
rhits = 0;
}
+ }
if (rigg[3] != -1 && rhits > rigg[3]) {
rhits -= rigg[3];
rigg[3] = 0;
car -= ghits;
ghits = 0;
}
- if (ghits > guns){
+ if (ghits > guns) {
ghits -= guns;
guns = 0;
} else {
ghits = 0;
}
hull -= ghits;
- if (Ghit)
- Write(portside(from, on, 0) ? W_GUNR : W_GUNL,
- on, guns, car, 0, 0);
+ if (Ghit) {
+ if (portside(from, on, 0)) {
+ send_gunr(on, guns, car);
+ } else {
+ send_gunl(on, guns, car);
+ }
+ }
hull -= hhits;
hull = hull < 0 ? 0 : hull;
if (on->file->captured != 0 && Chit)
- Write(W_PCREW, on, pc, 0, 0, 0);
+ send_pcrew(on, pc);
if (Hhit)
- Write(W_HULL, on, hull, 0, 0, 0);
+ send_hull(on, hull);
if (Chit)
- Write(W_CREW, on, crew[0], crew[1], crew[2], 0);
+ send_crew(on, crew[0], crew[1], crew[2]);
if (Rhit)
- Write(W_RIGG, on, rigg[0], rigg[1], rigg[2], rigg[3]);
+ send_rigg(on, rigg[0], rigg[1], rigg[2], rigg[3]);
switch (shot) {
case L_ROUND:
- message = "firing round shot on $$";
+ message = "firing round";
break;
case L_GRAPE:
- message = "firing grape shot on $$";
+ message = "firing grape";
break;
case L_CHAIN:
- message = "firing chain shot on $$";
+ message = "firing chain";
break;
case L_DOUBLE:
- message = "firing double shot on $$";
+ message = "firing double";
break;
case L_EXPLODE:
- message = "exploding shot on $$";
+ message = "exploding";
break;
default:
errx(1, "Unknown shot type %d", shot);
}
- makesignal(from, message, on);
+ makesignal(from, "%s shot on $$", on, message);
if (roll == 6 && rig) {
switch(Rhit) {
case 0:
default:
errx(1, "Bad Rhit = %d", Rhit);
}
- makemsg(on, message);
+ makemsg(on, "%s", message);
} else if (roll == 6) {
switch (Hhit) {
case 0:
break;
case 5:
message = "rudder cables shot through";
- Write(W_TA, on, 0, 0, 0, 0);
+ send_ta(on, 0);
break;
case 6:
message = "shot holes below the water line";
default:
errx(1, "Bad Hhit = %d", Hhit);
}
- makemsg(on, message);
+ makemsg(on, "%s", message);
}
/*
- if (Chit > 1 && on->file->readyL&R_INITIAL && on->file->readyR&R_INITIAL) {
+ if (Chit > 1 && on->file->readyL & R_INITIAL &&
+ on->file->readyR & R_INITIAL) {
on->specs->qual--;
if (on->specs->qual <= 0) {
makemsg(on, "crew mutinying!");
on->specs->qual = 5;
Write(W_CAPTURED, on, on->file->index, 0, 0, 0);
- } else
+ } else {
makemsg(on, "crew demoralized");
+ }
Write(W_QUAL, on, on->specs->qual, 0, 0, 0);
}
*/
Cleansnag(struct ship *from, struct ship *to, int all, int flag)
{
if (flag & 1) {
- Write(W_UNGRAP, from, to->file->index, all, 0, 0);
- Write(W_UNGRAP, to, from->file->index, all, 0, 0);
+ send_ungrap(from, to->file->index, all);
+ send_ungrap(to, from->file->index, all);
}
if (flag & 2) {
- Write(W_UNFOUL, from, to->file->index, all, 0, 0);
- Write(W_UNFOUL, to, from->file->index, all, 0, 0);
+ send_unfoul(from, to->file->index, all);
+ send_unfoul(to, from->file->index, all);
}
if (!snagged2(from, to)) {
if (!snagged(from)) {
if (ship->file->struck)
return;
- Write(W_STRUCK, ship, 1, 0, 0, 0);
+ send_struck(ship, 1);
points = ship->specs->pts + from->file->points;
- Write(W_POINTS, from, points, 0, 0, 0);
+ send_points(from, points);
unboard(ship, ship, 0); /* all offense */
unboard(ship, ship, 1); /* all defense */
switch (dieroll()) {
case 3:
case 4: /* ship may sink */
- Write(W_SINK, ship, 1, 0, 0, 0);
+ send_sink(ship, 1);
break;
case 5:
case 6: /* ship may explode */
- Write(W_EXPLODE, ship, 1, 0, 0, 0);
+ send_explode(ship, 1);
break;
}
- Writestr(W_SIGNAL, ship, "striking her colours!");
+ send_signal(ship, "striking her colours!");
}