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
37 static char sccsid[] = "@(#)fly.c 8.1 (Berkeley) 5/31/93";
45 #define abs(a) ((a) < 0 ? -(a) : (a))
46 #define MIDR (LINES/2 - 1)
47 #define MIDC (COLS/2 - 1)
52 int gclock = 120; /* gtime for all the flights in the game */
59 if (oldsig == SIG_DFL) {
63 if (oldsig != SIG_IGN) {
75 puts("Whoops! No more memory...");
78 oldsig = signal(SIGINT, succumb);
82 row = rnd(LINES-3) + 1;
83 column = rnd(COLS-2) + 1;
148 if (row == MIDR && column - MIDC < 2 && MIDC - column < 2){
154 mvaddstr(0,0,"*** Out of torpedoes. ***");
162 mvaddstr(0,26,"Commands = r,R,l,L,u,U,d,D,f,+,q");
186 for (n=0; n < i; n++){
187 r = rnd(LINES-3) + 1;
191 mvaddstr(LINES-1-1,21,"TORPEDOES FUEL TIME");
200 addstr("------- + -------");
201 for (n = MIDR-4; n < MIDR-1; n++){
203 mvaddch(n+6,MIDC,'|');
213 for (n = MIDR-4; n < MIDR-1; n++){
215 mvaddch(n+6,MIDC,' ');
225 printw("%3d", torps);
226 for(n = LINES-1-2; n >= MIDR + 1; n--){
227 mvaddch(n, MIDC+MIDR-n, '/');
228 mvaddch(n, MIDC-MIDR+n, '\\');
231 mvaddch(MIDR,MIDC,'*');
232 for(n = LINES-1-2; n >= MIDR + 1; n--){
233 mvaddch(n, MIDC+MIDR-n, ' ');
234 mvaddch(n, MIDC-MIDR+n, ' ');
249 if (row + dr <= LINES-3 && row + dr > 0)
251 if (column + dc < COLS-1 && column + dc > 0)
253 } else if (fuel < 0){
255 mvaddstr(0,60,"*** Out of fuel ***");
257 d = (double) ((row - MIDR)*(row - MIDR) + (column - MIDC)*(column - MIDC));
259 row += (rnd(9) - 4) % (4 - abs(row - MIDR));
260 column += (rnd(9) - 4) % (4 - abs(column - MIDC));
263 mvaddstr(oldr, oldc - 1, " ");
266 mvaddstr(row, column - 1, "/-\\");
268 printw("%3d", torps);
272 printw("%3d", gclock);
274 signal(SIGALRM, moveenemy);
281 signal(SIGALRM, SIG_DFL);
282 mvcur(0,COLS-1,LINES-1,0);
284 signal(SIGTSTP, SIG_DFL);
285 signal(SIGINT, oldsig);