]> git.cameronkatri.com Git - bsdgames-darwin.git/blob - trek/srscan.c
clean up handling of fortunes a bit.
[bsdgames-darwin.git] / trek / srscan.c
1 /*
2 * Copyright (c) 1980 Regents of the University of California.
3 * All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
7 * are met:
8 * 1. Redistributions of source code must retain the above copyright
9 * notice, this list of conditions and the following disclaimer.
10 * 2. Redistributions in binary form must reproduce the above copyright
11 * notice, this list of conditions and the following disclaimer in the
12 * documentation and/or other materials provided with the distribution.
13 * 3. All advertising materials mentioning features or use of this software
14 * must display the following acknowledgement:
15 * This product includes software developed by the University of
16 * California, Berkeley and its contributors.
17 * 4. Neither the name of the University nor the names of its contributors
18 * may be used to endorse or promote products derived from this software
19 * without specific prior written permission.
20 *
21 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
22 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
23 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
24 * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
25 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
26 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
27 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
28 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
29 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
30 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
31 * SUCH DAMAGE.
32 */
33
34 #ifndef lint
35 /*static char sccsid[] = "from: @(#)srscan.c 5.4 (Berkeley) 6/1/90";*/
36 static char rcsid[] = "$Id: srscan.c,v 1.2 1993/08/01 18:49:56 mycroft Exp $";
37 #endif /* not lint */
38
39 # include "trek.h"
40 # include "getpar.h"
41
42 /*
43 ** SHORT RANGE SENSOR SCAN
44 **
45 ** A short range scan is taken of the current quadrant. If the
46 ** flag 'f' is one, it is an "auto srscan", which is not done
47 ** unless in 'fast' mode. It does a status report and a srscan.
48 ** If 'f' is -1, you get a status report only. If it is zero,
49 ** you get a srscan and an optional status report. The status
50 ** report is taken if you enter "srscan yes"; for all srscans
51 ** thereafter you get a status report with your srscan until
52 ** you type "srscan no". It defaults to on.
53 **
54 ** The current quadrant is filled in on the computer chart.
55 */
56
57 char *Color[4] =
58 {
59 "GREEN",
60 "DOCKED",
61 "YELLOW",
62 "RED"
63 };
64
65 srscan(f)
66 int f;
67 {
68 register int i, j;
69 register int statinfo;
70 char *s;
71 int percent;
72 struct quad *q;
73 extern struct cvntab Skitab[];
74 extern struct cvntab Lentab[];
75 struct cvntab *p;
76
77 if (f >= 0 && check_out(SRSCAN))
78 {
79 return;
80 }
81 if (f)
82 statinfo = 1;
83 else
84 {
85 if (!testnl())
86 Etc.statreport = getynpar("status report");
87 statinfo = Etc.statreport;
88 }
89 if (f > 0)
90 {
91 Etc.statreport = 1;
92 if (!Etc.fast)
93 return;
94 }
95 if (f >= 0)
96 {
97 printf("\nShort range sensor scan\n");
98 q = &Quad[Ship.quadx][Ship.quady];
99 q->scanned = q->klings * 100 + q->bases * 10 + q->stars;
100 printf(" ");
101 for (i = 0; i < NSECTS; i++)
102 {
103 printf("%d ", i);
104 }
105 printf("\n");
106 }
107
108 for (i = 0; i < NSECTS; i++)
109 {
110 if (f >= 0)
111 {
112 printf("%d ", i);
113 for (j = 0; j < NSECTS; j++)
114 printf("%c ", Sect[i][j]);
115 printf("%d", i);
116 if (statinfo)
117 printf(" ");
118 }
119 if (statinfo)
120 switch (i)
121 {
122 case 0:
123 printf("stardate %.2f", Now.date);
124 break;
125 case 1:
126 printf("condition %s", Color[Ship.cond]);
127 if (Ship.cloaked)
128 printf(", CLOAKED");
129 break;
130 case 2:
131 printf("position %d,%d/%d,%d",Ship.quadx, Ship.quady, Ship.sectx, Ship.secty);
132 break;
133 case 3:
134 printf("warp factor %.1f", Ship.warp);
135 break;
136 case 4:
137 printf("total energy %d", Ship.energy);
138 break;
139 case 5:
140 printf("torpedoes %d", Ship.torped);
141 break;
142 case 6:
143 s = "down";
144 if (Ship.shldup)
145 s = "up";
146 if (damaged(SHIELD))
147 s = "damaged";
148 percent = 100.0 * Ship.shield / Param.shield;
149 printf("shields %s, %d%%", s, percent);
150 break;
151 case 7:
152 printf("Klingons left %d", Now.klings);
153 break;
154 case 8:
155 printf("time left %.2f", Now.time);
156 break;
157 case 9:
158 printf("life support ");
159 if (damaged(LIFESUP))
160 {
161 printf("damaged, reserves = %.2f", Ship.reserves);
162 break;
163 }
164 printf("active");
165 break;
166 }
167 printf("\n");
168 }
169 if (f < 0)
170 {
171 printf("current crew %d\n", Ship.crew);
172 printf("brig space %d\n", Ship.brigfree);
173 printf("Klingon power %d\n", Param.klingpwr);
174 p = &Lentab[Game.length - 1];
175 if (Game.length > 2)
176 p--;
177 printf("Length, Skill %s%s, ", p->abrev, p->full);
178 p = &Skitab[Game.skill - 1];
179 printf("%s%s\n", p->abrev, p->full);
180 return;
181 }
182 printf(" ");
183 for (i = 0; i < NSECTS; i++)
184 printf("%d ", i);
185 printf("\n");
186
187 if (q->qsystemname & Q_DISTRESSED)
188 printf("Distressed ");
189 if (q->qsystemname)
190 printf("Starsystem %s\n", systemname(q));
191 }