Home | History | Annotate | Line # | Download | only in cribbage
cribbage.h revision 1.9
      1 /*	$NetBSD: cribbage.h,v 1.9 2003/08/07 09:37:09 agc Exp $	*/
      2 
      3 /*
      4  * Copyright (c) 1980, 1993
      5  *	The Regents of the University of California.  All rights reserved.
      6  *
      7  * Redistribution and use in source and binary forms, with or without
      8  * modification, are permitted provided that the following conditions
      9  * are met:
     10  * 1. Redistributions of source code must retain the above copyright
     11  *    notice, this list of conditions and the following disclaimer.
     12  * 2. Redistributions in binary form must reproduce the above copyright
     13  *    notice, this list of conditions and the following disclaimer in the
     14  *    documentation and/or other materials provided with the distribution.
     15  * 3. Neither the name of the University nor the names of its contributors
     16  *    may be used to endorse or promote products derived from this software
     17  *    without specific prior written permission.
     18  *
     19  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
     20  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
     21  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
     22  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
     23  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
     24  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
     25  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
     26  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
     27  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
     28  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
     29  * SUCH DAMAGE.
     30  *
     31  *	@(#)cribbage.h	8.1 (Berkeley) 5/31/93
     32  */
     33 
     34 extern  CARD		deck[ CARDS ];		/* a deck */
     35 extern  CARD		phand[ FULLHAND ];	/* player's hand */
     36 extern  CARD		chand[ FULLHAND ];	/* computer's hand */
     37 extern  CARD		crib[ CINHAND ];	/* the crib */
     38 extern  CARD		turnover;		/* the starter */
     39 
     40 extern  CARD		known[ CARDS ];		/* cards we have seen */
     41 extern  int		knownum;		/* # of cards we know */
     42 
     43 extern  int		pscore;			/* player's score */
     44 extern  int		cscore;			/* comp's score */
     45 extern  int		glimit;			/* points to win game */
     46 
     47 extern  int		pgames;			/* player's games won */
     48 extern  int		cgames;			/* comp's games won */
     49 extern  int		gamecount;		/* # games played */
     50 extern	int		Lastscore[2];		/* previous score for each */
     51 
     52 extern  BOOLEAN		iwon;			/* if comp won last */
     53 extern  BOOLEAN		explain;		/* player mistakes explained */
     54 extern  BOOLEAN		rflag;			/* if all cuts random */
     55 extern  BOOLEAN		quiet;			/* if suppress random mess */
     56 extern	BOOLEAN		playing;		/* currently playing game */
     57 
     58 extern  char		explan[];		/* string for explanation */
     59 
     60 void	 addmsg __P((const char *, ...));
     61 int	 adjust __P((const CARD [], CARD));
     62 int	 anymove __P((const CARD [], int, int));
     63 int	 anysumto __P((const CARD [], int, int, int));
     64 void	 bye __P((void));
     65 int	 cchose __P((const CARD [], int, int));
     66 void	 cdiscard __P((BOOLEAN));
     67 int	 chkscr __P((int *, int));
     68 int	 comphand __P((const CARD [], const char *));
     69 void	 cremove __P((CARD, CARD [], int));
     70 int	 cut __P((BOOLEAN, int));
     71 int	 deal __P((int));
     72 void	 discard __P((BOOLEAN));
     73 void	 do_wait __P((void));
     74 void	 endmsg __P((void));
     75 int	 eq __P((CARD, CARD));
     76 int	 fifteens __P((const CARD [], int));
     77 void	 game __P((void));
     78 void	 gamescore __P((void));
     79 char	*getline __P((void));
     80 int	 getuchar __P((void));
     81 int	 incard __P((CARD *));
     82 int	 infrom __P((const CARD [], int, const char *));
     83 void	 instructions __P((void));
     84 int	 is_one __P((CARD, const CARD [], int));
     85 void	 makeboard __P((void));
     86 void	 makedeck __P((CARD []));
     87 void	 makeknown __P((const CARD [], int));
     88 void	 msg __P((const char *, ...));
     89 int	 msgcard __P((CARD, BOOLEAN));
     90 int	 msgcrd __P((CARD, BOOLEAN, const char *, BOOLEAN));
     91 int	 number __P((int, int, const char *));
     92 int	 numofval __P((const CARD [], int, int));
     93 int	 pairuns __P((const CARD [], int));
     94 int	 peg __P((BOOLEAN));
     95 int	 pegscore __P((CARD, const CARD [], int, int));
     96 int	 playhand __P((BOOLEAN));
     97 int	 plyrhand __P((const CARD [], const char *));
     98 void	 prcard __P((WINDOW *, int, int, CARD, BOOLEAN));
     99 void	 prcrib __P((BOOLEAN, BOOLEAN));
    100 void	 prhand __P((const CARD [], int, WINDOW *, BOOLEAN));
    101 void	 printcard __P((WINDOW *, int, CARD, BOOLEAN));
    102 void	 prpeg __P((int, int, BOOLEAN));
    103 void	 prtable __P((int));
    104 int	 readchar __P((void));
    105 void	 rint __P((int)) __attribute__((__noreturn__));
    106 int	 score __P((BOOLEAN));
    107 int	 scorehand __P((const CARD [], CARD, int, BOOLEAN, BOOLEAN));
    108 void	 shuffle __P((CARD []));
    109 void	 sorthand __P((CARD [], int));
    110 void	 wait_for __P((int));
    111