]>
git.cameronkatri.com Git - bsdgames-darwin.git/blob - monop/monop.c
1 /* $NetBSD: monop.c,v 1.18 2008/02/20 04:48:10 dholland 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. Neither the name of the University nor the names of its contributors
16 * may be used to endorse or promote products derived from this software
17 * without specific prior written permission.
19 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
20 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
21 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
22 * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
23 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
24 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
25 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
26 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
27 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
28 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
32 #include <sys/cdefs.h>
34 __COPYRIGHT("@(#) Copyright (c) 1980, 1993\n\
35 The Regents of the University of California. All rights reserved.\n");
40 static char sccsid
[] = "@(#)monop.c 8.1 (Berkeley) 5/31/93";
42 __RCSID("$NetBSD: monop.c,v 1.18 2008/02/20 04:48:10 dholland Exp $");
53 int main(int, char *[]);
54 static void getplayers(void);
55 static void init_players(void);
56 static void init_monops(void);
57 static void do_quit(int);
61 * This program implements a monopoly game
68 /* Revoke setgid privileges */
82 num_luck
= sizeof lucky_mes
/ sizeof (char *);
84 signal(SIGINT
, do_quit
);
86 printf("\n%s (%d) (cash $%d) on %s\n", cur_p
->name
, player
+ 1,
87 cur_p
->money
, board
[cur_p
->loc
].name
);
90 execute(getinp("-- Command: ", comlist
));
103 * This routine gets the names of the players
114 if ((num_play
= get_int("How many players? ")) <= 0 ||
116 printf("Sorry. Number must range from 1 to 9\n");
120 cur_p
= play
= (PLAY
*) calloc(num_play
, sizeof (PLAY
));
123 for (i
= 0; i
< num_play
; i
++) {
125 printf("Player %d's name: ", i
+ 1);
126 for (sp
= buf
; (*sp
= getchar()) != '\n'; sp
++)
131 name_list
[i
] = play
[i
].name
= (char *)calloc(1, sp
- buf
);
132 if (name_list
[i
] == NULL
)
134 strcpy(play
[i
].name
, buf
);
135 play
[i
].money
= 1500;
137 name_list
[i
++] = "done";
139 for (i
= 0; i
< num_play
; i
++)
140 for (j
= i
+ 1; j
< num_play
; j
++)
141 if (strcasecmp(name_list
[i
], name_list
[j
]) == 0) {
142 if (i
!= num_play
- 1)
143 printf("Hey!!! Some of those are "
144 "IDENTICAL!! Let's try that "
147 printf("\"done\" is a reserved word. "
148 "Please try again\n");
149 for (i
= 0; i
< num_play
; i
++)
157 * This routine figures out who goes first
168 for (cur_max
= i
= 0; i
< num_play
; i
++) {
169 printf("%s (%d) rolls %d\n", play
[i
].name
, i
+1, rl
=roll(2, 6));
175 else if (rl
== cur_max
)
179 printf("%d people rolled the same thing, so we'll try again\n",
184 cur_p
= &play
[max_pl
];
185 printf("%s (%d) goes first\n", cur_p
->name
, max_pl
+ 1);
189 * This routine initializes the monopoly structures.
197 for (mp
= mon
; mp
< &mon
[N_MON
]; mp
++) {
198 mp
->name
= mp
->not_m
;
199 for (i
= 0; i
< mp
->num_in
; i
++)
200 mp
->sq
[i
] = &board
[mp
->sqnums
[i
]];