]>
git.cameronkatri.com Git - bsdgames-darwin.git/blob - monop/monop.c
1 /* $NetBSD: monop.c,v 1.9 1999/09/12 09:02:22 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
36 #include <sys/cdefs.h>
38 __COPYRIGHT("@(#) Copyright (c) 1980, 1993\n\
39 The Regents of the University of California. All rights reserved.\n");
44 static char sccsid
[] = "@(#)monop.c 8.1 (Berkeley) 5/31/93";
46 __RCSID("$NetBSD: monop.c,v 1.9 1999/09/12 09:02:22 jsm Exp $");
56 int main
__P((int, char *[]));
57 static void getplayers
__P((void));
58 static void init_players
__P((void));
59 static void init_monops
__P((void));
60 static void do_quit
__P((int));
63 * This program implements a monopoly game
70 /* Revoke setgid privileges */
71 setregid(getgid(), getgid());
83 num_luck
= sizeof lucky_mes
/ sizeof (char *);
85 signal(SIGINT
, do_quit
);
87 printf("\n%s (%d) (cash $%d) on %s\n", cur_p
->name
, player
+ 1,
88 cur_p
->money
, board
[cur_p
->loc
].name
);
91 execute(getinp("-- Command: ", comlist
));
98 int n
__attribute__((__unused__
));
104 * This routine gets the names of the players
115 if ((num_play
=get_int("How many players? ")) <= 0 ||
117 printf("Sorry. Number must range from 1 to 9\n");
121 cur_p
= play
= (PLAY
*) calloc(num_play
, sizeof (PLAY
));
123 errx(1, "out of memory");
124 for (i
= 0; i
< num_play
; i
++) {
126 printf("Player %d's name: ", i
+ 1);
127 for (sp
= buf
; (*sp
=getchar()) != '\n'; sp
++)
132 name_list
[i
] = play
[i
].name
= (char *)calloc(1, sp
- buf
);
133 if (name_list
[i
] == NULL
)
134 errx(1, "out of memory");
135 strcpy(play
[i
].name
, buf
);
136 play
[i
].money
= 1500;
138 name_list
[i
++] = "done";
140 for (i
= 0; i
< num_play
; i
++)
141 for (j
= i
+ 1; j
< num_play
; j
++)
142 if (strcasecmp(name_list
[i
], name_list
[j
]) == 0) {
143 if (i
!= num_play
- 1)
144 printf("Hey!!! Some of those are "
145 "IDENTICAL!! Let's try that "
148 printf("\"done\" is a reserved word. "
149 "Please try again\n");
150 for (i
= 0; i
< num_play
; i
++)
158 * This routine figures out who goes first
169 for (cur_max
= i
= 0; i
< num_play
; i
++) {
170 printf("%s (%d) rolls %d\n", play
[i
].name
, i
+1, rl
=roll(2, 6));
176 else if (rl
== cur_max
)
180 printf("%d people rolled the same thing, so we'll try again\n",
185 cur_p
= &play
[max_pl
];
186 printf("%s (%d) goes first\n", cur_p
->name
, max_pl
+ 1);
190 * This routine initalizes the monopoly structures.
198 for (mp
= mon
; mp
< &mon
[N_MON
]; mp
++) {
199 mp
->name
= mp
->not_m
;
200 for (i
= 0; i
< mp
->num_in
; i
++)
201 mp
->sq
[i
] = &board
[mp
->sqnums
[i
]];