]>
git.cameronkatri.com Git - bsdgames-darwin.git/blob - robots/robots.h
1 /* $NetBSD: robots.h,v 1.14 1999/09/30 18:01:33 jsm Exp $ */
4 * Copyright (c) 1980, 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. All advertising materials mentioning features or use of this software
16 * must display the following acknowledgement:
17 * This product includes software developed by the University of
18 * California, Berkeley and its contributors.
19 * 4. Neither the name of the University nor the names of its contributors
20 * may be used to endorse or promote products derived from this software
21 * without specific prior written permission.
23 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
24 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
25 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
26 * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
27 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
28 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
29 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
30 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
31 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
32 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
35 * @(#)robots.h 8.1 (Berkeley) 5/31/93
38 # include <sys/ttydefaults.h>
53 * miscellaneous constants
56 # define Y_FIELDSIZE 23
57 # define X_FIELDSIZE 60
61 # define MAXROBOTS (MAXLEVELS * 10)
64 # define S_BONUS (60 * ROB_SCORE)
66 # define X_SCORE (X_FIELDSIZE + 9)
67 # define Y_PROMPT (Y_FIELDSIZE - 1)
68 # define X_PROMPT (X_FIELDSIZE + 2)
69 # define MAXSCORES (Y_SIZE - 2)
71 # define MS_NAME "Ten"
74 * characters on screen
97 typedef struct passwd PASSWD
;
103 extern bool Dead
, Full_clear
, Jump
, Newscore
, Real_time
, Running
,
104 Teleport
, Waiting
, Was_bonus
, Auto_bot
;
107 extern bool Pattern_roll
, Stand_still
;
110 extern char Cnt_move
, Field
[Y_FIELDSIZE
][X_FIELDSIZE
], Run_ch
;
111 extern const char *Next_move
, *Move_list
;
113 extern int Count
, Level
, Num_robots
, Num_scrap
, Num_scores
,
114 Start_level
, Wait_bonus
, Num_games
;
116 extern u_int32_t Score
;
118 extern COORD Max
, Min
, My_pos
, Robots
[], Scrap
[];
120 extern jmp_buf End_move
;
126 void add_score
__P((int));
127 bool another
__P((void));
128 int cmp_sc
__P((const void *, const void *));
129 bool do_move
__P((int, int));
130 bool eaten
__P((const COORD
*));
131 void flush_in
__P((void));
132 void get_move
__P((void));
133 void init_field
__P((void));
134 bool jumping
__P((void));
135 void make_level
__P((void));
136 void move_robots
__P((int));
137 bool must_telep
__P((void));
138 void play_level
__P((void));
139 int query
__P((const char *));
140 void quit
__P((int)) __attribute__((__noreturn__
));
141 void reset_count
__P((void));
143 COORD
*rnd_pos
__P((void));
144 void score
__P((int));
145 void set_name
__P((SCORE
*));
146 void show_score
__P((void));
148 char automove
__P((void));