2 * Copyright (c) 1983, 1993
3 * The Regents of the University of California. All rights reserved.
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
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.
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
36 static char sccsid[] = "@(#)fly.c 8.1 (Berkeley) 5/31/93";
38 static const char rcsid[] =
47 #define abs(a) ((a) < 0 ? -(a) : (a))
48 #define MIDR (LINES/2 - 1)
49 #define MIDC (COLS/2 - 1)
54 int gclock = 120; /* gtime for all the flights in the game */
61 if (oldsig == SIG_DFL) {
65 if (oldsig != SIG_IGN) {
77 puts("Whoops! No more memory...");
80 oldsig = signal(SIGINT, succumb);
84 row = rnd(LINES-3) + 1;
85 column = rnd(COLS-2) + 1;
150 if (row == MIDR && column - MIDC < 2 && MIDC - column < 2){
156 mvaddstr(0,0,"*** Out of torpedoes. ***");
164 mvaddstr(0,26,"Commands = r,R,l,L,u,U,d,D,f,+,q");
188 for (n=0; n < i; n++){
189 r = rnd(LINES-3) + 1;
193 mvaddstr(LINES-1-1,21,"TORPEDOES FUEL TIME");
202 addstr("------- + -------");
203 for (n = MIDR-4; n < MIDR-1; n++){
205 mvaddch(n+6,MIDC,'|');
215 for (n = MIDR-4; n < MIDR-1; n++){
217 mvaddch(n+6,MIDC,' ');
227 printw("%3d", torps);
228 for(n = LINES-1-2; n >= MIDR + 1; n--){
229 mvaddch(n, MIDC+MIDR-n, '/');
230 mvaddch(n, MIDC-MIDR+n, '\\');
233 mvaddch(MIDR,MIDC,'*');
234 for(n = LINES-1-2; n >= MIDR + 1; n--){
235 mvaddch(n, MIDC+MIDR-n, ' ');
236 mvaddch(n, MIDC-MIDR+n, ' ');
251 if (row + dr <= LINES-3 && row + dr > 0)
253 if (column + dc < COLS-1 && column + dc > 0)
255 } else if (fuel < 0){
257 mvaddstr(0,60,"*** Out of fuel ***");
259 d = (double) ((row - MIDR)*(row - MIDR) + (column - MIDC)*(column - MIDC));
261 row += (rnd(9) - 4) % (4 - abs(row - MIDR));
262 column += (rnd(9) - 4) % (4 - abs(column - MIDC));
265 mvaddstr(oldr, oldc - 1, " ");
268 mvaddstr(row, column - 1, "/-\\");
270 printw("%3d", torps);
274 printw("%3d", gclock);
276 signal(SIGALRM, moveenemy);
283 signal(SIGALRM, SIG_DFL);
284 mvcur(0,COLS-1,LINES-1,0);
286 signal(SIGTSTP, SIG_DFL);
287 signal(SIGINT, oldsig);