]>
git.cameronkatri.com Git - bsdgames-darwin.git/blob - trek/srscan.c
1 /* $NetBSD: srscan.c,v 1.6 2003/08/07 09:37:54 agc Exp $ */
4 * Copyright (c) 1980, 1993
5 * The Regents of the University of California. All rights reserved.
7 * Redistribution and use in source and binary forms, with or without
8 * modification, are permitted provided that the following conditions
10 * 1. Redistributions of source code must retain the above copyright
11 * notice, this list of conditions and the following disclaimer.
12 * 2. Redistributions in binary form must reproduce the above copyright
13 * notice, this list of conditions and the following disclaimer in the
14 * documentation and/or other materials provided with the distribution.
15 * 3. Neither the name of the University nor the names of its contributors
16 * may be used to endorse or promote products derived from this software
17 * without specific prior written permission.
19 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
20 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
21 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
22 * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
23 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
24 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
25 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
26 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
27 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
28 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
32 #include <sys/cdefs.h>
35 static char sccsid
[] = "@(#)srscan.c 8.1 (Berkeley) 5/31/93";
37 __RCSID("$NetBSD: srscan.c,v 1.6 2003/08/07 09:37:54 agc Exp $");
46 ** SHORT RANGE SENSOR SCAN
48 ** A short range scan is taken of the current quadrant. If the
49 ** flag 'f' is one, it is an "auto srscan", which is not done
50 ** unless in 'fast' mode. It does a status report and a srscan.
51 ** If 'f' is -1, you get a status report only. If it is zero,
52 ** you get a srscan and an optional status report. The status
53 ** report is taken if you enter "srscan yes"; for all srscans
54 ** thereafter you get a status report with your srscan until
55 ** you type "srscan no". It defaults to on.
57 ** The current quadrant is filled in on the computer chart.
60 const char *const Color
[4] =
76 struct quad
*q
= NULL
;
77 const struct cvntab
*p
;
79 if (f
>= 0 && check_out(SRSCAN
))
88 Etc
.statreport
= getynpar("status report");
89 statinfo
= Etc
.statreport
;
99 printf("\nShort range sensor scan\n");
100 q
= &Quad
[Ship
.quadx
][Ship
.quady
];
101 q
->scanned
= q
->klings
* 100 + q
->bases
* 10 + q
->stars
;
103 for (i
= 0; i
< NSECTS
; i
++)
110 for (i
= 0; i
< NSECTS
; i
++)
115 for (j
= 0; j
< NSECTS
; j
++)
116 printf("%c ", Sect
[i
][j
]);
125 printf("stardate %.2f", Now
.date
);
128 printf("condition %s", Color
[Ship
.cond
]);
133 printf("position %d,%d/%d,%d",Ship
.quadx
, Ship
.quady
, Ship
.sectx
, Ship
.secty
);
136 printf("warp factor %.1f", Ship
.warp
);
139 printf("total energy %d", Ship
.energy
);
142 printf("torpedoes %d", Ship
.torped
);
150 percent
= 100.0 * Ship
.shield
/ Param
.shield
;
151 printf("shields %s, %d%%", s
, percent
);
154 printf("Klingons left %d", Now
.klings
);
157 printf("time left %.2f", Now
.time
);
160 printf("life support ");
161 if (damaged(LIFESUP
))
163 printf("damaged, reserves = %.2f", Ship
.reserves
);
173 printf("current crew %d\n", Ship
.crew
);
174 printf("brig space %d\n", Ship
.brigfree
);
175 printf("Klingon power %d\n", Param
.klingpwr
);
176 p
= &Lentab
[Game
.length
- 1];
179 printf("Length, Skill %s%s, ", p
->abrev
, p
->full
);
180 p
= &Skitab
[Game
.skill
- 1];
181 printf("%s%s\n", p
->abrev
, p
->full
);
185 for (i
= 0; i
< NSECTS
; i
++)
189 if (q
->qsystemname
& Q_DISTRESSED
)
190 printf("Distressed ");
192 printf("Starsystem %s\n", systemname(q
));