ncurses 6.0 - patch 20170930
[ncurses.git] / test / dots_curses.c
1 /****************************************************************************
2  * Copyright (c) 2014,2017 Free Software Foundation, Inc.                   *
3  *                                                                          *
4  * Permission is hereby granted, free of charge, to any person obtaining a  *
5  * copy of this software and associated documentation files (the            *
6  * "Software"), to deal in the Software without restriction, including      *
7  * without limitation the rights to use, copy, modify, merge, publish,      *
8  * distribute, distribute with modifications, sublicense, and/or sell       *
9  * copies of the Software, and to permit persons to whom the Software is    *
10  * furnished to do so, subject to the following conditions:                 *
11  *                                                                          *
12  * The above copyright notice and this permission notice shall be included  *
13  * in all copies or substantial portions of the Software.                   *
14  *                                                                          *
15  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS  *
16  * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF               *
17  * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.   *
18  * IN NO EVENT SHALL THE ABOVE COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,   *
19  * DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR    *
20  * OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR    *
21  * THE USE OR OTHER DEALINGS IN THE SOFTWARE.                               *
22  *                                                                          *
23  * Except as contained in this notice, the name(s) of the above copyright   *
24  * holders shall not be used in advertising or otherwise to promote the     *
25  * sale, use or other dealings in this Software without prior written       *
26  * authorization.                                                           *
27  ****************************************************************************/
28
29 /*
30  * Author: Thomas E. Dickey
31  *
32  * $Id: dots_curses.c,v 1.5 2017/09/30 15:41:17 tom Exp $
33  *
34  * A simple demo of the curses interface used for comparison with termcap.
35  */
36 #include <test.priv.h>
37
38 #if !defined(__MINGW32__)
39 #include <sys/time.h>
40 #endif
41
42 #include <time.h>
43
44 #define valid(s) ((s != 0) && s != (char *)-1)
45
46 static bool interrupted = FALSE;
47 static long total_chars = 0;
48 static time_t started;
49
50 static void
51 cleanup(void)
52 {
53     endwin();
54
55     printf("\n\n%ld total chars, rate %.2f/sec\n",
56            total_chars,
57            ((double) (total_chars) / (double) (time((time_t *) 0) - started)));
58 }
59
60 static void
61 onsig(int n GCC_UNUSED)
62 {
63     interrupted = TRUE;
64 }
65
66 static double
67 ranf(void)
68 {
69     long r = (rand() & 077777);
70     return ((double) r / 32768.);
71 }
72
73 static int
74 mypair(int fg, int bg)
75 {
76     int pair = (fg * COLORS) + bg;
77     return (pair >= COLOR_PAIRS) ? -1 : pair;
78 }
79
80 static void
81 set_colors(int fg, int bg)
82 {
83     int pair = mypair(fg, bg);
84     if (pair > 0) {
85         attron(COLOR_PAIR(mypair(fg, bg)));
86     }
87 }
88
89 int
90 main(int argc GCC_UNUSED,
91      char *argv[]GCC_UNUSED)
92 {
93     int x, y, z, p;
94     int fg, bg;
95     double r;
96     double c;
97
98     srand((unsigned) time(0));
99
100     InitAndCatch(initscr(), onsig);
101     if (has_colors()) {
102         start_color();
103         for (fg = 0; fg < COLORS; fg++) {
104             for (bg = 0; bg < COLORS; bg++) {
105                 int pair = mypair(fg, bg);
106                 if (pair > 0)
107                     init_pair((short) pair, (short) fg, (short) bg);
108             }
109         }
110     }
111
112     r = (double) (LINES - 4);
113     c = (double) (COLS - 4);
114     started = time((time_t *) 0);
115
116     fg = COLOR_WHITE;
117     bg = COLOR_BLACK;
118     while (!interrupted) {
119         x = (int) (c * ranf()) + 2;
120         y = (int) (r * ranf()) + 2;
121         p = (ranf() > 0.9) ? '*' : ' ';
122
123         move(y, x);
124         if (has_colors()) {
125             z = (int) (ranf() * COLORS);
126             if (ranf() > 0.01) {
127                 set_colors(fg = z, bg);
128                 attron(COLOR_PAIR(mypair(fg, bg)));
129             } else {
130                 set_colors(fg, bg = z);
131                 napms(1);
132             }
133         } else {
134             if (ranf() <= 0.01) {
135                 if (ranf() > 0.6) {
136                     attron(A_REVERSE);
137                 } else {
138                     attroff(A_REVERSE);
139                 }
140                 napms(1);
141             }
142         }
143         AddCh(p);
144         refresh();
145         ++total_chars;
146     }
147     cleanup();
148     ExitProgram(EXIT_SUCCESS);
149 }