-/* $NetBSD: dr_3.c,v 1.11 2001/01/04 03:21:17 jwise Exp $ */
+/* $NetBSD: dr_3.c,v 1.19 2009/03/14 22:52:52 dholland 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[] = "@(#)dr_3.c 8.1 (Berkeley) 5/31/93";
#else
-__RCSID("$NetBSD: dr_3.c,v 1.11 2001/01/04 03:21:17 jwise Exp $");
+__RCSID("$NetBSD: dr_3.c,v 1.19 2009/03/14 22:52:52 dholland Exp $");
#endif
#endif /* not lint */
#include <stdlib.h>
+#include <string.h>
#include "extern.h"
#include "driver.h"
-void moveall(void);
-static int stillmoving(int);
-static int is_isolated(struct ship *);
-static int push(struct ship *, struct ship *);
-static void step(int, struct ship *, char *);
-void sendbp(struct ship *, struct ship *, int, int);
-int is_toughmelee(struct ship *, struct ship *, int, int);
-void reload(void);
-void checksails(void);
+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 (!sp->file->movebuf[k])
sp->file->movebuf[k+1] = '\0';
else if (sp->file->dir)
- step(sp->file->movebuf[k], sp, &moved[n]);
+ step(sp, sp->file->movebuf[k], &moved[n]);
n++;
}
/*
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++;
}
}
static void
-step(int com, struct ship *sp, char *moved)
+step(struct ship *sp, int com, char *moved)
{
int dist;
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);
}
}