]> git.cameronkatri.com Git - bsdgames-darwin.git/blobdiff - robots/move.c
fish: remove modulo bias from random number generation
[bsdgames-darwin.git] / robots / move.c
index de030121b08be7b687198c6b8a9a873829ea5f9d..3b13d1f8347809870528a285aaca5a5d246e5dd4 100644 (file)
@@ -1,4 +1,4 @@
-/*     $NetBSD: move.c,v 1.13 2009/07/20 05:44:02 dholland Exp $       */
+/*     $NetBSD: move.c,v 1.16 2009/08/12 08:30:55 dholland Exp $       */
 
 /*
  * Copyright (c) 1980, 1993
 #if 0
 static char sccsid[] = "@(#)move.c     8.1 (Berkeley) 5/31/93";
 #else
-__RCSID("$NetBSD: move.c,v 1.13 2009/07/20 05:44:02 dholland Exp $");
+__RCSID("$NetBSD: move.c,v 1.16 2009/08/12 08:30:55 dholland Exp $");
 #endif
 #endif /* not lint */
 
+#include <sys/types.h>
+#include <sys/ttydefaults.h>  /* for CTRL */
+#include <ctype.h>
+#include <curses.h>
+#include <unistd.h>
 #include "robots.h"
 
-# define       ESC     '\033'
+#define ESC    '\033'
+
+static bool do_move(int, int);
+static bool eaten(const COORD *);
+static bool must_telep(void);
 
 /*
  * get_move:
@@ -49,15 +58,15 @@ __RCSID("$NetBSD: move.c,v 1.13 2009/07/20 05:44:02 dholland Exp $");
 void
 get_move(void)
 {
-       int             c;
+       int c;
 #ifdef FANCY
-       int             lastmove;
+       int lastmove;
 #endif /*FANCY*/
 
        if (Waiting)
                return;
 
-#ifdef FANCY
+#ifdef FANCY
        if (Pattern_roll) {
                if (Next_move >= Move_list)
                        lastmove = *Next_move;
@@ -73,7 +82,7 @@ get_move(void)
                        c = Run_ch;
                else if (Count != 0)
                        c = Cnt_move;
-#ifdef FANCY
+#ifdef FANCY
                else if (Num_robots > 1 && Stand_still)
                        c = '>';
                else if (Num_robots > 1 && Pattern_roll) {
@@ -151,7 +160,7 @@ over:
                  case 'Y': case 'U': case 'H': case 'J':
                  case 'K': case 'L': case 'B': case 'N':
                  case '>':
-                       Running = TRUE;
+                       Running = true;
                        if (c == '>')
                                Run_ch = ' ';
                        else
@@ -166,13 +175,13 @@ over:
                        break;
                  case 'w':
                  case 'W':
-                       Waiting = TRUE;
+                       Waiting = true;
                        leaveok(stdscr, TRUE);
                        goto ret;
                  case 't':
                  case 'T':
 teleport:
-                       Running = FALSE;
+                       Running = false;
                        mvaddch(My_pos.y, My_pos.x, ' ');
                        My_pos = *rnd_pos();
                        telmsg(1);
@@ -207,15 +216,15 @@ ret:
  *     Must I teleport; i.e., is there anywhere I can move without
  * being eaten?
  */
-bool
+static bool
 must_telep(void)
 {
-       int             x, y;
-       static COORD    newpos;
+       int x, y;
+       static COORD newpos;
 
-#ifdef FANCY
+#ifdef FANCY
        if (Stand_still && Num_robots > 1 && eaten(&My_pos))
-               return TRUE;
+               return true;
 #endif
 
        for (y = -1; y <= 1; y++) {
@@ -229,20 +238,20 @@ must_telep(void)
                        if (Field[newpos.y][newpos.x] > 0)
                                continue;
                        if (!eaten(&newpos))
-                               return FALSE;
+                               return false;
                }
        }
-       return TRUE;
+       return true;
 }
 
 /*
  * do_move:
  *     Execute a move
  */
-bool
+static bool
 do_move(int dy, int dx)
 {
-       static COORD    newpos;
+       static COORD newpos;
 
        newpos.y = My_pos.y + dy;
        newpos.x = My_pos.x + dx;
@@ -250,7 +259,7 @@ do_move(int dy, int dx)
            newpos.x <= 0 || newpos.x >= X_FIELDSIZE ||
            Field[newpos.y][newpos.x] > 0 || eaten(&newpos)) {
                if (Running) {
-                       Running = FALSE;
+                       Running = false;
                        leaveok(stdscr, FALSE);
                        move(My_pos.y, My_pos.x);
                        refresh();
@@ -259,26 +268,26 @@ do_move(int dy, int dx)
                        putchar(CTRL('G'));
                        reset_count();
                }
-               return FALSE;
+               return false;
        }
        else if (dy == 0 && dx == 0)
-               return TRUE;
+               return true;
        mvaddch(My_pos.y, My_pos.x, ' ');
        My_pos = newpos;
        mvaddch(My_pos.y, My_pos.x, PLAYER);
        if (!jumping())
                refresh();
-       return TRUE;
+       return true;
 }
 
 /*
  * eaten:
  *     Player would get eaten at this place
  */
-bool
+static bool
 eaten(const COORD *pos)
 {
-       int     x, y;
+       int x, y;
 
        for (y = pos->y - 1; y <= pos->y + 1; y++) {
                if (y <= 0 || y >= Y_FIELDSIZE)
@@ -287,10 +296,10 @@ eaten(const COORD *pos)
                        if (x <= 0 || x >= X_FIELDSIZE)
                                continue;
                        if (Field[y][x] == 1)
-                               return TRUE;
+                               return true;
                }
        }
-       return FALSE;
+       return false;
 }
 
 /*
@@ -301,7 +310,7 @@ void
 reset_count(void)
 {
        Count = 0;
-       Running = FALSE;
+       Running = false;
        leaveok(stdscr, FALSE);
        refresh();
 }