1*a4cc1f4fSdholland /* $NetBSD: move_robs.c,v 1.10 2009/07/20 06:39:06 dholland Exp $ */
26045e6e0Scgd
361f28255Scgd /*
46045e6e0Scgd * Copyright (c) 1980, 1993
56045e6e0Scgd * The Regents of the University of California. All rights reserved.
661f28255Scgd *
761f28255Scgd * Redistribution and use in source and binary forms, with or without
861f28255Scgd * modification, are permitted provided that the following conditions
961f28255Scgd * are met:
1061f28255Scgd * 1. Redistributions of source code must retain the above copyright
1161f28255Scgd * notice, this list of conditions and the following disclaimer.
1261f28255Scgd * 2. Redistributions in binary form must reproduce the above copyright
1361f28255Scgd * notice, this list of conditions and the following disclaimer in the
1461f28255Scgd * documentation and/or other materials provided with the distribution.
15e5aeb4eaSagc * 3. Neither the name of the University nor the names of its contributors
1661f28255Scgd * may be used to endorse or promote products derived from this software
1761f28255Scgd * without specific prior written permission.
1861f28255Scgd *
1961f28255Scgd * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
2061f28255Scgd * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
2161f28255Scgd * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
2261f28255Scgd * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
2361f28255Scgd * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
2461f28255Scgd * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
2561f28255Scgd * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
2661f28255Scgd * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
2761f28255Scgd * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
2861f28255Scgd * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
2961f28255Scgd * SUCH DAMAGE.
3061f28255Scgd */
3161f28255Scgd
329007937fSlukem #include <sys/cdefs.h>
3361f28255Scgd #ifndef lint
346045e6e0Scgd #if 0
356045e6e0Scgd static char sccsid[] = "@(#)move_robs.c 8.1 (Berkeley) 5/31/93";
366045e6e0Scgd #else
37*a4cc1f4fSdholland __RCSID("$NetBSD: move_robs.c,v 1.10 2009/07/20 06:39:06 dholland Exp $");
386045e6e0Scgd #endif
3961f28255Scgd #endif /* not lint */
4061f28255Scgd
41*a4cc1f4fSdholland #include <curses.h>
42*a4cc1f4fSdholland #include <signal.h>
43*a4cc1f4fSdholland #include <unistd.h>
4461f28255Scgd #include "robots.h"
4561f28255Scgd
4661f28255Scgd /*
4761f28255Scgd * move_robots:
4861f28255Scgd * Move the robots around
4961f28255Scgd */
5061f28255Scgd void
move_robots(int was_sig)5130870bd5Sdholland move_robots(int was_sig)
5261f28255Scgd {
539007937fSlukem COORD *rp;
5461f28255Scgd
5561f28255Scgd if (Real_time)
5661f28255Scgd signal(SIGALRM, move_robots);
5761f28255Scgd #ifdef DEBUG
5861f28255Scgd move(Min.y, Min.x);
5961f28255Scgd addch(inch());
6061f28255Scgd move(Max.y, Max.x);
6161f28255Scgd addch(inch());
62d594ce93Scgd #endif /* DEBUG */
6361f28255Scgd for (rp = Robots; rp < &Robots[MAXROBOTS]; rp++) {
6461f28255Scgd if (rp->y < 0)
6561f28255Scgd continue;
6661f28255Scgd mvaddch(rp->y, rp->x, ' ');
6761f28255Scgd Field[rp->y][rp->x]--;
6861f28255Scgd rp->y += sign(My_pos.y - rp->y);
6961f28255Scgd rp->x += sign(My_pos.x - rp->x);
7061f28255Scgd if (rp->y <= 0)
7161f28255Scgd rp->y = 0;
7261f28255Scgd else if (rp->y >= Y_FIELDSIZE)
7361f28255Scgd rp->y = Y_FIELDSIZE - 1;
7461f28255Scgd if (rp->x <= 0)
7561f28255Scgd rp->x = 0;
7661f28255Scgd else if (rp->x >= X_FIELDSIZE)
7761f28255Scgd rp->x = X_FIELDSIZE - 1;
7861f28255Scgd Field[rp->y][rp->x]++;
7961f28255Scgd }
8061f28255Scgd
8161f28255Scgd Min.y = Y_FIELDSIZE;
8261f28255Scgd Min.x = X_FIELDSIZE;
8361f28255Scgd Max.y = 0;
8461f28255Scgd Max.x = 0;
8561f28255Scgd for (rp = Robots; rp < &Robots[MAXROBOTS]; rp++)
8661f28255Scgd if (rp->y < 0)
8761f28255Scgd continue;
8861f28255Scgd else if (rp->y == My_pos.y && rp->x == My_pos.x)
89*a4cc1f4fSdholland Dead = true;
9061f28255Scgd else if (Field[rp->y][rp->x] > 1) {
9161f28255Scgd mvaddch(rp->y, rp->x, HEAP);
9218dfb39eSchristos Scrap[Num_scrap++] = *rp;
9361f28255Scgd rp->y = -1;
9461f28255Scgd Num_robots--;
9561f28255Scgd if (Waiting)
9661f28255Scgd Wait_bonus++;
9761f28255Scgd add_score(ROB_SCORE);
9861f28255Scgd }
9961f28255Scgd else {
10061f28255Scgd mvaddch(rp->y, rp->x, ROBOT);
10161f28255Scgd if (rp->y < Min.y)
10261f28255Scgd Min.y = rp->y;
10361f28255Scgd if (rp->x < Min.x)
10461f28255Scgd Min.x = rp->x;
10561f28255Scgd if (rp->y > Max.y)
10661f28255Scgd Max.y = rp->y;
10761f28255Scgd if (rp->x > Max.x)
10861f28255Scgd Max.x = rp->x;
10961f28255Scgd }
11061f28255Scgd
11161f28255Scgd if (was_sig) {
11261f28255Scgd refresh();
11361f28255Scgd if (Dead || Num_robots <= 0)
11461f28255Scgd longjmp(End_move, 0);
11561f28255Scgd }
11661f28255Scgd
11761f28255Scgd #ifdef DEBUG
11861f28255Scgd standout();
11961f28255Scgd move(Min.y, Min.x);
12061f28255Scgd addch(inch());
12161f28255Scgd move(Max.y, Max.x);
12261f28255Scgd addch(inch());
12361f28255Scgd standend();
12418dfb39eSchristos #endif /* DEBUG */
12561f28255Scgd if (Real_time)
12661f28255Scgd alarm(3);
12761f28255Scgd }
12861f28255Scgd
12961f28255Scgd /*
13061f28255Scgd * add_score:
13161f28255Scgd * Add a score to the overall point total
13261f28255Scgd */
1339007937fSlukem void
add_score(int add)13430870bd5Sdholland add_score(int add)
13561f28255Scgd {
13661f28255Scgd Score += add;
13761f28255Scgd move(Y_SCORE, X_SCORE);
13861f28255Scgd printw("%d", Score);
13961f28255Scgd }
14061f28255Scgd
14161f28255Scgd /*
14261f28255Scgd * sign:
14361f28255Scgd * Return the sign of the number
14461f28255Scgd */
1459007937fSlukem int
sign(int n)14630870bd5Sdholland sign(int n)
14761f28255Scgd {
14861f28255Scgd if (n < 0)
14961f28255Scgd return -1;
15061f28255Scgd else if (n > 0)
15161f28255Scgd return 1;
15261f28255Scgd else
15361f28255Scgd return 0;
15461f28255Scgd }
155