hangman.h 2.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  1. /* $NetBSD: hangman.h,v 1.13 2004/01/27 20:30:29 jsm Exp $ */
  2. /*
  3. * Copyright (c) 1983, 1993
  4. * The Regents of the University of California. All rights reserved.
  5. *
  6. * Redistribution and use in source and binary forms, with or without
  7. * modification, are permitted provided that the following conditions
  8. * are met:
  9. * 1. Redistributions of source code must retain the above copyright
  10. * notice, this list of conditions and the following disclaimer.
  11. * 2. Redistributions in binary form must reproduce the above copyright
  12. * notice, this list of conditions and the following disclaimer in the
  13. * documentation and/or other materials provided with the distribution.
  14. * 3. Neither the name of the University nor the names of its contributors
  15. * may be used to endorse or promote products derived from this software
  16. * without specific prior written permission.
  17. *
  18. * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
  19. * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  20. * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
  21. * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
  22. * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  23. * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
  24. * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
  25. * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
  26. * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
  27. * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  28. * SUCH DAMAGE.
  29. *
  30. * @(#)hangman.h 8.1 (Berkeley) 5/31/93
  31. */
  32. #include <sys/types.h>
  33. #include <sys/stat.h>
  34. #include <ctype.h>
  35. #include <curses.h>
  36. #include <signal.h>
  37. #include <stdlib.h>
  38. #include <string.h>
  39. #include <unistd.h>
  40. #include "pathnames.h"
  41. #define MINLEN 6
  42. #define MAXERRS 7
  43. #define MESGY 12
  44. #define MESGX 0
  45. #define PROMPTY 11
  46. #define PROMPTX 0
  47. #define KNOWNY 10
  48. #define KNOWNX 1
  49. #define NUMBERY 4
  50. #define NUMBERX (COLS - 1 - 26)
  51. #define AVGY 5
  52. #define AVGX (COLS - 1 - 26)
  53. #define GUESSY 2
  54. #define GUESSX (COLS - 1 - 26)
  55. typedef struct {
  56. short y, x;
  57. char ch;
  58. } ERR_POS;
  59. extern bool Guessed[];
  60. extern char Word[], Known[];
  61. extern const char *const Noose_pict[];
  62. extern int Errors, Wordnum;
  63. extern unsigned int Minlen;
  64. extern double Average;
  65. extern const ERR_POS Err_pos[];
  66. extern const char *Dict_name;
  67. extern FILE *Dict;
  68. extern off_t Dict_size;
  69. void die(int) __attribute__((__noreturn__));
  70. void endgame(void);
  71. int main(int, char *[]);
  72. void getguess(void);
  73. void getword(void);
  74. void playgame(void);
  75. void prdata(void);
  76. void prman(void);
  77. void prword(void);
  78. int readch(void);
  79. void setup(void);