]>
git.cameronkatri.com Git - bsdgames-darwin.git/blob - monop/monop.c
1 /* $NetBSD: monop.c,v 1.3 1995/03/23 08:34:52 cgd 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
37 static char copyright
[] =
38 "@(#) 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 static char rcsid
[] = "$NetBSD: monop.c,v 1.3 1995/03/23 08:34:52 cgd Exp $";
53 * This program implements a monopoly game
70 num_luck
= sizeof lucky_mes
/ sizeof (char *);
74 printf("\n%s (%d) (cash $%d) on %s\n", cur_p
->name
, player
+ 1,
75 cur_p
->money
, board
[cur_p
->loc
].name
);
78 execute(getinp("-- Command: ", comlist
));
82 * This routine gets the names of the players
92 if ((num_play
=get_int("How many players? ")) <= 0 ||
94 printf("Sorry. Number must range from 1 to 9\n");
98 cur_p
= play
= (PLAY
*) calloc(num_play
, sizeof (PLAY
));
99 for (i
= 0; i
< num_play
; i
++) {
101 printf("Player %d's name: ", i
+ 1);
102 for (sp
= buf
; (*sp
=getchar()) != '\n'; sp
++)
107 strcpy(name_list
[i
]=play
[i
].name
=(char *)calloc(1,sp
-buf
),buf
);
108 play
[i
].money
= 1500;
110 name_list
[i
++] = "done";
112 for (i
= 0; i
< num_play
; i
++)
113 for (j
= i
+ 1; j
< num_play
; j
++)
114 if (strcasecmp(name_list
[i
], name_list
[j
]) == 0) {
115 if (i
!= num_play
- 1)
116 printf("Hey!!! Some of those are IDENTICAL!! Let's try that again....\n");
118 printf("\"done\" is a reserved word. Please try again\n");
119 for (i
= 0; i
< num_play
; i
++)
126 * This routine figures out who goes first
130 reg
int i
, rl
, cur_max
;
136 for (cur_max
= i
= 0; i
< num_play
; i
++) {
137 printf("%s (%d) rolls %d\n", play
[i
].name
, i
+1, rl
=roll(2, 6));
143 else if (rl
== cur_max
)
147 printf("%d people rolled the same thing, so we'll try again\n",
152 cur_p
= &play
[max_pl
];
153 printf("%s (%d) goes first\n", cur_p
->name
, max_pl
+ 1);
156 * This routine initalizes the monopoly structures.
163 for (mp
= mon
; mp
< &mon
[N_MON
]; mp
++) {
164 mp
->name
= mp
->not_m
;
165 for (i
= 0; i
< mp
->num_in
; i
++)
166 mp
->sq
[i
] = &board
[mp
->sqnums
[i
]];