cribbage.h revision 1.13 1 1.13 jmc /* $NetBSD: cribbage.h,v 1.13 2005/07/02 08:32:32 jmc 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.9 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.3 cgd * @(#)cribbage.h 8.1 (Berkeley) 5/31/93
32 1.1 cgd */
33 1.1 cgd
34 1.1 cgd extern CARD deck[ CARDS ]; /* a deck */
35 1.1 cgd extern CARD phand[ FULLHAND ]; /* player's hand */
36 1.1 cgd extern CARD chand[ FULLHAND ]; /* computer's hand */
37 1.1 cgd extern CARD crib[ CINHAND ]; /* the crib */
38 1.1 cgd extern CARD turnover; /* the starter */
39 1.1 cgd
40 1.1 cgd extern CARD known[ CARDS ]; /* cards we have seen */
41 1.1 cgd extern int knownum; /* # of cards we know */
42 1.1 cgd
43 1.1 cgd extern int pscore; /* player's score */
44 1.1 cgd extern int cscore; /* comp's score */
45 1.1 cgd extern int glimit; /* points to win game */
46 1.1 cgd
47 1.1 cgd extern int pgames; /* player's games won */
48 1.1 cgd extern int cgames; /* comp's games won */
49 1.1 cgd extern int gamecount; /* # games played */
50 1.1 cgd extern int Lastscore[2]; /* previous score for each */
51 1.1 cgd
52 1.1 cgd extern BOOLEAN iwon; /* if comp won last */
53 1.1 cgd extern BOOLEAN explain; /* player mistakes explained */
54 1.1 cgd extern BOOLEAN rflag; /* if all cuts random */
55 1.1 cgd extern BOOLEAN quiet; /* if suppress random mess */
56 1.1 cgd
57 1.8 thorpej extern char explan[]; /* string for explanation */
58 1.1 cgd
59 1.12 jsm void addmsg(const char *, ...)
60 1.12 jsm __attribute__((__format__(__printf__, 1, 2)));
61 1.11 jsm int adjust(const CARD [], CARD);
62 1.11 jsm int anymove(const CARD [], int, int);
63 1.11 jsm int anysumto(const CARD [], int, int, int);
64 1.11 jsm void bye(void);
65 1.11 jsm int cchose(const CARD [], int, int);
66 1.11 jsm void cdiscard(BOOLEAN);
67 1.11 jsm int chkscr(int *, int);
68 1.11 jsm int comphand(const CARD [], const char *);
69 1.11 jsm void cremove(CARD, CARD [], int);
70 1.11 jsm int cut(BOOLEAN, int);
71 1.13 jmc int deal(BOOLEAN);
72 1.11 jsm void discard(BOOLEAN);
73 1.11 jsm void do_wait(void);
74 1.11 jsm void endmsg(void);
75 1.11 jsm int eq(CARD, CARD);
76 1.11 jsm int fifteens(const CARD [], int);
77 1.11 jsm void game(void);
78 1.11 jsm void gamescore(void);
79 1.11 jsm char *getline(void);
80 1.11 jsm int getuchar(void);
81 1.11 jsm int incard(CARD *);
82 1.11 jsm int infrom(const CARD [], int, const char *);
83 1.11 jsm void instructions(void);
84 1.11 jsm int is_one(CARD, const CARD [], int);
85 1.11 jsm void makeboard(void);
86 1.11 jsm void makedeck(CARD []);
87 1.11 jsm void makeknown(const CARD [], int);
88 1.12 jsm void msg(const char *, ...)
89 1.12 jsm __attribute__((__format__(__printf__, 1, 2)));
90 1.11 jsm int msgcard(CARD, BOOLEAN);
91 1.11 jsm int msgcrd(CARD, BOOLEAN, const char *, BOOLEAN);
92 1.11 jsm int number(int, int, const char *);
93 1.11 jsm int numofval(const CARD [], int, int);
94 1.11 jsm int pairuns(const CARD [], int);
95 1.11 jsm int peg(BOOLEAN);
96 1.11 jsm int pegscore(CARD, const CARD [], int, int);
97 1.11 jsm int playhand(BOOLEAN);
98 1.11 jsm int plyrhand(const CARD [], const char *);
99 1.11 jsm void prcard(WINDOW *, int, int, CARD, BOOLEAN);
100 1.11 jsm void prcrib(BOOLEAN, BOOLEAN);
101 1.11 jsm void prhand(const CARD [], int, WINDOW *, BOOLEAN);
102 1.11 jsm void printcard(WINDOW *, int, CARD, BOOLEAN);
103 1.11 jsm void prpeg(int, int, BOOLEAN);
104 1.11 jsm void prtable(int);
105 1.11 jsm int readchar(void);
106 1.11 jsm void receive_intr(int) __attribute__((__noreturn__));
107 1.11 jsm int score(BOOLEAN);
108 1.11 jsm int scorehand(const CARD [], CARD, int, BOOLEAN, BOOLEAN);
109 1.11 jsm void shuffle(CARD []);
110 1.11 jsm void sorthand(CARD [], int);
111 1.11 jsm void wait_for(int);
112