Home | History | Annotate | Line # | Download | only in trek
kill.c revision 1.7.40.1
      1  1.7.40.1       jym /*	$NetBSD: kill.c,v 1.7.40.1 2009/05/13 19:18:08 jym Exp $	*/
      2       1.3       cgd 
      3       1.1       cgd /*
      4       1.3       cgd  * Copyright (c) 1980, 1993
      5       1.3       cgd  *	The Regents of the University of California.  All rights reserved.
      6       1.1       cgd  *
      7       1.1       cgd  * Redistribution and use in source and binary forms, with or without
      8       1.1       cgd  * modification, are permitted provided that the following conditions
      9       1.1       cgd  * are met:
     10       1.1       cgd  * 1. Redistributions of source code must retain the above copyright
     11       1.1       cgd  *    notice, this list of conditions and the following disclaimer.
     12       1.1       cgd  * 2. Redistributions in binary form must reproduce the above copyright
     13       1.1       cgd  *    notice, this list of conditions and the following disclaimer in the
     14       1.1       cgd  *    documentation and/or other materials provided with the distribution.
     15       1.7       agc  * 3. Neither the name of the University nor the names of its contributors
     16       1.1       cgd  *    may be used to endorse or promote products derived from this software
     17       1.1       cgd  *    without specific prior written permission.
     18       1.1       cgd  *
     19       1.1       cgd  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
     20       1.1       cgd  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
     21       1.1       cgd  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
     22       1.1       cgd  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
     23       1.1       cgd  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
     24       1.1       cgd  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
     25       1.1       cgd  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
     26       1.1       cgd  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
     27       1.1       cgd  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
     28       1.1       cgd  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
     29       1.1       cgd  * SUCH DAMAGE.
     30       1.1       cgd  */
     31       1.1       cgd 
     32       1.4  christos #include <sys/cdefs.h>
     33       1.1       cgd #ifndef lint
     34       1.3       cgd #if 0
     35       1.3       cgd static char sccsid[] = "@(#)kill.c	8.1 (Berkeley) 5/31/93";
     36       1.3       cgd #else
     37  1.7.40.1       jym __RCSID("$NetBSD: kill.c,v 1.7.40.1 2009/05/13 19:18:08 jym Exp $");
     38       1.3       cgd #endif
     39       1.1       cgd #endif /* not lint */
     40       1.1       cgd 
     41       1.4  christos #include <stdio.h>
     42  1.7.40.1       jym #include <limits.h>
     43       1.4  christos #include "trek.h"
     44       1.1       cgd 
     45       1.1       cgd /*
     46       1.1       cgd **  KILL KILL KILL !!!
     47       1.1       cgd **
     48       1.1       cgd **	This file handles the killing off of almost anything.
     49       1.1       cgd */
     50       1.1       cgd 
     51       1.1       cgd /*
     52       1.1       cgd **  Handle a Klingon's death
     53       1.1       cgd **
     54       1.1       cgd **	The Klingon at the sector given by the parameters is killed
     55       1.1       cgd **	and removed from the Klingon list.  Notice that it is not
     56       1.1       cgd **	removed from the event list; this is done later, when the
     57       1.1       cgd **	the event is to be caught.  Also, the time left is recomputed,
     58       1.1       cgd **	and the game is won if that was the last klingon.
     59       1.1       cgd */
     60       1.1       cgd 
     61       1.4  christos void
     62       1.1       cgd killk(ix, iy)
     63       1.1       cgd int	ix, iy;
     64       1.1       cgd {
     65       1.4  christos 	int		i;
     66       1.1       cgd 
     67       1.1       cgd 	printf("   *** Klingon at %d,%d destroyed ***\n", ix, iy);
     68       1.1       cgd 
     69       1.1       cgd 	/* remove the scoundrel */
     70       1.1       cgd 	Now.klings -= 1;
     71       1.1       cgd 	Sect[ix][iy] = EMPTY;
     72       1.1       cgd 	Quad[Ship.quadx][Ship.quady].klings -= 1;
     73       1.1       cgd 	/* %%% IS THIS SAFE???? %%% */
     74       1.1       cgd 	Quad[Ship.quadx][Ship.quady].scanned -= 100;
     75       1.1       cgd 	Game.killk += 1;
     76       1.1       cgd 
     77       1.1       cgd 	/* find the Klingon in the Klingon list */
     78       1.1       cgd 	for (i = 0; i < Etc.nkling; i++)
     79       1.1       cgd 		if (ix == Etc.klingon[i].x && iy == Etc.klingon[i].y)
     80       1.1       cgd 		{
     81       1.1       cgd 			/* purge him from the list */
     82       1.1       cgd 			Etc.nkling -= 1;
     83       1.1       cgd 			for (; i < Etc.nkling; i++)
     84       1.4  christos 				Etc.klingon[i] = Etc.klingon[i+1];
     85       1.1       cgd 			break;
     86       1.1       cgd 		}
     87       1.1       cgd 
     88       1.1       cgd 	/* find out if that was the last one */
     89       1.1       cgd 	if (Now.klings <= 0)
     90       1.1       cgd 		win();
     91       1.1       cgd 
     92       1.1       cgd 	/* recompute time left */
     93       1.1       cgd 	Now.time = Now.resource / Now.klings;
     94       1.1       cgd 	return;
     95       1.1       cgd }
     96       1.1       cgd 
     97       1.1       cgd 
     98       1.1       cgd /*
     99       1.1       cgd **  handle a starbase's death
    100       1.1       cgd */
    101       1.1       cgd 
    102       1.4  christos void
    103       1.1       cgd killb(qx, qy)
    104       1.1       cgd int	qx, qy;
    105       1.1       cgd {
    106       1.4  christos 	struct quad	*q;
    107       1.4  christos 	struct xy	*b;
    108       1.1       cgd 
    109       1.1       cgd 	q = &Quad[qx][qy];
    110       1.1       cgd 
    111       1.1       cgd 	if (q->bases <= 0)
    112       1.1       cgd 		return;
    113       1.5     veego 	if (!damaged(SSRADIO)) {
    114       1.1       cgd 		/* then update starchart */
    115       1.1       cgd 		if (q->scanned < 1000)
    116       1.1       cgd 			q->scanned -= 10;
    117       1.1       cgd 		else
    118       1.1       cgd 			if (q->scanned > 1000)
    119       1.1       cgd 				q->scanned = -1;
    120       1.5     veego 	}
    121       1.1       cgd 	q->bases = 0;
    122       1.1       cgd 	Now.bases -= 1;
    123       1.1       cgd 	for (b = Now.base; ; b++)
    124       1.1       cgd 		if (qx == b->x && qy == b->y)
    125       1.1       cgd 			break;
    126       1.4  christos 	*b = Now.base[Now.bases];
    127       1.1       cgd 	if (qx == Ship.quadx && qy == Ship.quady)
    128       1.1       cgd 	{
    129       1.1       cgd 		Sect[Etc.starbase.x][Etc.starbase.y] = EMPTY;
    130       1.1       cgd 		if (Ship.cond == DOCKED)
    131       1.4  christos 			undock(0);
    132       1.1       cgd 		printf("Starbase at %d,%d destroyed\n", Etc.starbase.x, Etc.starbase.y);
    133       1.1       cgd 	}
    134       1.1       cgd 	else
    135       1.1       cgd 	{
    136       1.1       cgd 		if (!damaged(SSRADIO))
    137       1.1       cgd 		{
    138       1.1       cgd 			printf("Uhura: Starfleet command reports that the starbase in\n");
    139       1.1       cgd 			printf("   quadrant %d,%d has been destroyed\n", qx, qy);
    140       1.1       cgd 		}
    141       1.1       cgd 		else
    142  1.7.40.1       jym 			schedule(E_KATSB | E_GHOST, TOOLARGE, qx, qy, 0);
    143       1.1       cgd 	}
    144       1.1       cgd }
    145       1.1       cgd 
    146       1.1       cgd 
    147       1.1       cgd /**
    148       1.1       cgd  **	kill an inhabited starsystem
    149       1.1       cgd  **/
    150       1.1       cgd 
    151       1.4  christos void
    152       1.1       cgd kills(x, y, f)
    153       1.1       cgd int	x, y;	/* quad coords if f == 0, else sector coords */
    154       1.1       cgd int	f;	/* f != 0 -- this quad;  f < 0 -- Enterprise's fault */
    155       1.1       cgd {
    156       1.4  christos 	struct quad	*q;
    157       1.4  christos 	struct event	*e;
    158       1.6   hubertf 	const char	*name;
    159       1.1       cgd 
    160       1.1       cgd 	if (f)
    161       1.1       cgd 	{
    162       1.1       cgd 		/* current quadrant */
    163       1.1       cgd 		q = &Quad[Ship.quadx][Ship.quady];
    164       1.1       cgd 		Sect[x][y] = EMPTY;
    165       1.1       cgd 		name = systemname(q);
    166       1.1       cgd 		if (name == 0)
    167       1.1       cgd 			return;
    168       1.1       cgd 		printf("Inhabited starsystem %s at %d,%d destroyed\n",
    169       1.1       cgd 			name, x, y);
    170       1.1       cgd 		if (f < 0)
    171       1.1       cgd 			Game.killinhab += 1;
    172       1.1       cgd 	}
    173       1.1       cgd 	else
    174       1.1       cgd 	{
    175       1.1       cgd 		/* different quadrant */
    176       1.1       cgd 		q = &Quad[x][y];
    177       1.1       cgd 	}
    178       1.1       cgd 	if (q->qsystemname & Q_DISTRESSED)
    179       1.1       cgd 	{
    180       1.1       cgd 		/* distressed starsystem */
    181       1.1       cgd 		e = &Event[q->qsystemname & Q_SYSTEM];
    182       1.1       cgd 		printf("Distress call for %s invalidated\n",
    183       1.1       cgd 			Systemname[e->systemname]);
    184       1.1       cgd 		unschedule(e);
    185       1.1       cgd 	}
    186       1.1       cgd 	q->qsystemname = 0;
    187       1.1       cgd 	q->stars -= 1;
    188       1.1       cgd }
    189       1.1       cgd 
    190       1.1       cgd 
    191       1.1       cgd /**
    192       1.1       cgd  **	"kill" a distress call
    193       1.1       cgd  **/
    194       1.1       cgd 
    195       1.4  christos void
    196       1.1       cgd killd(x, y, f)
    197       1.1       cgd int	x, y;		/* quadrant coordinates */
    198       1.1       cgd int	f;		/* set if user is to be informed */
    199       1.1       cgd {
    200       1.4  christos 	struct event	*e;
    201       1.4  christos 	int		i;
    202       1.4  christos 	struct quad	*q;
    203       1.1       cgd 
    204       1.1       cgd 	q = &Quad[x][y];
    205       1.1       cgd 	for (i = 0; i < MAXEVENTS; i++)
    206       1.1       cgd 	{
    207       1.1       cgd 		e = &Event[i];
    208       1.1       cgd 		if (e->x != x || e->y != y)
    209       1.1       cgd 			continue;
    210       1.1       cgd 		switch (e->evcode)
    211       1.1       cgd 		{
    212       1.1       cgd 		  case E_KDESB:
    213       1.1       cgd 			if (f)
    214       1.1       cgd 			{
    215       1.1       cgd 				printf("Distress call for starbase in %d,%d nullified\n",
    216       1.1       cgd 					x, y);
    217       1.1       cgd 				unschedule(e);
    218       1.1       cgd 			}
    219       1.1       cgd 			break;
    220       1.1       cgd 
    221       1.1       cgd 		  case E_ENSLV:
    222       1.1       cgd 		  case E_REPRO:
    223       1.1       cgd 			if (f)
    224       1.1       cgd 			{
    225       1.1       cgd 				printf("Distress call for %s in quadrant %d,%d nullified\n",
    226       1.1       cgd 					Systemname[e->systemname], x, y);
    227       1.1       cgd 				q->qsystemname = e->systemname;
    228       1.1       cgd 				unschedule(e);
    229       1.1       cgd 			}
    230       1.1       cgd 			else
    231       1.1       cgd 			{
    232       1.1       cgd 				e->evcode |= E_GHOST;
    233       1.1       cgd 			}
    234       1.1       cgd 		}
    235       1.1       cgd 	}
    236       1.1       cgd }
    237