trek.h revision 1.8 1 1.8 jsm /* $NetBSD: trek.h,v 1.8 1999/09/17 17:06:08 jsm 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.1 cgd * 3. All advertising materials mentioning features or use of this software
16 1.1 cgd * must display the following acknowledgement:
17 1.1 cgd * This product includes software developed by the University of
18 1.1 cgd * California, Berkeley and its contributors.
19 1.1 cgd * 4. Neither the name of the University nor the names of its contributors
20 1.1 cgd * may be used to endorse or promote products derived from this software
21 1.1 cgd * without specific prior written permission.
22 1.1 cgd *
23 1.1 cgd * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
24 1.1 cgd * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
25 1.1 cgd * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
26 1.1 cgd * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
27 1.1 cgd * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
28 1.1 cgd * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
29 1.1 cgd * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
30 1.1 cgd * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
31 1.1 cgd * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
32 1.1 cgd * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
33 1.1 cgd * SUCH DAMAGE.
34 1.1 cgd *
35 1.3 cgd * @(#)trek.h 8.1 (Berkeley) 5/31/93
36 1.1 cgd */
37 1.1 cgd
38 1.1 cgd /*
39 1.1 cgd ** Global Declarations
40 1.1 cgd **
41 1.1 cgd ** Virtually all non-local variable declarations are made in this
42 1.1 cgd ** file. Exceptions are those things which are initialized, which
43 1.1 cgd ** are defined in "externs.c", and things which are local to one
44 1.1 cgd ** program file.
45 1.1 cgd **
46 1.1 cgd ** So far as I know, nothing in here must be preinitialized to
47 1.1 cgd ** zero.
48 1.1 cgd */
49 1.1 cgd
50 1.1 cgd /* external function definitions */
51 1.1 cgd
52 1.1 cgd /********************* GALAXY **************************/
53 1.1 cgd
54 1.1 cgd /* galactic parameters */
55 1.1 cgd # define NSECTS 10 /* dimensions of quadrant in sectors */
56 1.1 cgd # define NQUADS 8 /* dimension of galazy in quadrants */
57 1.1 cgd # define NINHAB 32 /* number of quadrants which are inhabited */
58 1.1 cgd
59 1.1 cgd struct quad /* definition for each quadrant */
60 1.1 cgd {
61 1.5 christos unsigned char bases; /* number of bases in this quadrant */
62 1.1 cgd char klings; /* number of Klingons in this quadrant */
63 1.1 cgd char holes; /* number of black holes in this quadrant */
64 1.1 cgd int scanned; /* star chart entry (see below) */
65 1.4 thorpej short stars; /* number of stars in this quadrant */
66 1.1 cgd char qsystemname; /* starsystem name (see below) */
67 1.1 cgd };
68 1.1 cgd
69 1.1 cgd # define Q_DISTRESSED 0200
70 1.1 cgd # define Q_SYSTEM 077
71 1.1 cgd
72 1.1 cgd /* systemname conventions:
73 1.1 cgd * 1 -> NINHAB index into Systemname table for live system.
74 1.1 cgd * + Q_DISTRESSED distressed starsystem -- systemname & Q_SYSTEM
75 1.1 cgd * is the index into the Event table which will
76 1.1 cgd * have the system name
77 1.1 cgd * 0 dead or nonexistent starsystem
78 1.1 cgd *
79 1.1 cgd * starchart ("scanned") conventions:
80 1.1 cgd * 0 -> 999 taken as is
81 1.1 cgd * -1 not yet scanned ("...")
82 1.1 cgd * 1000 supernova ("///")
83 1.1 cgd * 1001 starbase + ??? (".1.")
84 1.1 cgd */
85 1.1 cgd
86 1.1 cgd /* ascii names of systems */
87 1.6 hubertf extern const char *const Systemname[NINHAB];
88 1.1 cgd
89 1.1 cgd /* quadrant definition */
90 1.8 jsm extern struct quad Quad[NQUADS][NQUADS];
91 1.1 cgd
92 1.1 cgd /* defines for sector map (below) */
93 1.1 cgd # define EMPTY '.'
94 1.1 cgd # define STAR '*'
95 1.1 cgd # define BASE '#'
96 1.1 cgd # define ENTERPRISE 'E'
97 1.1 cgd # define QUEENE 'Q'
98 1.1 cgd # define KLINGON 'K'
99 1.1 cgd # define INHABIT '@'
100 1.1 cgd # define HOLE ' '
101 1.1 cgd
102 1.1 cgd /* current sector map */
103 1.8 jsm extern char Sect[NSECTS][NSECTS];
104 1.1 cgd
105 1.1 cgd
106 1.5 christos
107 1.1 cgd /************************ DEVICES ******************************/
108 1.1 cgd
109 1.1 cgd # define NDEV 16 /* max number of devices */
110 1.1 cgd
111 1.1 cgd /* device tokens */
112 1.1 cgd # define WARP 0 /* warp engines */
113 1.1 cgd # define SRSCAN 1 /* short range scanners */
114 1.1 cgd # define LRSCAN 2 /* long range scanners */
115 1.1 cgd # define PHASER 3 /* phaser control */
116 1.1 cgd # define TORPED 4 /* photon torpedo control */
117 1.1 cgd # define IMPULSE 5 /* impulse engines */
118 1.1 cgd # define SHIELD 6 /* shield control */
119 1.1 cgd # define COMPUTER 7 /* on board computer */
120 1.1 cgd # define SSRADIO 8 /* subspace radio */
121 1.1 cgd # define LIFESUP 9 /* life support systems */
122 1.1 cgd # define SINS 10 /* Space Inertial Navigation System */
123 1.1 cgd # define CLOAK 11 /* cloaking device */
124 1.1 cgd # define XPORTER 12 /* transporter */
125 1.1 cgd # define SHUTTLE 13 /* shuttlecraft */
126 1.1 cgd
127 1.1 cgd /* device names */
128 1.1 cgd struct device
129 1.1 cgd {
130 1.6 hubertf const char *name; /* device name */
131 1.6 hubertf const char *person; /* the person who fixes it */
132 1.1 cgd };
133 1.1 cgd
134 1.8 jsm extern const struct device Device[NDEV];
135 1.1 cgd
136 1.1 cgd /*************************** EVENTS ****************************/
137 1.1 cgd
138 1.1 cgd # define NEVENTS 12 /* number of different event types */
139 1.1 cgd
140 1.1 cgd # define E_LRTB 1 /* long range tractor beam */
141 1.1 cgd # define E_KATSB 2 /* Klingon attacks starbase */
142 1.1 cgd # define E_KDESB 3 /* Klingon destroys starbase */
143 1.1 cgd # define E_ISSUE 4 /* distress call is issued */
144 1.1 cgd # define E_ENSLV 5 /* Klingons enslave a quadrant */
145 1.1 cgd # define E_REPRO 6 /* a Klingon is reproduced */
146 1.1 cgd # define E_FIXDV 7 /* fix a device */
147 1.1 cgd # define E_ATTACK 8 /* Klingon attack during rest period */
148 1.1 cgd # define E_SNAP 9 /* take a snapshot for time warp */
149 1.1 cgd # define E_SNOVA 10 /* supernova occurs */
150 1.1 cgd
151 1.1 cgd # define E_GHOST 0100 /* ghost of a distress call if ssradio out */
152 1.1 cgd # define E_HIDDEN 0200 /* event that is unreportable because ssradio out */
153 1.1 cgd # define E_EVENT 077 /* mask to get event code */
154 1.1 cgd
155 1.1 cgd struct event
156 1.1 cgd {
157 1.5 christos unsigned char x, y; /* coordinates */
158 1.5 christos double date; /* trap stardate */
159 1.5 christos char evcode; /* event type */
160 1.5 christos unsigned char systemname; /* starsystem name */
161 1.1 cgd };
162 1.1 cgd /* systemname conventions:
163 1.1 cgd * 1 -> NINHAB index into Systemname table for reported distress calls
164 1.1 cgd *
165 1.1 cgd * evcode conventions:
166 1.1 cgd * 1 -> NEVENTS-1 event type
167 1.1 cgd * + E_HIDDEN unreported (SSradio out)
168 1.1 cgd * + E_GHOST actually already expired
169 1.1 cgd * 0 unallocated
170 1.1 cgd */
171 1.1 cgd
172 1.1 cgd # define MAXEVENTS 25 /* max number of concurrently pending events */
173 1.1 cgd
174 1.8 jsm extern struct event Event[MAXEVENTS]; /* dynamic event list; one entry per pending event */
175 1.1 cgd
176 1.1 cgd /***************************** KLINGONS *******************************/
177 1.1 cgd
178 1.1 cgd struct kling
179 1.1 cgd {
180 1.5 christos unsigned char x, y; /* coordinates */
181 1.1 cgd int power; /* power left */
182 1.1 cgd double dist; /* distance to Enterprise */
183 1.1 cgd double avgdist; /* average over this move */
184 1.1 cgd char srndreq; /* set if surrender has been requested */
185 1.1 cgd };
186 1.1 cgd
187 1.1 cgd # define MAXKLQUAD 9 /* maximum klingons per quadrant */
188 1.1 cgd
189 1.1 cgd /********************** MISCELLANEOUS ***************************/
190 1.1 cgd
191 1.1 cgd /* condition codes */
192 1.1 cgd # define GREEN 0
193 1.1 cgd # define DOCKED 1
194 1.1 cgd # define YELLOW 2
195 1.1 cgd # define RED 3
196 1.1 cgd
197 1.1 cgd /* starbase coordinates */
198 1.1 cgd # define MAXBASES 9 /* maximum number of starbases in galaxy */
199 1.1 cgd
200 1.1 cgd /* distress calls */
201 1.1 cgd # define MAXDISTR 5 /* maximum concurrent distress calls */
202 1.1 cgd
203 1.1 cgd /* phaser banks */
204 1.1 cgd # define NBANKS 6 /* number of phaser banks */
205 1.1 cgd
206 1.1 cgd struct xy
207 1.1 cgd {
208 1.5 christos unsigned char x, y; /* coordinates */
209 1.1 cgd };
210 1.1 cgd
211 1.1 cgd
212 1.6 hubertf extern const struct cvntab Skitab[];
213 1.6 hubertf extern const struct cvntab Lentab[];
214 1.5 christos
215 1.1 cgd /*
216 1.1 cgd * note that much of the stuff in the following structs CAN NOT
217 1.1 cgd * be moved around!!!!
218 1.1 cgd */
219 1.1 cgd
220 1.1 cgd
221 1.1 cgd /* information regarding the state of the starship */
222 1.8 jsm struct Ship_struct
223 1.1 cgd {
224 1.1 cgd double warp; /* warp factor */
225 1.1 cgd double warp2; /* warp factor squared */
226 1.1 cgd double warp3; /* warp factor cubed */
227 1.1 cgd char shldup; /* shield up flag */
228 1.1 cgd char cloaked; /* set if cloaking device on */
229 1.1 cgd int energy; /* starship's energy */
230 1.1 cgd int shield; /* energy in shields */
231 1.1 cgd double reserves; /* life support reserves */
232 1.1 cgd int crew; /* ship's complement */
233 1.1 cgd int brigfree; /* space left in brig */
234 1.1 cgd char torped; /* torpedoes */
235 1.1 cgd char cloakgood; /* set if we have moved */
236 1.1 cgd int quadx; /* quadrant x coord */
237 1.1 cgd int quady; /* quadrant y coord */
238 1.1 cgd int sectx; /* sector x coord */
239 1.1 cgd int secty; /* sector y coord */
240 1.5 christos unsigned char cond; /* condition code */
241 1.1 cgd char sinsbad; /* Space Inertial Navigation System condition */
242 1.6 hubertf const char *shipname; /* name of current starship */
243 1.1 cgd char ship; /* current starship */
244 1.1 cgd int distressed; /* number of distress calls */
245 1.8 jsm };
246 1.8 jsm extern struct Ship_struct Ship;
247 1.1 cgd
248 1.1 cgd /* sinsbad is set if SINS is working but not calibrated */
249 1.1 cgd
250 1.1 cgd /* game related information, mostly scoring */
251 1.8 jsm struct Game_struct
252 1.1 cgd {
253 1.1 cgd int killk; /* number of klingons killed */
254 1.1 cgd int deaths; /* number of deaths onboard Enterprise */
255 1.1 cgd char negenbar; /* number of hits on negative energy barrier */
256 1.1 cgd char killb; /* number of starbases killed */
257 1.1 cgd int kills; /* number of stars killed */
258 1.1 cgd char skill; /* skill rating of player */
259 1.1 cgd char length; /* length of game */
260 1.1 cgd char killed; /* set if you were killed */
261 1.1 cgd char killinhab; /* number of inhabited starsystems killed */
262 1.1 cgd char tourn; /* set if a tournament game */
263 1.1 cgd char passwd[15]; /* game password */
264 1.1 cgd char snap; /* set if snapshot taken */
265 1.1 cgd char helps; /* number of help calls */
266 1.1 cgd int captives; /* total number of captives taken */
267 1.8 jsm };
268 1.8 jsm extern struct Game_struct Game;
269 1.1 cgd
270 1.1 cgd /* per move information */
271 1.8 jsm struct Move_struct
272 1.1 cgd {
273 1.1 cgd char free; /* set if a move is free */
274 1.1 cgd char endgame; /* end of game flag */
275 1.1 cgd char shldchg; /* set if shields changed this move */
276 1.1 cgd char newquad; /* set if just entered this quadrant */
277 1.1 cgd char resting; /* set if this move is a rest */
278 1.1 cgd double time; /* time used this move */
279 1.8 jsm };
280 1.8 jsm extern struct Move_struct Move;
281 1.1 cgd
282 1.1 cgd /* parametric information */
283 1.8 jsm struct Param_struct
284 1.1 cgd {
285 1.5 christos unsigned char bases; /* number of starbases */
286 1.1 cgd char klings; /* number of klingons */
287 1.1 cgd double date; /* stardate */
288 1.1 cgd double time; /* time left */
289 1.1 cgd double resource; /* Federation resources */
290 1.1 cgd int energy; /* starship's energy */
291 1.1 cgd int shield; /* energy in shields */
292 1.1 cgd double reserves; /* life support reserves */
293 1.1 cgd int crew; /* size of ship's complement */
294 1.1 cgd int brigfree; /* max possible number of captives */
295 1.1 cgd char torped; /* photon torpedos */
296 1.1 cgd double damfac[NDEV]; /* damage factor */
297 1.1 cgd double dockfac; /* docked repair time factor */
298 1.1 cgd double regenfac; /* regeneration factor */
299 1.1 cgd int stopengy; /* energy to do emergency stop */
300 1.1 cgd int shupengy; /* energy to put up shields */
301 1.1 cgd int klingpwr; /* Klingon initial power */
302 1.1 cgd int warptime; /* time chewer multiplier */
303 1.1 cgd double phasfac; /* Klingon phaser power eater factor */
304 1.1 cgd char moveprob[6]; /* probability that a Klingon moves */
305 1.1 cgd double movefac[6]; /* Klingon move distance multiplier */
306 1.1 cgd double eventdly[NEVENTS]; /* event time multipliers */
307 1.1 cgd double navigcrud[2]; /* navigation crudup factor */
308 1.1 cgd int cloakenergy; /* cloaking device energy per stardate */
309 1.1 cgd double damprob[NDEV]; /* damage probability */
310 1.1 cgd double hitfac; /* Klingon attack factor */
311 1.1 cgd int klingcrew; /* number of Klingons in a crew */
312 1.1 cgd double srndrprob; /* surrender probability */
313 1.1 cgd int energylow; /* low energy mark (cond YELLOW) */
314 1.8 jsm };
315 1.8 jsm extern struct Param_struct Param;
316 1.1 cgd
317 1.1 cgd /* Sum of damage probabilities must add to 1000 */
318 1.1 cgd
319 1.1 cgd /* other information kept in a snapshot */
320 1.8 jsm struct Now_struct
321 1.1 cgd {
322 1.5 christos unsigned char bases; /* number of starbases */
323 1.1 cgd char klings; /* number of klingons */
324 1.1 cgd double date; /* stardate */
325 1.1 cgd double time; /* time left */
326 1.1 cgd double resource; /* Federation resources */
327 1.1 cgd char distressed; /* number of currently distressed quadrants */
328 1.1 cgd struct event *eventptr[NEVENTS]; /* pointer to event structs */
329 1.1 cgd struct xy base[MAXBASES]; /* locations of starbases */
330 1.8 jsm };
331 1.8 jsm extern struct Now_struct Now;
332 1.1 cgd
333 1.1 cgd /* Other stuff, not dumped in a snapshot */
334 1.8 jsm struct Etc_struct
335 1.1 cgd {
336 1.1 cgd struct kling klingon[MAXKLQUAD]; /* sorted Klingon list */
337 1.4 thorpej short nkling; /* number of Klingons in this sector */
338 1.1 cgd /* < 0 means automatic override mode */
339 1.1 cgd char fast; /* set if speed > 300 baud */
340 1.1 cgd struct xy starbase; /* starbase in current quadrant */
341 1.1 cgd char snapshot[sizeof Quad + sizeof Event + sizeof Now]; /* snapshot for time warp */
342 1.1 cgd char statreport; /* set to get a status report on a srscan */
343 1.8 jsm };
344 1.8 jsm extern struct Etc_struct Etc;
345 1.1 cgd
346 1.1 cgd /*
347 1.1 cgd * eventptr is a pointer to the event[] entry of the last
348 1.1 cgd * scheduled event of each type. Zero if no such event scheduled.
349 1.1 cgd */
350 1.1 cgd
351 1.1 cgd /* Klingon move indicies */
352 1.1 cgd # define KM_OB 0 /* Old quadrant, Before attack */
353 1.1 cgd # define KM_OA 1 /* Old quadrant, After attack */
354 1.1 cgd # define KM_EB 2 /* Enter quadrant, Before attack */
355 1.1 cgd # define KM_EA 3 /* Enter quadrant, After attack */
356 1.1 cgd # define KM_LB 4 /* Leave quadrant, Before attack */
357 1.1 cgd # define KM_LA 5 /* Leave quadrant, After attack */
358 1.1 cgd
359 1.1 cgd /* you lose codes */
360 1.1 cgd # define L_NOTIME 1 /* ran out of time */
361 1.1 cgd # define L_NOENGY 2 /* ran out of energy */
362 1.1 cgd # define L_DSTRYD 3 /* destroyed by a Klingon */
363 1.1 cgd # define L_NEGENB 4 /* ran into the negative energy barrier */
364 1.1 cgd # define L_SUICID 5 /* destroyed in a nova */
365 1.1 cgd # define L_SNOVA 6 /* destroyed in a supernova */
366 1.1 cgd # define L_NOLIFE 7 /* life support died (so did you) */
367 1.1 cgd # define L_NOHELP 8 /* you could not be rematerialized */
368 1.1 cgd # define L_TOOFAST 9 /* pretty stupid going at warp 10 */
369 1.1 cgd # define L_STAR 10 /* ran into a star */
370 1.1 cgd # define L_DSTRCT 11 /* self destructed */
371 1.1 cgd # define L_CAPTURED 12 /* captured by Klingons */
372 1.1 cgd # define L_NOCREW 13 /* you ran out of crew */
373 1.1 cgd
374 1.1 cgd /****************** COMPILE OPTIONS ***********************/
375 1.1 cgd
376 1.1 cgd /* Trace info */
377 1.1 cgd # define xTRACE 1
378 1.8 jsm extern int Trace;
379 1.5 christos
380 1.5 christos /* abandon.c */
381 1.5 christos void abandon __P((int));
382 1.5 christos
383 1.5 christos /* attack.c */
384 1.5 christos void attack __P((int));
385 1.5 christos
386 1.5 christos /* autover.c */
387 1.5 christos void autover __P((void));
388 1.5 christos
389 1.5 christos /* capture.c */
390 1.5 christos void capture __P((int));
391 1.5 christos struct kling *selectklingon __P((void));
392 1.5 christos
393 1.5 christos /* cgetc.c */
394 1.5 christos char cgetc __P((int));
395 1.5 christos
396 1.5 christos /* check_out.c */
397 1.5 christos int check_out __P((int));
398 1.5 christos
399 1.5 christos /* checkcond.c */
400 1.5 christos void checkcond __P((void));
401 1.5 christos
402 1.5 christos /* compkl.c */
403 1.5 christos void compkldist __P((int));
404 1.5 christos
405 1.5 christos /* computer.c */
406 1.5 christos void computer __P((int));
407 1.5 christos
408 1.5 christos /* damage.c */
409 1.5 christos void damage __P((int, double));
410 1.5 christos
411 1.5 christos /* damaged.c */
412 1.5 christos int damaged __P((int));
413 1.5 christos
414 1.5 christos /* dcrept.c */
415 1.5 christos void dcrept __P((int));
416 1.5 christos
417 1.5 christos /* destruct.c */
418 1.5 christos void destruct __P((int));
419 1.5 christos
420 1.5 christos /* dock.c */
421 1.5 christos void dock __P((int));
422 1.5 christos void undock __P((int));
423 1.5 christos
424 1.5 christos /* dumpgame.c */
425 1.5 christos void dumpgame __P((int));
426 1.5 christos int restartgame __P((void));
427 1.5 christos
428 1.5 christos /* dumpme.c */
429 1.5 christos void dumpme __P((int));
430 1.5 christos
431 1.5 christos /* dumpssradio.c */
432 1.5 christos int dumpssradio __P((void));
433 1.5 christos
434 1.5 christos /* events.c */
435 1.5 christos int events __P((int));
436 1.5 christos
437 1.5 christos /* externs.c */
438 1.5 christos
439 1.5 christos /* getcodi.c */
440 1.5 christos int getcodi __P((int *, double *));
441 1.5 christos
442 1.5 christos /* help.c */
443 1.5 christos void help __P((int));
444 1.5 christos
445 1.5 christos /* impulse.c */
446 1.5 christos void impulse __P((int));
447 1.5 christos
448 1.5 christos /* initquad.c */
449 1.5 christos void initquad __P((int));
450 1.5 christos void sector __P((int *, int *));
451 1.5 christos
452 1.5 christos /* kill.c */
453 1.5 christos void killk __P((int, int ));
454 1.5 christos void killb __P((int, int ));
455 1.5 christos void kills __P((int, int , int));
456 1.5 christos void killd __P((int, int , int));
457 1.5 christos
458 1.5 christos /* klmove.c */
459 1.5 christos void klmove __P((int));
460 1.5 christos
461 1.5 christos /* lose.c */
462 1.7 jsm void lose __P((int)) __attribute__((__noreturn__));
463 1.5 christos
464 1.5 christos /* lrscan.c */
465 1.5 christos void lrscan __P((int));
466 1.5 christos
467 1.5 christos /* move.c */
468 1.5 christos double move __P((int, int, double, double));
469 1.5 christos
470 1.5 christos /* nova.c */
471 1.5 christos void nova __P((int, int ));
472 1.5 christos
473 1.5 christos /* out.c */
474 1.5 christos void out __P((int));
475 1.5 christos
476 1.5 christos /* phaser.c */
477 1.5 christos void phaser __P((int));
478 1.5 christos
479 1.5 christos /* play.c */
480 1.7 jsm void myreset __P((int)) __attribute__((__noreturn__));
481 1.7 jsm void play __P((void)) __attribute__((__noreturn__));
482 1.5 christos
483 1.5 christos /* ram.c */
484 1.5 christos void ram __P((int, int ));
485 1.5 christos
486 1.5 christos /* ranf.c */
487 1.5 christos int ranf __P((int));
488 1.5 christos double franf __P((void));
489 1.5 christos
490 1.5 christos /* rest.c */
491 1.5 christos void rest __P((int));
492 1.5 christos
493 1.5 christos /* schedule.c */
494 1.5 christos struct event *schedule __P((int, double, int, int , int));
495 1.5 christos void reschedule __P((struct event *, double));
496 1.5 christos void unschedule __P((struct event *));
497 1.5 christos struct event *xsched __P((int, int, int, int , int ));
498 1.5 christos void xresched __P((struct event *, int, int));
499 1.5 christos
500 1.5 christos /* score.c */
501 1.5 christos long score __P((void));
502 1.5 christos
503 1.5 christos /* setup.c */
504 1.5 christos void setup __P((void));
505 1.5 christos
506 1.5 christos /* setwarp.c */
507 1.5 christos void setwarp __P((int));
508 1.5 christos
509 1.5 christos /* shield.c */
510 1.5 christos void shield __P((int));
511 1.5 christos
512 1.5 christos /* snova.c */
513 1.5 christos void snova __P((int, int ));
514 1.5 christos
515 1.5 christos /* srscan.c */
516 1.5 christos void srscan __P((int));
517 1.5 christos
518 1.5 christos /* systemname.c */
519 1.6 hubertf const char *systemname __P((const struct quad *));
520 1.5 christos
521 1.5 christos /* torped.c */
522 1.5 christos void torped __P((int));
523 1.5 christos
524 1.5 christos /* visual.c */
525 1.5 christos void visual __P((int));
526 1.5 christos
527 1.5 christos /* warp.c */
528 1.5 christos void dowarp __P((int));
529 1.5 christos void warp __P((int, int, double));
530 1.5 christos
531 1.5 christos /* win.c */
532 1.7 jsm void win __P((void)) __attribute__((__noreturn__));
533