1 /* $NetBSD: fly.c,v 1.15 2012/10/13 19:58:53 dholland Exp $ */
4 * Copyright (c) 1983, 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
[] = "@(#)fly.c 8.2 (Berkeley) 4/28/95";
37 __RCSID("$NetBSD: fly.c,v 1.15 2012/10/13 19:58:53 dholland Exp $");
46 #define MIDR (LINES/2 - 1)
47 #define MIDC (COLS/2 - 1)
49 static int row
, column
;
50 static int dr
= 0, dc
= 0;
51 static char destroyed
;
52 int ourclock
= 120; /* time for all the flights in the game */
53 static char cross
= 0;
56 static void blast(void);
57 static void endfly(void);
58 static void moveenemy(int);
59 static void notarget(void);
60 static void screen(void);
61 static void succumb(int);
62 static void target(void);
65 succumb(int dummy __unused
)
67 if (oldsig
== SIG_DFL
) {
71 if (oldsig
!= SIG_IGN
) {
81 if (initscr() == NULL
) {
82 puts("Whoops! No more memory...");
85 oldsig
= signal(SIGINT
, succumb
);
89 row
= rnd(LINES
- 3) + 1;
90 column
= rnd(COLS
- 2) + 1;
154 if (row
== MIDR
&& column
< MIDC
+ 2 &&
160 mvaddstr(0, 0, "*** Out of torpedoes. ***");
168 mvaddstr(0, 26, "Commands = r,R,l,L,u,U,d,D,f,+,q");
193 for (n
= 0; n
< i
; n
++) {
194 r
= rnd(LINES
- 3) + 1;
198 mvaddstr(LINES
- 1 - 1, 21, "TORPEDOES FUEL TIME");
207 move(MIDR
, MIDC
- 10);
208 addstr("------- + -------");
209 for (n
= MIDR
- 4; n
< MIDR
- 1; n
++) {
210 mvaddch(n
, MIDC
, '|');
211 mvaddch(n
+ 6, MIDC
, '|');
220 move(MIDR
, MIDC
- 10);
222 for (n
= MIDR
- 4; n
< MIDR
- 1; n
++) {
223 mvaddch(n
, MIDC
, ' ');
224 mvaddch(n
+ 6, MIDC
, ' ');
235 printw("%3d", torps
);
236 for (n
= LINES
- 1 - 2; n
>= MIDR
+ 1; n
--) {
237 mvaddch(n
, MIDC
+ MIDR
- n
, '/');
238 mvaddch(n
, MIDC
- MIDR
+ n
, '\\');
241 mvaddch(MIDR
, MIDC
, '*');
242 for (n
= LINES
- 1 - 2; n
>= MIDR
+ 1; n
--) {
243 mvaddch(n
, MIDC
+ MIDR
- n
, ' ');
244 mvaddch(n
, MIDC
- MIDR
+ n
, ' ');
251 moveenemy(int dummy __unused
)
259 if (row
+ dr
<= LINES
- 3 && row
+ dr
> 0)
261 if (column
+ dc
< COLS
- 1 && column
+ dc
> 0)
266 mvaddstr(0, 60, "*** Out of fuel ***");
268 d
= (double) ((row
- MIDR
) * (row
- MIDR
) + (column
- MIDC
) *
271 row
+= (rnd(9) - 4) % (4 - abs(row
- MIDR
));
272 column
+= (rnd(9) - 4) % (4 - abs(column
- MIDC
));
275 mvaddstr(oldr
, oldc
- 1, " ");
278 mvaddstr(row
, column
- 1, "/-\\");
280 printw("%3d", torps
);
284 printw("%3d", ourclock
);
286 signal(SIGALRM
, moveenemy
);
294 signal(SIGALRM
, SIG_DFL
);
295 mvcur(0, COLS
- 1, LINES
- 1, 0);
297 signal(SIGTSTP
, SIG_DFL
);
298 signal(SIGINT
, oldsig
);