]> CyberLeo.Net >> Repos - FreeBSD/FreeBSD.git/blob - games/mille/mille.c
Removed duplicate VCS ID tags, as per style(9).
[FreeBSD/FreeBSD.git] / games / mille / mille.c
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
34 #ifndef lint
35 static const char copyright[] =
36 "@(#) Copyright (c) 1982, 1993\n\
37         The Regents of the University of California.  All rights reserved.\n";
38 #endif /* not lint */
39
40 #ifndef lint
41 #if 0
42 static char sccsid[] = "@(#)mille.c     8.1 (Berkeley) 5/31/93";
43 #else
44 static const char rcsid[] =
45   "$FreeBSD$";
46 #endif
47 #endif /* not lint */
48
49 # include       "mille.h"
50 # include       <signal.h>
51 # ifdef attron
52 #       include <term.h>
53 # endif attron
54
55 /*
56  * @(#)mille.c  1.3 (Berkeley) 5/10/83
57  */
58
59 static void usage __P((void));
60
61 int
62 main(ac, av)
63         int     ac;
64         char    *av[]; {
65
66         bool    restore;
67
68         /* revoke */
69         setgid(getgid());
70
71         if (strcmp(av[0], "a.out") == 0) {
72                 outf = fopen("q", "w");
73                 setbuf(outf, (char *)NULL);
74                 Debug = TRUE;
75         }
76         restore = FALSE;
77         switch (ac) {
78           case 2:
79                 rest_f(av[1]);
80                 restore = TRUE;
81           case 1:
82                 break;
83           default:
84                 usage();
85                 /* NOTREACHED */
86         }
87         Play = PLAYER;
88         initscr();
89         delwin(stdscr);
90         stdscr = Board = newwin(BOARD_Y, BOARD_X, 0, 0);
91         Score = newwin(SCORE_Y, SCORE_X, 0, 40);
92         Miles = newwin(MILES_Y, MILES_X, 17, 0);
93 #ifdef attron
94         idlok(Board, TRUE);
95         idlok(Score, TRUE);
96         idlok(Miles, TRUE);
97 #endif
98         leaveok(Score, TRUE);
99         leaveok(Miles, TRUE);
100         clearok(curscr, TRUE);
101         srandomdev();
102         crmode();
103         noecho();
104         signal(SIGINT, rub);
105         for (;;) {
106                 if (!restore || (Player[PLAYER].total >= 5000
107                     || Player[COMP].total >= 5000)) {
108                         if (Player[COMP].total < Player[PLAYER].total)
109                                 Player[PLAYER].games++;
110                         else if (Player[COMP].total > Player[PLAYER].total)
111                                 Player[COMP].games++;
112                         Player[COMP].total = 0;
113                         Player[PLAYER].total = 0;
114                 }
115                 do {
116                         if (!restore)
117                                 Handstart = Play = other(Handstart);
118                         if (!restore || On_exit) {
119                                 shuffle();
120                                 init();
121                         }
122                         newboard();
123                         if (restore)
124                                 mvwaddstr(Score, ERR_Y, ERR_X, Initstr);
125                         prboard();
126                         do {
127                                 domove();
128                                 if (Finished)
129                                         newscore();
130                                 prboard();
131                         } while (!Finished);
132                         check_more();
133                         restore = On_exit = FALSE;
134                 } while (Player[COMP].total < 5000
135                     && Player[PLAYER].total < 5000);
136         }
137 }
138
139 static void
140 usage()
141 {
142         fprintf(stderr, "usage: mille [restore_file]\n");
143         exit(1);
144 }
145
146 /*
147  *      Routine to trap rubouts, and make sure they really want to
148  * quit.
149  */
150 void
151 rub(sig)
152 int sig; {
153
154         (void)signal(SIGINT, SIG_IGN);
155         if (getyn(REALLYPROMPT))
156                 die(0);
157         (void)signal(SIGINT, rub);
158 }
159
160 /*
161  *      Time to go beddy-by
162  */
163 void
164 die(code)
165 int code; {
166
167         (void)signal(SIGINT, SIG_IGN);
168         if (outf)
169                 fflush(outf);
170         mvcur(0, COLS - 1, LINES - 1, 0);
171         endwin();
172         exit(code);
173 }