1 /* $NetBSD: srscan.c,v 1.10 2009/05/25 00:39:45 dholland 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.10 2009/05/25 00:39:45 dholland 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 static const char *const Color
[4] = {
74 struct quad
*q
= NULL
;
75 const struct cvntab
*p
;
77 if (f
>= 0 && check_out(SRSCAN
)) {
84 Etc
.statreport
= getynpar("status report");
85 statinfo
= Etc
.statreport
;
93 printf("\nShort range sensor scan\n");
94 q
= &Quad
[Ship
.quadx
][Ship
.quady
];
95 q
->scanned
= q
->klings
* 100 + q
->bases
* 10 + q
->stars
;
97 for (i
= 0; i
< NSECTS
; i
++) {
103 for (i
= 0; i
< NSECTS
; i
++) {
106 for (j
= 0; j
< NSECTS
; j
++)
107 printf("%c ", Sect
[i
][j
]);
115 printf("stardate %.2f", Now
.date
);
118 printf("condition %s", Color
[Ship
.cond
]);
123 printf("position %d,%d/%d,%d", Ship
.quadx
,
124 Ship
.quady
, Ship
.sectx
, Ship
.secty
);
127 printf("warp factor %.1f", Ship
.warp
);
130 printf("total energy %d", Ship
.energy
);
133 printf("torpedoes %d", Ship
.torped
);
141 percent
= 100.0 * Ship
.shield
/ Param
.shield
;
142 printf("shields %s, %d%%", s
, percent
);
145 printf("Klingons left %d", Now
.klings
);
148 printf("time left %.2f", Now
.time
);
151 printf("life support ");
152 if (damaged(LIFESUP
)) {
153 printf("damaged, reserves = %.2f",
163 printf("current crew %d\n", Ship
.crew
);
164 printf("brig space %d\n", Ship
.brigfree
);
165 printf("Klingon power %d\n", Param
.klingpwr
);
166 p
= &Lentab
[Game
.length
- 1];
169 printf("Length, Skill %s%s, ", p
->abbrev
, p
->full
);
170 p
= &Skitab
[Game
.skill
- 1];
171 printf("%s%s\n", p
->abbrev
, p
->full
);
175 for (i
= 0; i
< NSECTS
; i
++)
179 if (q
->qsystemname
& Q_DISTRESSED
)
180 printf("Distressed ");
182 printf("Starsystem %s\n", systemname(q
));