]> git.cameronkatri.com Git - bsdgames-darwin.git/blobdiff - robots/make_level.c
fish: remove modulo bias from random number generation
[bsdgames-darwin.git] / robots / make_level.c
index 998155db943555afb7811c664253d5ba3dda594c..a88ecb503ef4b9b48e4a5322fe210575963cdc7a 100644 (file)
@@ -1,4 +1,4 @@
-/*     $NetBSD: make_level.c,v 1.3 1995/04/22 10:08:56 cgd Exp $       */
+/*     $NetBSD: make_level.c,v 1.10 2009/07/20 06:39:06 dholland Exp $ */
 
 /*
  * Copyright (c) 1980, 1993
  * 2. Redistributions in binary form must reproduce the above copyright
  *    notice, this list of conditions and the following disclaimer in the
  *    documentation and/or other materials provided with the distribution.
- * 3. All advertising materials mentioning features or use of this software
- *    must display the following acknowledgement:
- *     This product includes software developed by the University of
- *     California, Berkeley and its contributors.
- * 4. Neither the name of the University nor the names of its contributors
+ * 3. Neither the name of the University nor the names of its contributors
  *    may be used to endorse or promote products derived from this software
  *    without specific prior written permission.
  *
  * SUCH DAMAGE.
  */
 
+#include <sys/cdefs.h>
 #ifndef lint
 #if 0
 static char sccsid[] = "@(#)make_level.c       8.1 (Berkeley) 5/31/93";
 #else
-static char rcsid[] = "$NetBSD: make_level.c,v 1.3 1995/04/22 10:08:56 cgd Exp $";
+__RCSID("$NetBSD: make_level.c,v 1.10 2009/07/20 06:39:06 dholland Exp $");
 #endif
 #endif /* not lint */
 
-# include      "robots.h"
+#include <curses.h>
+#include <string.h>
+#include "robots.h"
 
 /*
  * make_level:
  *     Make the current level
  */
-make_level()
+void
+make_level(void)
 {
-       register int    i;
-       register COORD  *cp;
-       register WINDOW *wp;
-       register int    x, *endp;
+       int i;
+       COORD *cp;
+       int x;
 
        reset_count();
        for (i = 1; i < Y_FIELDSIZE; i++)
@@ -62,14 +61,14 @@ make_level()
        if (My_pos.y > 0)
                mvaddch(My_pos.y, My_pos.x, ' ');
 
-       Waiting = FALSE;
+       Waiting = false;
        Wait_bonus = 0;
        leaveok(stdscr, FALSE);
        for (cp = Robots; cp < &Robots[MAXROBOTS]; cp++)
                cp->y = -1;
        My_pos.y = -1;
 
-       bzero(Field, sizeof Field);
+       memset(Field, 0, sizeof Field);
        Min.y = Y_FIELDSIZE;
        Min.x = X_FIELDSIZE;
        Max.y = 0;
@@ -77,6 +76,8 @@ make_level()
        if ((i = Level * 10) > MAXROBOTS)
                i = MAXROBOTS;
        Num_robots = i;
+       memset(Scrap, 0, sizeof(Scrap[0]) * MAXROBOTS);
+       Num_scrap = 0;
        while (i-- > 0) {
                cp = rnd_pos();
                Robots[i] = *cp;