1*211c4183Smestre /* $OpenBSD: misc.c,v 1.14 2016/01/08 18:20:33 mestre Exp $ */
2df930be7Sderaadt /* $NetBSD: misc.c,v 1.4 1995/03/23 08:34:47 cgd Exp $ */
3df930be7Sderaadt
4df930be7Sderaadt /*
5df930be7Sderaadt * Copyright (c) 1980, 1993
6df930be7Sderaadt * The Regents of the University of California. All rights reserved.
7df930be7Sderaadt *
8df930be7Sderaadt * Redistribution and use in source and binary forms, with or without
9df930be7Sderaadt * modification, are permitted provided that the following conditions
10df930be7Sderaadt * are met:
11df930be7Sderaadt * 1. Redistributions of source code must retain the above copyright
12df930be7Sderaadt * notice, this list of conditions and the following disclaimer.
13df930be7Sderaadt * 2. Redistributions in binary form must reproduce the above copyright
14df930be7Sderaadt * notice, this list of conditions and the following disclaimer in the
15df930be7Sderaadt * documentation and/or other materials provided with the distribution.
167a09557bSmillert * 3. Neither the name of the University nor the names of its contributors
17df930be7Sderaadt * may be used to endorse or promote products derived from this software
18df930be7Sderaadt * without specific prior written permission.
19df930be7Sderaadt *
20df930be7Sderaadt * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
21df930be7Sderaadt * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
22df930be7Sderaadt * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
23df930be7Sderaadt * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
24df930be7Sderaadt * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
25df930be7Sderaadt * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
26df930be7Sderaadt * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
27df930be7Sderaadt * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
28df930be7Sderaadt * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
29df930be7Sderaadt * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
30df930be7Sderaadt * SUCH DAMAGE.
31df930be7Sderaadt */
32df930be7Sderaadt
33df930be7Sderaadt #include <ctype.h>
3491d73282Smestre #include <stdio.h>
3591d73282Smestre #include <stdlib.h>
3691d73282Smestre
3791d73282Smestre #include "monop.ext"
38df930be7Sderaadt
39df930be7Sderaadt /*
40df930be7Sderaadt * This routine executes a truncated set of commands until a
41df930be7Sderaadt * "yes or "no" answer is gotten.
42df930be7Sderaadt */
43bb3b10f2Spjanzen int
getyn(char * prompt)44*211c4183Smestre getyn(char *prompt)
45bb3b10f2Spjanzen {
46bb3b10f2Spjanzen int com;
47df930be7Sderaadt
48df930be7Sderaadt for (;;)
4909abf9b2Snicm if ((com=getinp(prompt, ynlist)) < 2)
50df930be7Sderaadt return com;
51df930be7Sderaadt else
52df930be7Sderaadt (*func[com-2])();
53df930be7Sderaadt }
54df930be7Sderaadt /*
55df930be7Sderaadt * This routine tells the player if he's out of money.
56df930be7Sderaadt */
57bb3b10f2Spjanzen void
notify(void)58*211c4183Smestre notify(void)
59bb3b10f2Spjanzen {
60df930be7Sderaadt if (cur_p->money < 0)
61df930be7Sderaadt printf("That leaves you $%d in debt\n", -cur_p->money);
62df930be7Sderaadt else if (cur_p->money == 0)
63df930be7Sderaadt printf("that leaves you broke\n");
64df930be7Sderaadt else if (fixing && !told_em && cur_p->money > 0) {
65df930be7Sderaadt printf("-- You are now Solvent ---\n");
66df930be7Sderaadt told_em = TRUE;
67df930be7Sderaadt }
68df930be7Sderaadt }
69df930be7Sderaadt /*
70df930be7Sderaadt * This routine switches to the next player
71df930be7Sderaadt */
72bb3b10f2Spjanzen void
next_play(void)73*211c4183Smestre next_play(void)
74bb3b10f2Spjanzen {
754318df1eSpjanzen player = (player + 1) % num_play;
76df930be7Sderaadt cur_p = &play[player];
77df930be7Sderaadt num_doub = 0;
78df930be7Sderaadt }
79df930be7Sderaadt /*
80df930be7Sderaadt * This routine gets an integer from the keyboard after the
81df930be7Sderaadt * given prompt.
82df930be7Sderaadt */
83bb3b10f2Spjanzen int
get_int(char * prompt)84*211c4183Smestre get_int(char *prompt)
85bb3b10f2Spjanzen {
86bba3186fSpjanzen int num, snum;
87bb3b10f2Spjanzen char *sp;
88bb3b10f2Spjanzen int c, i;
89df930be7Sderaadt char buf[257];
90df930be7Sderaadt
91df930be7Sderaadt for (;;) {
922ee931d5Sotto printf("%s", prompt);
93df930be7Sderaadt num = 0;
94bba3186fSpjanzen i = 1;
95bb3b10f2Spjanzen for (sp = buf; (c = getchar()) != '\n';) {
96bb3b10f2Spjanzen if (c == EOF) {
97bb3b10f2Spjanzen printf("user closed input stream, quitting...\n");
98bb3b10f2Spjanzen exit(0);
99bb3b10f2Spjanzen }
100bb3b10f2Spjanzen *sp = c;
101bba3186fSpjanzen if (i < (int)sizeof(buf)) {
102bb3b10f2Spjanzen i++;
103bb3b10f2Spjanzen sp++;
104bb3b10f2Spjanzen }
105bb3b10f2Spjanzen }
106cf2fcc31Srahnds *sp = c;
107df930be7Sderaadt if (sp == buf)
108df930be7Sderaadt continue;
10985255e44Smmcc for (sp = buf; isspace((unsigned char)*sp); sp++)
110bba3186fSpjanzen ;
11185255e44Smmcc for (; isdigit((unsigned char)*sp); sp++) {
112bba3186fSpjanzen snum = num;
113df930be7Sderaadt num = num * 10 + *sp - '0';
114bba3186fSpjanzen if (num < snum) {
115bba3186fSpjanzen printf("Number too large - ");
116bba3186fSpjanzen *(sp + 1) = 'X'; /* Force a break */
117bba3186fSpjanzen }
118bba3186fSpjanzen }
119bba3186fSpjanzen /* Be kind to trailing spaces */
120bba3186fSpjanzen for (; *sp == ' '; sp++)
121bba3186fSpjanzen ;
122df930be7Sderaadt if (*sp == '\n')
123df930be7Sderaadt return num;
124df930be7Sderaadt else
125df930be7Sderaadt printf("I can't understand that\n");
126df930be7Sderaadt }
127df930be7Sderaadt }
128df930be7Sderaadt /*
129df930be7Sderaadt * This routine sets the monopoly flag from the list given.
130df930be7Sderaadt */
131bb3b10f2Spjanzen void
set_ownlist(int pl)132*211c4183Smestre set_ownlist(int pl)
133bb3b10f2Spjanzen {
134bb3b10f2Spjanzen int num; /* general counter */
135bb3b10f2Spjanzen MON *orig; /* remember starting monop ptr */
136bb3b10f2Spjanzen OWN *op; /* current owned prop */
137df930be7Sderaadt OWN *orig_op; /* origianl prop before loop */
138df930be7Sderaadt
139df930be7Sderaadt op = play[pl].own_list;
140df930be7Sderaadt #ifdef DEBUG
141bb3b10f2Spjanzen printf("op [%p] = play[pl [%d] ].own_list;\n", op, pl);
142df930be7Sderaadt #endif
143df930be7Sderaadt while (op) {
144df930be7Sderaadt #ifdef DEBUG
145df930be7Sderaadt printf("op->sqr->type = %d\n", op->sqr->type);
146df930be7Sderaadt #endif
147df930be7Sderaadt switch (op->sqr->type) {
148df930be7Sderaadt case UTIL:
149df930be7Sderaadt #ifdef DEBUG
150df930be7Sderaadt printf(" case UTIL:\n");
151df930be7Sderaadt #endif
152df930be7Sderaadt for (num = 0; op && op->sqr->type == UTIL; op = op->next)
153df930be7Sderaadt num++;
154df930be7Sderaadt play[pl].num_util = num;
155df930be7Sderaadt #ifdef DEBUG
156df930be7Sderaadt printf("play[pl].num_util = num [%d];\n", num);
157df930be7Sderaadt #endif
158df930be7Sderaadt break;
159df930be7Sderaadt case RR:
160df930be7Sderaadt #ifdef DEBUG
161df930be7Sderaadt printf(" case RR:\n");
162df930be7Sderaadt #endif
163df930be7Sderaadt for (num = 0; op && op->sqr->type == RR; op = op->next) {
164df930be7Sderaadt #ifdef DEBUG
165df930be7Sderaadt printf("iter: %d\n", num);
166bb3b10f2Spjanzen printf("op = %p, op->sqr = %p, op->sqr->type = %d\n", op, op->sqr, op->sqr->type);
167df930be7Sderaadt #endif
168df930be7Sderaadt num++;
169df930be7Sderaadt }
170df930be7Sderaadt play[pl].num_rr = num;
171df930be7Sderaadt #ifdef DEBUG
172df930be7Sderaadt printf("play[pl].num_rr = num [%d];\n", num);
173df930be7Sderaadt #endif
174df930be7Sderaadt break;
175df930be7Sderaadt case PRPTY:
176df930be7Sderaadt #ifdef DEBUG
177df930be7Sderaadt printf(" case PRPTY:\n");
178df930be7Sderaadt #endif
179df930be7Sderaadt orig = op->sqr->desc->mon_desc;
180df930be7Sderaadt orig_op = op;
181df930be7Sderaadt num = 0;
182df930be7Sderaadt while (op && op->sqr->desc->mon_desc == orig) {
183df930be7Sderaadt #ifdef DEBUG
184df930be7Sderaadt printf("iter: %d\n", num);
185df930be7Sderaadt #endif
186df930be7Sderaadt num++;
187df930be7Sderaadt #ifdef DEBUG
188df930be7Sderaadt printf("op = op->next ");
189df930be7Sderaadt #endif
190df930be7Sderaadt op = op->next;
191df930be7Sderaadt #ifdef DEBUG
192bb3b10f2Spjanzen printf("[%p];\n", op);
193df930be7Sderaadt #endif
194df930be7Sderaadt }
195df930be7Sderaadt #ifdef DEBUG
19699901d2cSderaadt printf("num = %d\n", num);
197df930be7Sderaadt #endif
19834944f90Stedu if (orig == NULL) {
199bb3b10f2Spjanzen printf("panic: bad monopoly descriptor: orig = %p\n", orig);
200df930be7Sderaadt printf("player # %d\n", pl+1);
201df930be7Sderaadt printhold(pl);
202bb3b10f2Spjanzen printf("orig_op = %p\n", orig_op);
20334944f90Stedu if (orig_op) {
20434944f90Stedu printf("orig_op->sqr->type = %d (PRPTY)\n",
20534944f90Stedu orig_op->sqr->type);
20634944f90Stedu printf("orig_op->next = %p\n",
20734944f90Stedu orig_op->next);
20834944f90Stedu printf("orig_op->sqr->desc = %p\n",
20934944f90Stedu orig_op->sqr->desc);
21034944f90Stedu }
211bb3b10f2Spjanzen printf("op = %p\n", op);
21234944f90Stedu if (op) {
21334944f90Stedu printf("op->sqr->type = %d (PRPTY)\n",
21434944f90Stedu op->sqr->type);
215bb3b10f2Spjanzen printf("op->next = %p\n", op->next);
21634944f90Stedu printf("op->sqr->desc = %p\n",
21734944f90Stedu op->sqr->desc);
21834944f90Stedu }
219df930be7Sderaadt printf("num = %d\n", num);
22034944f90Stedu exit(1);
221df930be7Sderaadt }
222df930be7Sderaadt #ifdef DEBUG
223df930be7Sderaadt printf("orig->num_in = %d\n", orig->num_in);
224df930be7Sderaadt #endif
225df930be7Sderaadt if (num == orig->num_in)
226df930be7Sderaadt is_monop(orig, pl);
227df930be7Sderaadt else
228df930be7Sderaadt isnot_monop(orig);
229df930be7Sderaadt break;
230df930be7Sderaadt }
231df930be7Sderaadt }
232df930be7Sderaadt }
233df930be7Sderaadt /*
234df930be7Sderaadt * This routine sets things up as if it is a new monopoly
235df930be7Sderaadt */
236bb3b10f2Spjanzen void
is_monop(MON * mp,int pl)237*211c4183Smestre is_monop(MON *mp, int pl)
238bb3b10f2Spjanzen {
239bb3b10f2Spjanzen int i;
240df930be7Sderaadt
241df930be7Sderaadt mp->owner = pl;
242df930be7Sderaadt mp->num_own = mp->num_in;
243df930be7Sderaadt for (i = 0; i < mp->num_in; i++)
244df930be7Sderaadt mp->sq[i]->desc->monop = TRUE;
245df930be7Sderaadt mp->name = mp->mon_n;
246df930be7Sderaadt }
247df930be7Sderaadt /*
248df930be7Sderaadt * This routine sets things up as if it is no longer a monopoly
249df930be7Sderaadt */
250bb3b10f2Spjanzen void
isnot_monop(MON * mp)251*211c4183Smestre isnot_monop(MON *mp)
252bb3b10f2Spjanzen {
253bb3b10f2Spjanzen int i;
254df930be7Sderaadt
255df930be7Sderaadt mp->owner = -1;
256df930be7Sderaadt for (i = 0; i < mp->num_in; i++)
257df930be7Sderaadt mp->sq[i]->desc->monop = FALSE;
258df930be7Sderaadt mp->name = mp->not_m;
259df930be7Sderaadt }
260df930be7Sderaadt /*
261df930be7Sderaadt * This routine gives a list of the current player's routine
262df930be7Sderaadt */
263bb3b10f2Spjanzen void
list(void)264*211c4183Smestre list(void)
265bb3b10f2Spjanzen {
266df930be7Sderaadt printhold(player);
267df930be7Sderaadt }
268df930be7Sderaadt /*
269df930be7Sderaadt * This routine gives a list of a given players holdings
270df930be7Sderaadt */
271bb3b10f2Spjanzen void
list_all(void)272*211c4183Smestre list_all(void)
273bb3b10f2Spjanzen {
274bb3b10f2Spjanzen int pl;
275df930be7Sderaadt
276df930be7Sderaadt while ((pl=getinp("Whose holdings do you want to see? ", name_list)) < num_play)
277df930be7Sderaadt printhold(pl);
278df930be7Sderaadt }
279df930be7Sderaadt /*
280df930be7Sderaadt * This routine gives the players a chance before it exits.
281df930be7Sderaadt */
282df930be7Sderaadt void
quit(void)283*211c4183Smestre quit(void)
284bb3b10f2Spjanzen {
285df930be7Sderaadt putchar('\n');
286bb3b10f2Spjanzen if (getyn("Do you all really want to quit? ") == 0)
287df930be7Sderaadt exit(0);
288df930be7Sderaadt }
289