* Copyright (c) 1987 Regents of the University of California.
* Redistribution and use in source and binary forms are permitted
* provided that this notice is preserved and that due credit is given
* to the University of California at Berkeley. The name of the University
* may not be used to endorse or promote products derived from this
* software without specific prior written permission. This software
* is provided ``as is'' without express or implied warranty.
"@(#) Copyright (c) 1987 Regents of the University of California.\n\
static char sccsid
[] = "@(#)monop.c 5.4 (Berkeley) %G%";
* This program implements a monopoly game
num_luck
= sizeof lucky_mes
/ sizeof (char *);
printf("\n%s (%d) (cash $%d) on %s\n", cur_p
->name
, player
+ 1,
cur_p
->money
, board
[cur_p
->loc
].name
);
execute(getinp("-- Command: ", comlist
));
* This routine gets the names of the players
if ((num_play
=get_int("How many players? ")) <= 0 ||
printf("Sorry. Number must range from 1 to 9\n");
cur_p
= play
= (PLAY
*) calloc(num_play
, sizeof (PLAY
));
for (i
= 0; i
< num_play
; i
++) {
printf("Player %d's name: ", i
+ 1);
for (sp
= buf
; (*sp
=getchar()) != '\n'; sp
++)
strcpy(name_list
[i
]=play
[i
].name
=(char *)calloc(1,sp
-buf
),buf
);
for (i
= 0; i
< num_play
; i
++)
for (j
= i
+ 1; j
< num_play
; j
++)
if (strcasecmp(name_list
[i
], name_list
[j
]) == 0) {
printf("Hey!!! Some of those are IDENTICAL!! Let's try that again....\n");
printf("\"done\" is a reserved word. Please try again\n");
for (i
= 0; i
< num_play
; i
++)
* This routine figures out who goes first
for (cur_max
= i
= 0; i
< num_play
; i
++) {
printf("%s (%d) rolls %d\n", play
[i
].name
, i
+1, rl
=roll(2, 6));
printf("%d people rolled the same thing, so we'll try again\n",
printf("%s (%d) goes first\n", cur_p
->name
, max_pl
+ 1);
* This routine initalizes the monopoly structures.
for (mp
= mon
; mp
< &mon
[N_MON
]; mp
++) {
for (i
= 0; i
< mp
->num_in
; i
++)
mp
->sq
[i
] = &board
[mp
->sqnum
[i
]];