1 /* 2 * Copyright (c) 1982, 1993 3 * The Regents of the University of California. All rights reserved. 4 * 5 * Redistribution and use in source and binary forms, with or without 6 * modification, are permitted provided that the following conditions 7 * are met: 8 * 1. Redistributions of source code must retain the above copyright 9 * notice, this list of conditions and the following disclaimer. 10 * 2. Redistributions in binary form must reproduce the above copyright 11 * notice, this list of conditions and the following disclaimer in the 12 * documentation and/or other materials provided with the distribution. 13 * 3. All advertising materials mentioning features or use of this software 14 * must display the following acknowledgement: 15 * This product includes software developed by the University of 16 * California, Berkeley and its contributors. 17 * 4. Neither the name of the University nor the names of its contributors 18 * may be used to endorse or promote products derived from this software 19 * without specific prior written permission. 20 * 21 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND 22 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 23 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 24 * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE 25 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 26 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 27 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 28 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 29 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 30 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 31 * SUCH DAMAGE. 32 * 33 * @(#)print.c 8.1 (Berkeley) 5/31/93 34 * $FreeBSD: src/games/mille/print.c,v 1.5 1999/12/12 06:17:24 billf Exp $ 35 * $DragonFly: src/games/mille/print.c,v 1.4 2006/08/27 17:17:23 pavalos Exp $ 36 */ 37 38 # include "mille.h" 39 40 /* 41 * @(#)print.c 1.1 (Berkeley) 4/1/82 42 */ 43 44 # define COMP_STRT 20 45 # define CARD_STRT 2 46 47 static void show_card (int, int, CARD, CARD *); 48 static void show_score (int, int, int, int *); 49 50 void 51 prboard(void) 52 { 53 54 PLAY *pp; 55 int i, j, k, temp; 56 57 for (k = 0; k < 2; k++) { 58 pp = &Player[k]; 59 temp = k * COMP_STRT + CARD_STRT; 60 for (i = 0; i < NUM_SAFE; i++) 61 if (pp->safety[i] == S_PLAYED && !pp->sh_safety[i]) { 62 mvaddstr(i, temp, C_name[i + S_CONV]); 63 if (pp->coups[i]) 64 mvaddch(i, temp - CARD_STRT, '*'); 65 pp->sh_safety[i] = TRUE; 66 } 67 show_card(14, temp, pp->battle, &pp->sh_battle); 68 show_card(16, temp, pp->speed, &pp->sh_speed); 69 for (i = C_25; i <= C_200; i++) { 70 const char *name; 71 int end; 72 73 if (pp->nummiles[i] == pp->sh_nummiles[i]) 74 continue; 75 76 name = C_name[i]; 77 temp = k * 40; 78 end = pp->nummiles[i]; 79 for (j = pp->sh_nummiles[i]; j < end; j++) 80 mvwaddstr(Miles, i + 1, (j << 2) + temp, name); 81 pp->sh_nummiles[i] = end; 82 } 83 } 84 prscore(TRUE); 85 temp = CARD_STRT; 86 pp = &Player[PLAYER]; 87 for (i = 0; i < HAND_SZ; i++) 88 show_card(i + 6, temp, pp->hand[i], &pp->sh_hand[i]); 89 mvprintw(6, COMP_STRT + CARD_STRT, "%2d", Topcard - Deck); 90 show_card(8, COMP_STRT + CARD_STRT, Discard, &Sh_discard); 91 if (End == 1000) { 92 move(EXT_Y, EXT_X); 93 standout(); 94 addstr("Extension"); 95 standend(); 96 } 97 wrefresh(Board); 98 wrefresh(Miles); 99 wrefresh(Score); 100 } 101 102 /* 103 * show_card: 104 * Show the given card if it is different from the last one shown 105 */ 106 static void 107 show_card(int y, int x, CARD c, CARD *lc) 108 { 109 if (c == *lc) 110 return; 111 112 mvprintw(y, x, C_fmt, C_name[c]); 113 *lc = c; 114 } 115 116 static char Score_fmt[] = "%4d"; 117 118 void 119 prscore(bool for_real) 120 { 121 122 PLAY *pp; 123 int x = for_real; /* uses for_real #ifndef EXTRAP */ 124 125 stdscr = Score; 126 for (pp = Player; pp < &Player[2]; pp++) { 127 x = (pp - Player) * 6 + 21; 128 show_score(1, x, pp->mileage, &pp->sh_mileage); 129 if (pp->safescore != pp->sh_safescore) { 130 mvprintw(2, x, Score_fmt, pp->safescore); 131 if (pp->safescore == 400) 132 mvaddstr(3, x + 1, "300"); 133 else 134 mvaddstr(3, x + 1, " 0"); 135 mvprintw(4, x, Score_fmt, pp->coupscore); 136 pp->sh_safescore = pp->safescore; 137 } 138 if (Window == W_FULL || Finished) { 139 #ifdef EXTRAP 140 if (for_real) 141 finalscore(pp); 142 else 143 extrapolate(pp); 144 #else 145 finalscore(pp); 146 #endif 147 show_score(11, x, pp->hand_tot, &pp->sh_hand_tot); 148 show_score(13, x, pp->total, &pp->sh_total); 149 show_score(14, x, pp->games, &pp->sh_games); 150 } 151 else { 152 show_score(6, x, pp->hand_tot, &pp->sh_hand_tot); 153 show_score(8, x, pp->total, &pp->sh_total); 154 show_score(9, x, pp->games, &pp->sh_games); 155 } 156 } 157 stdscr = Board; 158 } 159 160 /* 161 * show_score: 162 * Show a score value if it is different from the last time we 163 * showed it. 164 */ 165 static void 166 show_score(int y, int x, int s, int *ls) 167 { 168 if (s == *ls) 169 return; 170 171 mvprintw(y, x, Score_fmt, s); 172 *ls = s; 173 } 174