]> CyberLeo.Net >> Repos - FreeBSD/FreeBSD.git/blob - games/rain/rain.c
unfinished sblive driver, playback/mixer only for now - not enabled in
[FreeBSD/FreeBSD.git] / games / rain / rain.c
1 /*
2  * Copyright (c) 1980, 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) 1980, 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[] = "@(#)rain.c      8.1 (Berkeley) 5/31/93";
43 #endif
44 static const char rcsid[] =
45  "$FreeBSD$";
46 #endif /* not lint */
47
48 /*
49  * rain 11/3/1980 EPS/CITHEP
50  * cc rain.c -o rain -O -ltermlib
51  */
52
53 #include <sys/types.h>
54 #include <curses.h>
55 #include <err.h>
56 #include <stdio.h>
57 #include <signal.h>
58 #include <stdlib.h>
59 #include <unistd.h>
60
61 volatile sig_atomic_t sig_caught = 0;
62
63 int
64 main(argc, argv)
65         int argc;
66         char **argv;
67 {
68         int x, y, j;
69         long cols, lines;
70         int xpos[5], ypos[5];
71         unsigned int delay = 0;
72         int ch;
73         static void onsig();
74
75         while ((ch = getopt(argc, argv, "d:h")) != -1)
76                 switch (ch) {
77                 case 'd':
78                         if ((delay = (unsigned int)strtoul(optarg, (char **)NULL, 10)) < 1
79                             || delay > 1000)
80                                 errx(1, "invalid delay (1-1000)");
81                         delay *= 1000;  /* ms -> us */
82                         break;
83                 case 'h':
84                 default:
85                         (void)fprintf(stderr, "usage: rain [-d delay]\n");
86                         exit(1);
87                 }
88         srandomdev();
89
90         initscr();
91         cols = COLS - 4;
92         lines = LINES - 4;
93
94         (void)signal(SIGHUP, onsig);
95         (void)signal(SIGINT, onsig);
96         (void)signal(SIGQUIT, onsig);
97         (void)signal(SIGSTOP, onsig);
98         (void)signal(SIGTSTP, onsig);
99         (void)signal(SIGTERM, onsig);
100
101         for (j = 4; j >= 0; --j) {
102                 xpos[j] = random() % cols + 2;
103                 ypos[j] = random() % lines + 2;
104         }
105         for (j = 0;;) {
106                 if (sig_caught) {
107                         endwin();
108                         exit(0);
109                 }
110                 x = random() % cols + 2;
111                 y = random() % lines + 2;
112                 mvaddch(y, x, '.');
113                 mvaddch(ypos[j], xpos[j], 'o');
114                 if (!j--)
115                         j = 4;
116                 mvaddch(ypos[j], xpos[j], 'O');
117                 if (!j--)
118                         j = 4;
119                 mvaddch(ypos[j] - 1, xpos[j], '-');
120                 mvaddstr(ypos[j], xpos[j] - 1, "|.|");
121                 mvaddch(ypos[j] + 1, xpos[j], '-');
122                 if (!j--)
123                         j = 4;
124                 mvaddch(ypos[j] - 2, xpos[j], '-');
125                 mvaddstr(ypos[j] - 1, xpos[j] - 1, "/ \\");
126                 mvaddstr(ypos[j], xpos[j] - 2, "| O |");
127                 mvaddstr(ypos[j] + 1, xpos[j] - 1, "\\ /");
128                 mvaddch(ypos[j] + 2, xpos[j], '-');
129                 if (!j--)
130                         j = 4;
131                 mvaddch(ypos[j] - 2, xpos[j], ' ');
132                 mvaddstr(ypos[j] - 1, xpos[j] - 1, "   ");
133                 mvaddstr(ypos[j], xpos[j] - 2, "     ");
134                 mvaddstr(ypos[j] + 1, xpos[j] - 1, "   ");
135                 mvaddch(ypos[j] + 2, xpos[j], ' ');
136                 xpos[j] = x;
137                 ypos[j] = y;
138                 refresh();
139                 if (delay) usleep(delay);
140         }
141 }
142
143 static void
144 onsig()
145 {
146         sig_caught = 1;
147 }