DataMuseum.dk

Presents historical artifacts from the history of:

DKUUG/EUUG Conference tapes

This is an automatic "excavation" of a thematic subset of
artifacts from Datamuseum.dk's BitArchive.

See our Wiki for more about DKUUG/EUUG Conference tapes

Excavated with: AutoArchaeologist - Free & Open Source Software.


top - download
Index: ┃ T d

⟦201b5a52d⟧ TextFile

    Length: 1563 (0x61b)
    Types: TextFile
    Names: »detonate.c«

Derivation

└─⟦a0efdde77⟧ Bits:30001252 EUUGD11 Tape, 1987 Spring Conference Helsinki
    └─ ⟦526ad3590⟧ »EUUGD11/gnu-31mar87/X.V10.R4.tar.Z« 
        └─⟦2109abc41⟧ 
            └─ ⟦this⟧ »./X.V10R4/xtrek/detonate.c« 

TextFile

#ifndef lint
static char *rcsid_detonate_c = "$Header: detonate.c,v 10.1 86/11/30 15:24:16 jg Rel $";
#endif	lint
/* Copyright (c) 1986 	Chris Guthrie */

#include <X/Xlib.h>
#include <stdio.h>
#include <sys/types.h>
#include <sys/ipc.h>
#include <sys/shm.h>
#include "defs.h"
#include "struct.h"
#include "data.h"

/* Detonate torp */

detmine()
{
    register int i;
    register struct torp *j;

    if (me->p_flags & PFWEP) {
	warning("Weapons overheated");
	return;
    }
    for (i = 0; i < MAXTORP; i++, j++) {
	if (torps[i + (me->p_no * MAXTORP)].t_status == TMOVE) {
	    torps[i + (me->p_no * MAXTORP)].t_status = TOFF;
	}
	else if (torps[i + (me->p_no * MAXTORP)].t_status == TSTRAIGHT) {
	    torps[i + (me->p_no * MAXTORP)].t_status = TOFF;
	}
    }
}

detothers()
{
    register int h, i;
    int dx, dy;
    register struct torp *j;

    if (me->p_fuel < myship->s_detcost) {
	warning("Not enough fuel to detonate");
	return;
    }
    if (me->p_flags & PFWEP) {
	warning("Weapons overheated");
	return;
    }
    me->p_fuel -= myship->s_detcost;
    me->p_wtemp += myship->s_detcost / 5;

    for (h = 0; h < MAXPLAYER; h++) {
	if ((players[h].p_status == PFREE) || (h == me->p_no))
	    continue;
	for (i = h * MAXTORP; i < MAXTORP * (h + 1); i++) {
	    j = &torps[i];
	    if ((j->t_status == TMOVE) || (j->t_status == TSTRAIGHT)) {
		dx = j->t_x - me->p_x;
		dy = j->t_y - me->p_y;
		if (ABS(dx) > DETDIST || ABS(dy) > DETDIST) /* XXX */
		    continue;
		if (dx * dx + dy * dy < DETDIST * DETDIST)
		    j->t_status = TDET;
	    }
	}
    }
}