-/* $NetBSD: dr_3.c,v 1.15 2003/08/07 09:37:42 agc Exp $ */
+/* $NetBSD: dr_3.c,v 1.19 2009/03/14 22:52:52 dholland Exp $ */
/*
* Copyright (c) 1983, 1993
#if 0
static char sccsid[] = "@(#)dr_3.c 8.1 (Berkeley) 5/31/93";
#else
-__RCSID("$NetBSD: dr_3.c,v 1.15 2003/08/07 09:37:42 agc Exp $");
+__RCSID("$NetBSD: dr_3.c,v 1.19 2009/03/14 22:52:52 dholland Exp $");
#endif
#endif /* not lint */
#include "extern.h"
#include "driver.h"
-static int stillmoving(int);
-static int is_isolated(struct ship *);
-static int push(struct ship *, struct ship *);
-static void step(struct ship *, int, char *);
+static int stillmoving(int);
+static int is_isolated(struct ship *);
+static int push(struct ship *, struct ship *);
+static void step(struct ship *, int, char *);
/* move all comp ships */
void
foreachship(sp) {
struct ship *closest;
int ma, ta;
- char af;
+ bool af;
if (sp->file->captain[0] || sp->file->dir == 0)
continue;
*sp->file->movebuf = '\0';
else
closeon(sp, closest, sp->file->movebuf,
+ sizeof(sp->file->movebuf),
ta, ma, af);
} else
*sp->file->movebuf = '\0';
if (dieroll() < 4) {
makesignal(sp, "fouled with $$",
sq);
- Write(W_FOUL, sp, l, 0, 0, 0);
- Write(W_FOUL, sq, n, 0, 0, 0);
+ send_foul(sp, l);
+ send_foul(sq, n);
}
snap++;
}
if (sp->file->dir != 0) {
*sp->file->movebuf = 0;
if (row[n] != sp->file->row)
- Write(W_ROW, sp, sp->file->row, 0, 0, 0);
+ send_row(sp, sp->file->row);
if (col[n] != sp->file->col)
- Write(W_COL, sp, sp->file->col, 0, 0, 0);
+ send_col(sp, sp->file->col);
if (dir[n] != sp->file->dir)
- Write(W_DIR, sp, sp->file->dir, 0, 0, 0);
+ send_dir(sp, sp->file->dir);
if (drift[n] != sp->file->drift)
- Write(W_DRIFT, sp, sp->file->drift, 0, 0, 0);
+ send_drift(sp, sp->file->drift);
}
n++;
}
sp->file->row -= dr[winddir];
sp->file->col -= dc[winddir];
}
- } else
+ } else {
sp->file->drift = 0;
+ }
break;
}
}
for (n = 0; n < NBP && bp[n].turnsent; n++)
;
if (n < NBP && sections) {
- Write(isdefense ? W_DBP : W_OBP, from,
- n, turn, to->file->index, sections);
+ if (isdefense) {
+ send_dbp(from, n, turn, to->file->index, sections);
+ } else {
+ send_obp(from, n, turn, to->file->index, sections);
+ }
if (isdefense)
makemsg(from, "repelling boarders");
else
checksails(void)
{
struct ship *sp;
- int rig, full;
+ int rig, full;
struct ship *close;
foreachship(sp) {
full = 1;
else
full = 0;
- } else
+ } else {
full = 0;
- } else
+ }
+ } else {
full = 0;
+ }
if ((sp->file->FS != 0) != full)
- Write(W_FS, sp, full, 0, 0, 0);
+ send_fs(sp, full);
}
}