1 /* $NetBSD: fly.c,v 1.13 2005/07/01 06:04:54 jmc 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.13 2005/07/01 06:04:54 jmc Exp $");
45 #define MIDR (LINES/2 - 1)
46 #define MIDC (COLS/2 - 1)
48 static int row
, column
;
49 static int dr
= 0, dc
= 0;
50 static char destroyed
;
51 int ourclock
= 120; /* time for all the flights in the game */
52 static char cross
= 0;
55 static void blast(void);
56 static void endfly(void);
57 static void moveenemy(int);
58 static void notarget(void);
59 static void screen(void);
60 static void succumb(int);
61 static void target(void);
64 succumb(int dummy __unused
)
66 if (oldsig
== SIG_DFL
) {
70 if (oldsig
!= SIG_IGN
) {
80 if (initscr() == NULL
) {
81 puts("Whoops! No more memory...");
84 oldsig
= signal(SIGINT
, succumb
);
88 row
= rnd(LINES
- 3) + 1;
89 column
= rnd(COLS
- 2) + 1;
153 if (row
== MIDR
&& column
- MIDC
< 2 &&
159 mvaddstr(0, 0, "*** Out of torpedoes. ***");
167 mvaddstr(0, 26, "Commands = r,R,l,L,u,U,d,D,f,+,q");
192 for (n
= 0; n
< i
; n
++) {
193 r
= rnd(LINES
- 3) + 1;
197 mvaddstr(LINES
- 1 - 1, 21, "TORPEDOES FUEL TIME");
206 move(MIDR
, MIDC
- 10);
207 addstr("------- + -------");
208 for (n
= MIDR
- 4; n
< MIDR
- 1; n
++) {
209 mvaddch(n
, MIDC
, '|');
210 mvaddch(n
+ 6, MIDC
, '|');
219 move(MIDR
, MIDC
- 10);
221 for (n
= MIDR
- 4; n
< MIDR
- 1; n
++) {
222 mvaddch(n
, MIDC
, ' ');
223 mvaddch(n
+ 6, MIDC
, ' ');
234 printw("%3d", torps
);
235 for (n
= LINES
- 1 - 2; n
>= MIDR
+ 1; n
--) {
236 mvaddch(n
, MIDC
+ MIDR
- n
, '/');
237 mvaddch(n
, MIDC
- MIDR
+ n
, '\\');
240 mvaddch(MIDR
, MIDC
, '*');
241 for (n
= LINES
- 1 - 2; n
>= MIDR
+ 1; n
--) {
242 mvaddch(n
, MIDC
+ MIDR
- n
, ' ');
243 mvaddch(n
, MIDC
- MIDR
+ n
, ' ');
250 moveenemy(int dummy __unused
)
258 if (row
+ dr
<= LINES
- 3 && row
+ dr
> 0)
260 if (column
+ dc
< COLS
- 1 && column
+ dc
> 0)
265 mvaddstr(0, 60, "*** Out of fuel ***");
267 d
= (double) ((row
- MIDR
) * (row
- MIDR
) + (column
- MIDC
) *
270 row
+= (rnd(9) - 4) % (4 - abs(row
- MIDR
));
271 column
+= (rnd(9) - 4) % (4 - abs(column
- MIDC
));
274 mvaddstr(oldr
, oldc
- 1, " ");
277 mvaddstr(row
, column
- 1, "/-\\");
279 printw("%3d", torps
);
283 printw("%3d", ourclock
);
285 signal(SIGALRM
, moveenemy
);
293 signal(SIGALRM
, SIG_DFL
);
294 mvcur(0, COLS
- 1, LINES
- 1, 0);
296 signal(SIGTSTP
, SIG_DFL
);
297 signal(SIGINT
, oldsig
);