summaryrefslogtreecommitdiff
path: root/games/hunt/huntd/execute.c
diff options
context:
space:
mode:
Diffstat (limited to 'games/hunt/huntd/execute.c')
-rw-r--r--games/hunt/huntd/execute.c305
1 files changed, 180 insertions, 125 deletions
diff --git a/games/hunt/huntd/execute.c b/games/hunt/huntd/execute.c
index 53695c72f88..8719f63dac3 100644
--- a/games/hunt/huntd/execute.c
+++ b/games/hunt/huntd/execute.c
@@ -1,24 +1,27 @@
+/* $OpenBSD: execute.c,v 1.3 1999/01/29 07:30:35 d Exp $ */
/* $NetBSD: execute.c,v 1.2 1997/10/10 16:33:13 lukem Exp $ */
-/* $OpenBSD: execute.c,v 1.2 1999/01/21 05:47:40 d Exp $ */
/*
* Hunt
* Copyright (c) 1985 Conrad C. Huang, Gregory S. Couch, Kenneth C.R.C. Arnold
* San Francisco, California
*/
-# include <stdlib.h>
-# include "hunt.h"
+#include <stdlib.h>
+#include <string.h>
+#include <syslog.h>
+#include "hunt.h"
+#include "conf.h"
+#include "server.h"
-static void cloak __P((PLAYER *));
-static void face __P((PLAYER *, int));
-static void fire __P((PLAYER *, int));
-static void fire_slime __P((PLAYER *, int));
-static void move_player __P((PLAYER *, int));
-static void pickup __P((PLAYER *, int, int, int, int));
-static void scan __P((PLAYER *));
+static void cloak __P((PLAYER *));
+static void face __P((PLAYER *, int));
+static void fire __P((PLAYER *, int));
+static void fire_slime __P((PLAYER *, int));
+static void move_player __P((PLAYER *, int));
+static void pickup __P((PLAYER *, int, int, int, int));
+static void scan __P((PLAYER *));
-# ifdef MONITOR
/*
* mon_execute:
* Execute a single monitor command
@@ -30,20 +33,24 @@ mon_execute(pp)
char ch;
ch = pp->p_cbuf[pp->p_ncount++];
+
switch (ch) {
case CTRL('L'):
+ /* Redraw messed-up screen */
sendcom(pp, REDRAW);
break;
case 'q':
- (void) strcpy(pp->p_death, "| Quit |");
+ /* Quit client */
+ (void) strlcpy(pp->p_death, "| Quit |", sizeof pp->p_death);
break;
+ default:
+ /* Ignore everything else */
}
}
-# endif
/*
* execute:
- * Execute a single command
+ * Execute a single command from a player
*/
void
execute(pp)
@@ -53,47 +60,48 @@ execute(pp)
ch = pp->p_cbuf[pp->p_ncount++];
-# ifdef FLY
+ /* When flying, only allow refresh and quit. */
if (pp->p_flying >= 0) {
switch (ch) {
case CTRL('L'):
sendcom(pp, REDRAW);
break;
case 'q':
- (void) strcpy(pp->p_death, "| Quit |");
+ (void) strlcpy(pp->p_death, "| Quit |",
+ sizeof pp->p_death);
break;
}
return;
}
-# endif
+ /* Decode the command character: */
switch (ch) {
case CTRL('L'):
- sendcom(pp, REDRAW);
+ sendcom(pp, REDRAW); /* Refresh */
break;
case 'h':
- move_player(pp, LEFTS);
+ move_player(pp, LEFTS); /* Move left */
break;
case 'H':
- face(pp, LEFTS);
+ face(pp, LEFTS); /* Face left */
break;
case 'j':
- move_player(pp, BELOW);
+ move_player(pp, BELOW); /* Move down */
break;
case 'J':
- face(pp, BELOW);
+ face(pp, BELOW); /* Face down */
break;
case 'k':
- move_player(pp, ABOVE);
+ move_player(pp, ABOVE); /* Move up */
break;
case 'K':
- face(pp, ABOVE);
+ face(pp, ABOVE); /* Face up */
break;
case 'l':
- move_player(pp, RIGHT);
+ move_player(pp, RIGHT); /* Move right */
break;
case 'L':
- face(pp, RIGHT);
+ face(pp, RIGHT); /* Face right */
break;
case 'f':
case '1':
@@ -132,7 +140,6 @@ execute(pp)
case '@':
fire(pp, 10); /* 21x21 BOMB */
break;
-# ifdef OOZE
case 'o':
fire_slime(pp, 0); /* SLIME */
break;
@@ -140,27 +147,26 @@ execute(pp)
fire_slime(pp, 1); /* SSLIME */
break;
case 'p':
- fire_slime(pp, 2);
+ fire_slime(pp, 2); /* large slime */
break;
case 'P':
- fire_slime(pp, 3);
+ fire_slime(pp, 3); /* very large slime */
break;
-# endif
- case 's':
+ case 's': /* start scanning */
scan(pp);
break;
- case 'c':
+ case 'c': /* start cloaking */
cloak(pp);
break;
- case 'q':
- (void) strcpy(pp->p_death, "| Quit |");
+ case 'q': /* quit */
+ (void) strlcpy(pp->p_death, "| Quit |", sizeof pp->p_death);
break;
}
}
/*
* move_player:
- * Execute a move in the given direction
+ * Try to move player 'pp' in direction 'dir'.
*/
static void
move_player(pp, dir)
@@ -191,73 +197,78 @@ move_player(pp, dir)
}
moved = FALSE;
+
+ /* What would the player move over: */
switch (Maze[y][x]) {
+ /* Players can move through spaces and doors, no problem: */
case SPACE:
-# ifdef RANDOM
case DOOR:
-# endif
moved = TRUE;
break;
+ /* Can't move through walls: */
case WALL1:
case WALL2:
case WALL3:
-# ifdef REFLECT
case WALL4:
case WALL5:
-# endif
break;
+ /* Moving over a mine - try to pick it up: */
case MINE:
case GMINE:
if (dir == pp->p_face)
- pickup(pp, y, x, 2, Maze[y][x]);
+ /* facing it: 2% chance of trip */
+ pickup(pp, y, x, conf_ptrip_face, Maze[y][x]);
else if (opposite(dir, pp->p_face))
- pickup(pp, y, x, 95, Maze[y][x]);
+ /* facing away: 95% chance of trip */
+ pickup(pp, y, x, conf_ptrip_back, Maze[y][x]);
else
- pickup(pp, y, x, 50, Maze[y][x]);
+ /* facing sideways: 50% chance of trip */
+ pickup(pp, y, x, conf_ptrip_side, Maze[y][x]);
+ /* Remove the mine: */
Maze[y][x] = SPACE;
moved = TRUE;
break;
+ /* Moving into a bullet: */
case SHOT:
case GRENADE:
case SATCHEL:
case BOMB:
-# ifdef OOZE
case SLIME:
-# endif
-# ifdef DRONE
case DSHOT:
-# endif
+ /* Find which bullet: */
bp = is_bullet(y, x);
if (bp != NULL)
+ /* Detonate it: */
bp->b_expl = TRUE;
+ /* Remove it: */
Maze[y][x] = SPACE;
moved = TRUE;
break;
+ /* Moving into another player: */
case LEFTS:
case RIGHT:
case ABOVE:
case BELOW:
if (dir != pp->p_face)
+ /* Can't walk backwards/sideways into another player: */
sendcom(pp, BELL);
else {
+ /* Stab the other player */
newp = play_at(y, x);
- checkdam(newp, pp, pp->p_ident, STABDAM, KNIFE);
+ checkdam(newp, pp, pp->p_ident, conf_stabdam, KNIFE);
}
break;
-# ifdef FLY
+ /* Moving into a player flying overhead: */
case FLYER:
newp = play_at(y, x);
message(newp, "Oooh, there's a short guy waving at you!");
message(pp, "You couldn't quite reach him!");
break;
-# endif
-# ifdef BOOTS
- case BOOT:
+ /* Picking up a boot, or two: */
case BOOT_PAIR:
- if (Maze[y][x] == BOOT)
- pp->p_nboots++;
- else
- pp->p_nboots += 2;
+ pp->p_nboots++;
+ case BOOT:
+ pp->p_nboots++;
for (newp = Boot; newp < &Boot[NBOOTS]; newp++) {
if (newp->p_flying < 0)
continue;
@@ -274,22 +285,27 @@ move_player(pp, dir)
Maze[y][x] = SPACE;
moved = TRUE;
break;
-# endif
}
+
+ /* Can the player be moved? */
if (moved) {
+ /* Check the gun status: */
if (pp->p_ncshot > 0)
- if (--pp->p_ncshot == MAXNCSHOT) {
- cgoto(pp, STAT_GUN_ROW, STAT_VALUE_COL);
- outstr(pp, " ok", 3);
- }
+ if (--pp->p_ncshot == conf_maxncshot)
+ outyx(pp, STAT_GUN_ROW, STAT_VALUE_COL, " ok");
+ /* Check for bullets flying past: */
if (pp->p_undershot) {
fixshots(pp->p_y, pp->p_x, pp->p_over);
pp->p_undershot = FALSE;
}
+ /* Erase the player: */
drawplayer(pp, FALSE);
+ /* Save under: */
pp->p_over = Maze[y][x];
+ /* Move the player: */
pp->p_y = y;
pp->p_x = x;
+ /* Draw the player in their new position */
drawplayer(pp, TRUE);
}
}
@@ -320,44 +336,41 @@ fire(pp, req_index)
{
if (pp == NULL)
return;
-# ifdef DEBUG
- if (req_index < 0 || req_index >= MAXBOMB)
- message(pp, "What you do?");
-# endif
+
+ /* Drop the shot type down until we can afford it: */
while (req_index >= 0 && pp->p_ammo < shot_req[req_index])
req_index--;
+
+ /* Can we shoot at all? */
if (req_index < 0) {
message(pp, "Not enough charges.");
return;
}
- if (pp->p_ncshot > MAXNCSHOT)
+
+ /* Check if the gun is too hot: */
+ if (pp->p_ncshot > conf_maxncshot)
return;
- if (pp->p_ncshot++ == MAXNCSHOT) {
- cgoto(pp, STAT_GUN_ROW, STAT_VALUE_COL);
- outstr(pp, " ", 3);
+
+ /* Heat up the gun: */
+ if (pp->p_ncshot++ == conf_maxncshot) {
+ /* The gun has overheated: */
+ outyx(pp, STAT_GUN_ROW, STAT_VALUE_COL, " ");
}
+
+ /* Use up some ammo: */
pp->p_ammo -= shot_req[req_index];
- (void) sprintf(Buf, "%3d", pp->p_ammo);
- cgoto(pp, STAT_AMMO_ROW, STAT_VALUE_COL);
- outstr(pp, Buf, 3);
+ ammo_update(pp);
+ /* Start the bullet moving: */
add_shot(shot_type[req_index], pp->p_y, pp->p_x, pp->p_face,
shot_req[req_index], pp, FALSE, pp->p_face);
pp->p_undershot = TRUE;
- /*
- * Show the object to everyone
- */
+ /* Show the bullet to everyone: */
showexpl(pp->p_y, pp->p_x, shot_type[req_index]);
- for (pp = Player; pp < End_player; pp++)
- sendcom(pp, REFRESH);
-# ifdef MONITOR
- for (pp = Monitor; pp < End_monitor; pp++)
- sendcom(pp, REFRESH);
-# endif
+ sendcom(ALL_PLAYERS, REFRESH);
}
-# ifdef OOZE
/*
* fire_slime:
* Fire a slime shot in the given direction
@@ -369,43 +382,44 @@ fire_slime(pp, req_index)
{
if (pp == NULL)
return;
-# ifdef DEBUG
- if (req_index < 0 || req_index >= MAXSLIME)
- message(pp, "What you do?");
-# endif
+
+ /* Check configuration: */
+ if (!conf_ooze)
+ return;
+
+ /* Drop the slime type back util we can afford it: */
while (req_index >= 0 && pp->p_ammo < slime_req[req_index])
req_index--;
+
+ /* Can we afford to slime at all? */
if (req_index < 0) {
message(pp, "Not enough charges.");
return;
}
- if (pp->p_ncshot > MAXNCSHOT)
+
+ /* Is the gun too hot? */
+ if (pp->p_ncshot > conf_maxncshot)
return;
- if (pp->p_ncshot++ == MAXNCSHOT) {
- cgoto(pp, STAT_GUN_ROW, STAT_VALUE_COL);
- outstr(pp, " ", 3);
+
+ /* Heat up the gun: */
+ if (pp->p_ncshot++ == conf_maxncshot) {
+ /* The gun has overheated: */
+ outyx(pp, STAT_GUN_ROW, STAT_VALUE_COL, " ");
}
+
+ /* Use up some ammo: */
pp->p_ammo -= slime_req[req_index];
- (void) sprintf(Buf, "%3d", pp->p_ammo);
- cgoto(pp, STAT_AMMO_ROW, STAT_VALUE_COL);
- outstr(pp, Buf, 3);
+ ammo_update(pp);
+ /* Start the slime moving: */
add_shot(SLIME, pp->p_y, pp->p_x, pp->p_face,
- slime_req[req_index] * SLIME_FACTOR, pp, FALSE, pp->p_face);
+ slime_req[req_index] * conf_slimefactor, pp, FALSE, pp->p_face);
pp->p_undershot = TRUE;
- /*
- * Show the object to everyone
- */
+ /* Show the object to everyone: */
showexpl(pp->p_y, pp->p_x, SLIME);
- for (pp = Player; pp < End_player; pp++)
- sendcom(pp, REFRESH);
-# ifdef MONITOR
- for (pp = Monitor; pp < End_monitor; pp++)
- sendcom(pp, REFRESH);
-# endif
+ sendcom(ALL_PLAYERS, REFRESH);
}
-# endif
/*
* add_shot:
@@ -413,17 +427,18 @@ fire_slime(pp, req_index)
*/
void
add_shot(type, y, x, face, charge, owner, expl, over)
-int type;
-int y, x;
-char face;
-int charge;
-PLAYER *owner;
-int expl;
-char over;
+ int type;
+ int y, x;
+ char face;
+ int charge;
+ PLAYER *owner;
+ int expl;
+ char over;
{
BULLET *bp;
int size;
+ /* Determine the bullet's size based on its type and charge: */
switch (type) {
case SHOT:
case MINE:
@@ -447,12 +462,20 @@ char over;
break;
}
+ /* Create the bullet: */
bp = create_shot(type, y, x, face, charge, size, owner,
(owner == NULL) ? NULL : owner->p_ident, expl, over);
+
+ /* Insert the bullet into the front of the bullet list: */
bp->b_next = Bullets;
Bullets = bp;
}
+/*
+ * create_shot:
+ * allocate storage for an (unlinked) bullet structure;
+ * initialize and return it
+ */
BULLET *
create_shot(type, y, x, face, charge, size, owner, score, expl, over)
int type;
@@ -469,6 +492,7 @@ create_shot(type, y, x, face, charge, size, owner, score, expl, over)
bp = (BULLET *) malloc(sizeof (BULLET)); /* NOSTRICT */
if (bp == NULL) {
+ syslog(LOG_ERR, "malloc: %m");
if (owner != NULL)
message(owner, "Out of memory");
return NULL;
@@ -497,25 +521,34 @@ static void
cloak(pp)
PLAYER *pp;
{
+ /* Check configuration: */
+ if (!conf_cloak)
+ return;
+
+ /* Can we afford it?: */
if (pp->p_ammo <= 0) {
message(pp, "No more charges");
return;
}
-# ifdef BOOTS
+
+ /* Can't cloak with boots: */
if (pp->p_nboots > 0) {
message(pp, "Boots are too noisy to cloak!");
return;
}
-# endif
- (void) sprintf(Buf, "%3d", --pp->p_ammo);
- cgoto(pp, STAT_AMMO_ROW, STAT_VALUE_COL);
- outstr(pp, Buf, 3);
- pp->p_cloak += CLOAKLEN;
+ /* Consume a unit of ammo: */
+ pp->p_ammo--;
+ ammo_update(pp);
+
+ /* Add to the duration of a cloak: */
+ pp->p_cloak += conf_cloaklen;
+ /* Disable scan, if enabled: */
if (pp->p_scan >= 0)
pp->p_scan = -1;
+ /* Re-draw the player's scan/cloak status: */
showstat(pp);
}
@@ -527,27 +560,36 @@ static void
scan(pp)
PLAYER *pp;
{
+ /* Check configuration: */
+ if (!conf_scan)
+ return;
+
+ /* Can we afford it?: */
if (pp->p_ammo <= 0) {
message(pp, "No more charges");
return;
}
- (void) sprintf(Buf, "%3d", --pp->p_ammo);
- cgoto(pp, STAT_AMMO_ROW, STAT_VALUE_COL);
- outstr(pp, Buf, 3);
- pp->p_scan += SCANLEN;
+ /* Consume one unit of ammo: */
+ pp->p_ammo--;
+ ammo_update(pp);
+
+ /* Increase the scan time: */
+ pp->p_scan += Nplayer * conf_scanlen;
+ /* Disable cloak, if enabled: */
if (pp->p_cloak >= 0)
pp->p_cloak = -1;
+ /* Re-draw the player's scan/cloak status: */
showstat(pp);
}
/*
* pickup:
- * check whether the object blew up or whether he picked it up
+ * pick up a mine or grenade, with some probability of it exploding
*/
-void
+static void
pickup(pp, y, x, prob, obj)
PLAYER *pp;
int y, x;
@@ -556,6 +598,7 @@ pickup(pp, y, x, prob, obj)
{
int req;
+ /* Figure out how much ammo the player is trying to pick up: */
switch (obj) {
case MINE:
req = BULREQ;
@@ -564,15 +607,27 @@ pickup(pp, y, x, prob, obj)
req = GRENREQ;
break;
default:
+#ifdef DIAGNOSTIC
abort();
+#endif
+ return;
}
+
+ /* Does it explode? */
if (rand_num(100) < prob)
+ /* Ooooh, unlucky: (Boom) */
add_shot(obj, y, x, LEFTS, req, (PLAYER *) NULL,
TRUE, pp->p_face);
else {
+ /* Safely picked it up. Add to player's ammo: */
pp->p_ammo += req;
- (void) sprintf(Buf, "%3d", pp->p_ammo);
- cgoto(pp, STAT_AMMO_ROW, STAT_VALUE_COL);
- outstr(pp, Buf, 3);
+ ammo_update(pp);
}
}
+
+void
+ammo_update(pp)
+ PLAYER *pp;
+{
+ outyx(pp, STAT_AMMO_ROW, STAT_VALUE_COL - 1, "%4d", pp->p_ammo);
+}