hangman.h revision 1.13 1 1.13 jsm /* $NetBSD: hangman.h,v 1.13 2004/01/27 20:30:29 jsm Exp $ */
2 1.4 cgd
3 1.1 cgd /*
4 1.4 cgd * Copyright (c) 1983, 1993
5 1.4 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.12 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.4 cgd * @(#)hangman.h 8.1 (Berkeley) 5/31/93
32 1.1 cgd */
33 1.1 cgd
34 1.6 lukem #include <sys/types.h>
35 1.6 lukem #include <sys/stat.h>
36 1.6 lukem #include <ctype.h>
37 1.6 lukem #include <curses.h>
38 1.6 lukem #include <signal.h>
39 1.6 lukem #include <stdlib.h>
40 1.6 lukem #include <string.h>
41 1.6 lukem #include <unistd.h>
42 1.6 lukem #include "pathnames.h"
43 1.6 lukem
44 1.6 lukem #define MINLEN 6
45 1.6 lukem #define MAXERRS 7
46 1.6 lukem
47 1.6 lukem #define MESGY 12
48 1.6 lukem #define MESGX 0
49 1.6 lukem #define PROMPTY 11
50 1.6 lukem #define PROMPTX 0
51 1.6 lukem #define KNOWNY 10
52 1.6 lukem #define KNOWNX 1
53 1.6 lukem #define NUMBERY 4
54 1.6 lukem #define NUMBERX (COLS - 1 - 26)
55 1.6 lukem #define AVGY 5
56 1.6 lukem #define AVGX (COLS - 1 - 26)
57 1.6 lukem #define GUESSY 2
58 1.6 lukem #define GUESSX (COLS - 1 - 26)
59 1.1 cgd
60 1.1 cgd
61 1.1 cgd typedef struct {
62 1.6 lukem short y, x;
63 1.6 lukem char ch;
64 1.6 lukem } ERR_POS;
65 1.1 cgd
66 1.6 lukem extern bool Guessed[];
67 1.1 cgd
68 1.8 jsm extern char Word[], Known[];
69 1.8 jsm extern const char *const Noose_pict[];
70 1.1 cgd
71 1.6 lukem extern int Errors, Wordnum;
72 1.11 jsm extern unsigned int Minlen;
73 1.1 cgd
74 1.6 lukem extern double Average;
75 1.1 cgd
76 1.8 jsm extern const ERR_POS Err_pos[];
77 1.1 cgd
78 1.10 jsm extern const char *Dict_name;
79 1.10 jsm
80 1.6 lukem extern FILE *Dict;
81 1.1 cgd
82 1.6 lukem extern off_t Dict_size;
83 1.1 cgd
84 1.13 jsm void die(int) __attribute__((__noreturn__));
85 1.13 jsm void endgame(void);
86 1.13 jsm int main(int, char *[]);
87 1.13 jsm void getguess(void);
88 1.13 jsm void getword(void);
89 1.13 jsm void playgame(void);
90 1.13 jsm void prdata(void);
91 1.13 jsm void prman(void);
92 1.13 jsm void prword(void);
93 1.13 jsm int readch(void);
94 1.13 jsm void setup(void);
95