* Copyright (c) 1980 Regents of the University of California.
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* 3. All advertising materials mentioning features or use of this software
* must display the following acknowledgement:
* This product includes software developed by the University of
* California, Berkeley and its contributors.
* 4. Neither the name of the University nor the names of its contributors
* may be used to endorse or promote products derived from this software
* without specific prior written permission.
* THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
* ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
static char sccsid
[] = "@(#)houses.c 5.5 (Berkeley) 6/1/90";
static char *names
[N_MON
+2],
static MON
*monops
[N_MON
];
* These routines deal with buying and selling houses
for (op
= cur_p
->own_list
; op
&& op
->sqr
->type
!= PRPTY
; op
= op
->next
)
if (op
->sqr
->desc
->monop
) {
mp
= op
->sqr
->desc
->mon_desc
;
names
[num_mon
] = (monops
[num_mon
]=mp
)->name
;
for (i
= 0; i
< mp
->num_in
; i
++) {
if (op
->sqr
->desc
->houses
!= 5)
printf("You can't build on mortgaged monopolies.\n");
printf("You can't build any more.\n");
printf("But you don't have any monopolies!!\n");
names
[num_mon
++] = "done";
if ((p
=getinp("Which property do you wish to buy houses for? ", names
)) == num_mon
)
printf("Houses will cost $%d\n", price
);
printf("How many houses do you wish to buy for\n");
for (i
= 0; i
< mp
->num_in
; i
++) {
printf("%s (H):\n", mp
->sq
[i
]->name
);
(void)sprintf(cur_prop
, "%s (%d): ",
mp
->sq
[i
]->name
, pp
->houses
);
input
[i
] = get_int(cur_prop
);
temp
[i
] = input
[i
] + pp
->houses
;
printf("That's too many. The most you can buy is %d\n",
if (mp
->num_in
== 3 && (abs(temp
[0] - temp
[1]) > 1 ||
abs(temp
[0] - temp
[2]) > 1 || abs(temp
[1] - temp
[2]) > 1)) {
err
: printf("That makes the spread too wide. Try again\n");
else if (mp
->num_in
== 2 && abs(temp
[0] - temp
[1]) > 1)
for (tot
= i
= 0; i
< mp
->num_in
; i
++)
printf("You asked for %d houses for $%d\n", tot
, tot
* price
);
if (getyn("Is that ok? ", yn
) == 0) {
cur_p
->money
-= tot
* price
;
for (tot
= i
= 0; i
< mp
->num_in
; i
++)
mp
->sq
[i
]->desc
->houses
= temp
[i
];
* This routine sells houses.
for (op
= cur_p
->own_list
; op
; op
= op
->next
)
if (op
->sqr
->type
== PRPTY
&& op
->sqr
->desc
->monop
) {
mp
= op
->sqr
->desc
->mon_desc
;
names
[num_mon
] = (monops
[num_mon
]=mp
)->name
;
if (!good
&& op
->sqr
->desc
->houses
!= 0)
while (op
->next
&& op
->sqr
->desc
->mon_desc
== mp
printf("You don't have any houses to sell!!\n");
names
[num_mon
++] = "done";
if ((p
=getinp("Which property do you wish to sell houses from? ", names
)) == num_mon
)
printf("Houses will get you $%d apiece\n", price
);
printf("How many houses do you wish to sell from\n");
for (i
= 0; i
< mp
->num_in
; i
++) {
printf("%s (0):\n", mp
->sq
[i
]->name
);
(void)sprintf(cur_prop
,"%s (%d): ",
mp
->sq
[i
]->name
,pp
->houses
);
(void)sprintf(cur_prop
,"%s (H): ",mp
->sq
[i
]->name
);
input
[i
] = get_int(cur_prop
);
temp
[i
] = pp
->houses
- input
[i
];
printf("That's too many. The most you can sell is %d\n", pp
->houses
);
if (mp
->num_in
== 3 && (abs(temp
[0] - temp
[1]) > 1 ||
abs(temp
[0] - temp
[2]) > 1 || abs(temp
[1] - temp
[2]) > 1)) {
err
: printf("That makes the spread too wide. Try again\n");
else if (mp
->num_in
== 2 && abs(temp
[0] - temp
[1]) > 1)
for (tot
= i
= 0; i
< mp
->num_in
; i
++)
printf("You asked to sell %d houses for $%d\n",tot
,tot
* price
);
if (getyn("Is that ok? ", yn
) == 0) {
cur_p
->money
+= tot
* price
;
for (tot
= i
= 0; i
< mp
->num_in
; i
++)
mp
->sq
[i
]->desc
->houses
= temp
[i
];
for (i
= 0; i
< mp
->num_in
; i
++) {
if (sqp
->desc
->houses
== 5)
printf("%s (H) ", sqp
->name
);
printf("%s (%d) ", sqp
->name
, sqp
->desc
->houses
);