1 1.13 dholland /* $NetBSD: print.c,v 1.13 2012/06/19 05:35:32 dholland Exp $ */ 2 1.3 cgd 3 1.1 cgd /* 4 1.3 cgd * Copyright (c) 1980, 1993 5 1.3 cgd * The Regents of the University of California. All rights reserved. 6 1.1 cgd * 7 1.1 cgd * Redistribution and use in source and binary forms, with or without 8 1.1 cgd * modification, are permitted provided that the following conditions 9 1.1 cgd * are met: 10 1.1 cgd * 1. Redistributions of source code must retain the above copyright 11 1.1 cgd * notice, this list of conditions and the following disclaimer. 12 1.1 cgd * 2. Redistributions in binary form must reproduce the above copyright 13 1.1 cgd * notice, this list of conditions and the following disclaimer in the 14 1.1 cgd * documentation and/or other materials provided with the distribution. 15 1.7 agc * 3. Neither the name of the University nor the names of its contributors 16 1.1 cgd * may be used to endorse or promote products derived from this software 17 1.1 cgd * without specific prior written permission. 18 1.1 cgd * 19 1.1 cgd * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND 20 1.1 cgd * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 21 1.1 cgd * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 22 1.1 cgd * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE 23 1.1 cgd * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 24 1.1 cgd * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 25 1.1 cgd * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 26 1.1 cgd * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 27 1.1 cgd * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 28 1.1 cgd * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 29 1.1 cgd * SUCH DAMAGE. 30 1.1 cgd */ 31 1.1 cgd 32 1.4 christos #include <sys/cdefs.h> 33 1.1 cgd #ifndef lint 34 1.3 cgd #if 0 35 1.3 cgd static char sccsid[] = "@(#)print.c 8.1 (Berkeley) 5/31/93"; 36 1.3 cgd #else 37 1.13 dholland __RCSID("$NetBSD: print.c,v 1.13 2012/06/19 05:35:32 dholland Exp $"); 38 1.3 cgd #endif 39 1.1 cgd #endif /* not lint */ 40 1.1 cgd 41 1.11 dholland #include "monop.h" 42 1.1 cgd 43 1.6 jsm static const char *header = "Name Own Price Mg # Rent"; 44 1.4 christos 45 1.8 jsm static void printmorg(const SQUARE *); 46 1.1 cgd 47 1.1 cgd /* 48 1.1 cgd * This routine prints out the current board 49 1.1 cgd */ 50 1.4 christos void 51 1.13 dholland printboard(void) 52 1.4 christos { 53 1.5 simonb int i; 54 1.1 cgd 55 1.1 cgd printf("%s\t%s\n", header, header); 56 1.1 cgd for (i = 0; i < N_SQRS/2; i++) { 57 1.1 cgd printsq(i, FALSE); 58 1.1 cgd putchar('\t'); 59 1.1 cgd printsq(i+N_SQRS/2, TRUE); 60 1.1 cgd } 61 1.1 cgd } 62 1.5 simonb 63 1.1 cgd /* 64 1.1 cgd * This routine lists where each player is. 65 1.1 cgd */ 66 1.4 christos void 67 1.13 dholland where(void) 68 1.4 christos { 69 1.5 simonb int i; 70 1.1 cgd 71 1.1 cgd printf("%s Player\n", header); 72 1.1 cgd for (i = 0; i < num_play; i++) { 73 1.1 cgd printsq(play[i].loc, FALSE); 74 1.1 cgd printf(" %s (%d)", play[i].name, i+1); 75 1.1 cgd if (cur_p == &play[i]) 76 1.1 cgd printf(" *"); 77 1.1 cgd putchar('\n'); 78 1.1 cgd } 79 1.1 cgd } 80 1.5 simonb 81 1.1 cgd /* 82 1.1 cgd * This routine prints out an individual square 83 1.1 cgd */ 84 1.4 christos void 85 1.12 christos printsq(int sqn, bool eoln) 86 1.4 christos { 87 1.5 simonb int rnt; 88 1.5 simonb PROP *pp; 89 1.5 simonb SQUARE *sqp; 90 1.1 cgd 91 1.1 cgd sqp = &board[sqn]; 92 1.1 cgd printf("%-10.10s", sqp->name); 93 1.1 cgd switch (sqp->type) { 94 1.1 cgd case SAFE: 95 1.1 cgd case CC: 96 1.1 cgd case CHANCE: 97 1.1 cgd case INC_TAX: 98 1.1 cgd case GOTO_J: 99 1.1 cgd case LUX_TAX: 100 1.1 cgd case IN_JAIL: 101 1.1 cgd if (!eoln) 102 1.1 cgd printf(" "); 103 1.1 cgd break; 104 1.1 cgd case PRPTY: 105 1.1 cgd pp = sqp->desc; 106 1.1 cgd if (sqp->owner < 0) { 107 1.1 cgd printf(" - %-8.8s %3d", pp->mon_desc->name, sqp->cost); 108 1.1 cgd if (!eoln) 109 1.1 cgd printf(" "); 110 1.1 cgd break; 111 1.1 cgd } 112 1.1 cgd printf(" %d %-8.8s %3d", sqp->owner+1, pp->mon_desc->name, 113 1.1 cgd sqp->cost); 114 1.1 cgd printmorg(sqp); 115 1.1 cgd if (pp->monop) { 116 1.1 cgd if (pp->houses < 5) 117 1.1 cgd if (pp->houses > 0) 118 1.1 cgd printf("%d %4d", pp->houses, 119 1.1 cgd pp->rent[pp->houses]); 120 1.1 cgd else 121 1.1 cgd printf("0 %4d", pp->rent[0] * 2); 122 1.1 cgd else 123 1.1 cgd printf("H %4d", pp->rent[5]); 124 1.10 dholland } else 125 1.1 cgd printf(" %4d", pp->rent[0]); 126 1.1 cgd break; 127 1.1 cgd case UTIL: 128 1.1 cgd if (sqp->owner < 0) { 129 1.1 cgd printf(" - 150"); 130 1.1 cgd if (!eoln) 131 1.1 cgd printf(" "); 132 1.1 cgd break; 133 1.1 cgd } 134 1.1 cgd printf(" %d 150", sqp->owner+1); 135 1.1 cgd printmorg(sqp); 136 1.1 cgd printf("%d", play[sqp->owner].num_util); 137 1.1 cgd if (!eoln) 138 1.1 cgd printf(" "); 139 1.1 cgd break; 140 1.1 cgd case RR: 141 1.1 cgd if (sqp->owner < 0) { 142 1.1 cgd printf(" - Railroad 200"); 143 1.1 cgd if (!eoln) 144 1.1 cgd printf(" "); 145 1.1 cgd break; 146 1.1 cgd } 147 1.1 cgd printf(" %d Railroad 200", sqp->owner+1); 148 1.1 cgd printmorg(sqp); 149 1.1 cgd rnt = 25; 150 1.1 cgd rnt <<= play[sqp->owner].num_rr - 1; 151 1.5 simonb printf("%d %4d", play[sqp->owner].num_rr, 152 1.5 simonb 25 << (play[sqp->owner].num_rr - 1)); 153 1.1 cgd break; 154 1.1 cgd } 155 1.1 cgd if (eoln) 156 1.1 cgd putchar('\n'); 157 1.1 cgd } 158 1.5 simonb 159 1.1 cgd /* 160 1.1 cgd * This routine prints out the mortgage flag. 161 1.1 cgd */ 162 1.4 christos static void 163 1.13 dholland printmorg(const SQUARE *sqp) 164 1.4 christos { 165 1.1 cgd if (sqp->desc->morg) 166 1.1 cgd printf(" * "); 167 1.1 cgd else 168 1.1 cgd printf(" "); 169 1.1 cgd } 170 1.5 simonb 171 1.1 cgd /* 172 1.1 cgd * This routine lists the holdings of the player given 173 1.1 cgd */ 174 1.4 christos void 175 1.13 dholland printhold(int pl) 176 1.4 christos { 177 1.5 simonb OWN *op; 178 1.5 simonb PLAY *pp; 179 1.1 cgd 180 1.1 cgd pp = &play[pl]; 181 1.5 simonb printf("%s's (%d) holdings (Total worth: $%d):\n", name_list[pl], 182 1.5 simonb pl + 1, pp->money + prop_worth(pp)); 183 1.1 cgd printf("\t$%d", pp->money); 184 1.1 cgd if (pp->num_gojf) { 185 1.1 cgd printf(", %d get-out-of-jail-free card", pp->num_gojf); 186 1.1 cgd if (pp->num_gojf > 1) 187 1.1 cgd putchar('s'); 188 1.1 cgd } 189 1.1 cgd putchar('\n'); 190 1.1 cgd if (pp->own_list) { 191 1.1 cgd printf("\t%s\n", header); 192 1.1 cgd for (op = pp->own_list; op; op = op->next) { 193 1.1 cgd putchar('\t'); 194 1.1 cgd printsq(sqnum(op->sqr), TRUE); 195 1.1 cgd } 196 1.1 cgd } 197 1.1 cgd } 198