]> git.cameronkatri.com Git - bsdgames-darwin.git/blobdiff - battlestar/fly.c
Allow for the bathing goddess in ravage(). From OpenBSD.
[bsdgames-darwin.git] / battlestar / fly.c
index f3c2db98982e5fc0e08e377efd66bd15af65f35e..0182f103b94e0f5b1f4227483549d0e6d2c929aa 100644 (file)
@@ -1,4 +1,4 @@
-/*     $NetBSD: fly.c,v 1.4 1997/01/07 11:56:44 tls Exp $      */
+/*     $NetBSD: fly.c,v 1.8 1999/09/08 21:45:25 jsm Exp $      */
 
 /*
  * Copyright (c) 1983, 1993
  * SUCH DAMAGE.
  */
 
+#include <sys/cdefs.h>
 #ifndef lint
 #if 0
 static char sccsid[] = "@(#)fly.c      8.2 (Berkeley) 4/28/95";
 #else
-static char rcsid[] = "$NetBSD: fly.c,v 1.4 1997/01/07 11:56:44 tls Exp $";
+__RCSID("$NetBSD: fly.c,v 1.8 1999/09/08 21:45:25 jsm Exp $");
 #endif
-#endif /* not lint */
+#endif                         /* not lint */
 
 #include "extern.h"
 #undef UP
@@ -49,15 +50,16 @@ static char rcsid[] = "$NetBSD: fly.c,v 1.4 1997/01/07 11:56:44 tls Exp $";
 #define MIDR  (LINES/2 - 1)
 #define MIDC  (COLS/2 - 1)
 
-int row, column;
-int dr = 0, dc = 0;
-char destroyed;
-int clock = 120;               /* time for all the flights in the game */
-char cross = 0;
-sig_t oldsig;
+int     row, column;
+int     dr = 0, dc = 0;
+char    destroyed;
+int     ourclock = 120;                /* time for all the flights in the game */
+char    cross = 0;
+sig_t   oldsig;
 
 void
-succumb()
+succumb(dummy)
+       int     dummy __attribute__((__unused__));
 {
        if (oldsig == SIG_DFL) {
                endfly();
@@ -65,224 +67,228 @@ succumb()
        }
        if (oldsig != SIG_IGN) {
                endfly();
-               (*oldsig)(SIGINT);
+               (*oldsig) (SIGINT);
        }
 }
 
+int
 visual()
 {
-       void moveenemy();
-
        destroyed = 0;
-       if(initscr() == ERR){
+       if (initscr() == NULL) {
                puts("Whoops!  No more memory...");
-               return(0);
+               return (0);
        }
        oldsig = signal(SIGINT, succumb);
        crmode();
        noecho();
        screen();
-       row = rnd(LINES-3) + 1;
-       column = rnd(COLS-2) + 1;
-       moveenemy();
+       row = rnd(LINES - 3) + 1;
+       column = rnd(COLS - 2) + 1;
+       moveenemy(0);
        for (;;) {
-               switch(getchar()){
-
-                       case 'h':
-                       case 'r':
-                               dc = -1;
-                               fuel--;
-                               break;
-
-                       case 'H':
-                       case 'R':
-                               dc = -5;
-                               fuel -= 10;
-                               break;
-
-                       case 'l':
-                               dc = 1;
-                               fuel--;
-                               break;
-
-                       case 'L':
-                               dc = 5;
-                               fuel -= 10;
-                               break;
-
-                       case 'j':
-                       case 'u':
-                               dr = 1;
-                               fuel--;
-                               break;
-
-                       case 'J':
-                       case 'U':
-                               dr = 5;
-                               fuel -= 10;
-                               break;
-
-                       case 'k':
-                       case 'd':
-                               dr = -1;
-                               fuel--;
-                               break;
-
-                       case 'K':
-                       case 'D':
-                               dr = -5;
-                               fuel -= 10;
-                               break;
-
-                       case '+':
-                               if (cross){
-                                       cross = 0;
-                                       notarget();
+               switch (getchar()) {
+
+               case 'h':
+               case 'r':
+                       dc = -1;
+                       fuel--;
+                       break;
+
+               case 'H':
+               case 'R':
+                       dc = -5;
+                       fuel -= 10;
+                       break;
+
+               case 'l':
+                       dc = 1;
+                       fuel--;
+                       break;
+
+               case 'L':
+                       dc = 5;
+                       fuel -= 10;
+                       break;
+
+               case 'j':
+               case 'u':
+                       dr = 1;
+                       fuel--;
+                       break;
+
+               case 'J':
+               case 'U':
+                       dr = 5;
+                       fuel -= 10;
+                       break;
+
+               case 'k':
+               case 'd':
+                       dr = -1;
+                       fuel--;
+                       break;
+
+               case 'K':
+               case 'D':
+                       dr = -5;
+                       fuel -= 10;
+                       break;
+
+               case '+':
+                       if (cross) {
+                               cross = 0;
+                               notarget();
+                       } else
+                               cross = 1;
+                       break;
+
+               case ' ':
+               case 'f':
+                       if (torps) {
+                               torps -= 2;
+                               blast();
+                               if (row == MIDR && column - MIDC < 2 && MIDC - column < 2) {
+                                       destroyed = 1;
+                                       alarm(0);
                                }
-                               else
-                                       cross = 1;
-                               break;
+                       } else
+                               mvaddstr(0, 0, "*** Out of torpedoes. ***");
+                       break;
 
-                       case ' ':
-                       case 'f':
-                               if (torps){
-                                       torps -= 2;
-                                       blast();
-                                       if (row == MIDR && column - MIDC < 2 && MIDC - column < 2){
-                                               destroyed = 1;
-                                               alarm(0);
-                                       }
-                               }
-                               else
-                                       mvaddstr(0,0,"*** Out of torpedoes. ***");
-                               break;
-
-                       case 'q':
-                               endfly();
-                               return(0);
+               case 'q':
+                       endfly();
+                       return (0);
 
-                       default:
-                               mvaddstr(0,26,"Commands = r,R,l,L,u,U,d,D,f,+,q");
-                               continue;
+               default:
+                       mvaddstr(0, 26, "Commands = r,R,l,L,u,U,d,D,f,+,q");
+                       continue;
 
-                       case EOF:
-                               break;
+               case EOF:
+                       break;
                }
-               if (destroyed){
+               if (destroyed) {
                        endfly();
-                       return(1);
+                       return (1);
                }
-               if (clock <= 0){
+               if (ourclock <= 0) {
                        endfly();
                        die();
                }
        }
 }
 
+void
 screen()
 {
-       register int r,c,n;
-       int i;
+       int     r, c, n;
+       int     i;
 
        clear();
        i = rnd(100);
-       for (n=0; n < i; n++){
-               r = rnd(LINES-3) + 1;
+       for (n = 0; n < i; n++) {
+               r = rnd(LINES - 3) + 1;
                c = rnd(COLS);
                mvaddch(r, c, '.');
        }
-       mvaddstr(LINES-1-1,21,"TORPEDOES           FUEL           TIME");
+       mvaddstr(LINES - 1 - 1, 21, "TORPEDOES           FUEL           TIME");
        refresh();
 }
 
+void
 target()
 {
-       register int n;
+       int     n;
 
-       move(MIDR,MIDC-10);
+       move(MIDR, MIDC - 10);
        addstr("-------   +   -------");
-       for (n = MIDR-4; n < MIDR-1; n++){
-               mvaddch(n,MIDC,'|');
-               mvaddch(n+6,MIDC,'|');
+       for (n = MIDR - 4; n < MIDR - 1; n++) {
+               mvaddch(n, MIDC, '|');
+               mvaddch(n + 6, MIDC, '|');
        }
 }
 
+void
 notarget()
 {
-       register int n;
+       int     n;
 
-       move(MIDR,MIDC-10);
+       move(MIDR, MIDC - 10);
        addstr("                     ");
-       for (n = MIDR-4; n < MIDR-1; n++){
-               mvaddch(n,MIDC,' ');
-               mvaddch(n+6,MIDC,' ');
+       for (n = MIDR - 4; n < MIDR - 1; n++) {
+               mvaddch(n, MIDC, ' ');
+               mvaddch(n + 6, MIDC, ' ');
        }
 }
 
+void
 blast()
 {
-       register int n;
+       int     n;
 
        alarm(0);
-       move(LINES-1, 24);
+       move(LINES - 1, 24);
        printw("%3d", torps);
-       for(n = LINES-1-2; n >= MIDR + 1; n--){
-               mvaddch(n, MIDC+MIDR-n, '/');
-               mvaddch(n, MIDC-MIDR+n, '\\');
+       for (n = LINES - 1 - 2; n >= MIDR + 1; n--) {
+               mvaddch(n, MIDC + MIDR - n, '/');
+               mvaddch(n, MIDC - MIDR + n, '\\');
                refresh();
        }
-       mvaddch(MIDR,MIDC,'*');
-       for(n = LINES-1-2; n >= MIDR + 1; n--){
-               mvaddch(n, MIDC+MIDR-n, ' ');
-               mvaddch(n, MIDC-MIDR+n, ' ');
+       mvaddch(MIDR, MIDC, '*');
+       for (n = LINES - 1 - 2; n >= MIDR + 1; n--) {
+               mvaddch(n, MIDC + MIDR - n, ' ');
+               mvaddch(n, MIDC - MIDR + n, ' ');
                refresh();
        }
        alarm(1);
 }
 
 void
-moveenemy()
+moveenemy(dummy)
+       int     dummy __attribute__((__unused__));
 {
-       double d;
-       int oldr, oldc;
+       double  d;
+       int     oldr, oldc;
 
        oldr = row;
        oldc = column;
-       if (fuel > 0){
-               if (row + dr <= LINES-3 && row + dr > 0)
+       if (fuel > 0) {
+               if (row + dr <= LINES - 3 && row + dr > 0)
                        row += dr;
-               if (column + dc < COLS-1 && column + dc > 0)
+               if (column + dc < COLS - 1 && column + dc > 0)
                        column += dc;
-       } else if (fuel < 0){
-               fuel = 0;
-               mvaddstr(0,60,"*** Out of fuel ***");
-       }
-       d = (double) ((row - MIDR)*(row - MIDR) + (column - MIDC)*(column - MIDC));
-       if (d < 16){
+       } else
+               if (fuel < 0) {
+                       fuel = 0;
+                       mvaddstr(0, 60, "*** Out of fuel ***");
+               }
+       d = (double) ((row - MIDR) * (row - MIDR) + (column - MIDC) * (column - MIDC));
+       if (d < 16) {
                row += (rnd(9) - 4) % (4 - abs(row - MIDR));
                column += (rnd(9) - 4) % (4 - abs(column - MIDC));
        }
-       clock--;
+       ourclock--;
        mvaddstr(oldr, oldc - 1, "   ");
        if (cross)
                target();
        mvaddstr(row, column - 1, "/-\\");
-       move(LINES-1, 24);
+       move(LINES - 1, 24);
        printw("%3d", torps);
-       move(LINES-1, 42);
+       move(LINES - 1, 42);
        printw("%3d", fuel);
-       move(LINES-1, 57);
-       printw("%3d", clock);
+       move(LINES - 1, 57);
+       printw("%3d", ourclock);
        refresh();
        signal(SIGALRM, moveenemy);
        alarm(1);
 }
 
+void
 endfly()
 {
        alarm(0);
        signal(SIGALRM, SIG_DFL);
-       mvcur(0,COLS-1,LINES-1,0);
+       mvcur(0, COLS - 1, LINES - 1, 0);
        endwin();
        signal(SIGTSTP, SIG_DFL);
        signal(SIGINT, oldsig);