• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /****************************************************************************
2  * Copyright 2019-2022,2023 Thomas E. Dickey                                *
3  * Copyright 2006-2014,2017 Free Software Foundation, Inc.                  *
4  *                                                                          *
5  * Permission is hereby granted, free of charge, to any person obtaining a  *
6  * copy of this software and associated documentation files (the            *
7  * "Software"), to deal in the Software without restriction, including      *
8  * without limitation the rights to use, copy, modify, merge, publish,      *
9  * distribute, distribute with modifications, sublicense, and/or sell       *
10  * copies of the Software, and to permit persons to whom the Software is    *
11  * furnished to do so, subject to the following conditions:                 *
12  *                                                                          *
13  * The above copyright notice and this permission notice shall be included  *
14  * in all copies or substantial portions of the Software.                   *
15  *                                                                          *
16  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS  *
17  * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF               *
18  * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.   *
19  * IN NO EVENT SHALL THE ABOVE COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,   *
20  * DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR    *
21  * OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR    *
22  * THE USE OR OTHER DEALINGS IN THE SOFTWARE.                               *
23  *                                                                          *
24  * Except as contained in this notice, the name(s) of the above copyright   *
25  * holders shall not be used in advertising or otherwise to promote the     *
26  * sale, use or other dealings in this Software without prior written       *
27  * authorization.                                                           *
28  ****************************************************************************/
29 /*
30  * $Id: echochar.c,v 1.26 2023/05/27 20:13:10 tom Exp $
31  *
32  * Demonstrate the echochar function (compare to dots.c).
33  * Thomas Dickey - 2006/11/4
34  */
35 
36 #include <test.priv.h>
37 
38 #include <time.h>
39 
40 static bool interrupted = FALSE;
41 static long total_chars = 0;
42 static time_t started;
43 
44 static void
cleanup(void)45 cleanup(void)
46 {
47     stop_curses();
48 
49     printf("\n\n%ld total cells, rate %.2f/sec\n",
50 	   total_chars,
51 	   ((double) (total_chars) / (double) (time((time_t *) 0) - started)));
52 }
53 
54 static void
onsig(int n GCC_UNUSED)55 onsig(int n GCC_UNUSED)
56 {
57     interrupted = TRUE;
58 }
59 
60 static double
ranf(void)61 ranf(void)
62 {
63     long r = (rand() & 077777);
64     return ((double) r / 32768.);
65 }
66 
67 static void
set_color(const char * const my_pairs,int fg,int bg)68 set_color(const char *const my_pairs, int fg, int bg)
69 {
70     int pair = (fg * COLORS) + bg;
71     if (pair < COLOR_PAIRS) {
72 	if (!my_pairs[pair]) {
73 	    init_pair((short) pair,
74 		      (short) fg,
75 		      (short) bg);
76 	}
77 	attron(COLOR_PAIR(pair));
78     }
79 }
80 
81 static void
usage(int ok)82 usage(int ok)
83 {
84     static const char *msg[] =
85     {
86 	"Usage: echochar"
87 	,""
88 	,USAGE_COMMON
89 	,"Options:"
90 	," -r       use addch/refresh rather than echochar()"
91     };
92     size_t n;
93 
94     for (n = 0; n < SIZEOF(msg); n++)
95 	fprintf(stderr, "%s\n", msg[n]);
96 
97     ExitProgram(ok ? EXIT_SUCCESS : EXIT_FAILURE);
98 }
99 /* *INDENT-OFF* */
VERSION_COMMON()100 VERSION_COMMON()
101 /* *INDENT-ON* */
102 
103 int
104 main(int argc, char *argv[])
105 {
106     int ch;
107     double r;
108     double c;
109     bool use_colors;
110     bool opt_r = FALSE;
111     char *my_pairs = 0;
112     int last_fg = 0;
113     int last_bg = 0;
114 
115     while ((ch = getopt(argc, argv, OPTS_COMMON "r")) != -1) {
116 	switch (ch) {
117 	case 'r':
118 	    opt_r = TRUE;
119 	    break;
120 	case OPTS_VERSION:
121 	    show_version(argv);
122 	    ExitProgram(EXIT_SUCCESS);
123 	default:
124 	    usage(ch == OPTS_USAGE);
125 	    /* NOTREACHED */
126 	}
127     }
128 
129     InitAndCatch(initscr(), onsig);
130 
131     use_colors = has_colors();
132     if (use_colors) {
133 	start_color();
134 	if (COLOR_PAIRS > 0) {
135 	    my_pairs = typeCalloc(char, (size_t) COLOR_PAIRS);
136 	}
137 	use_colors = (my_pairs != 0);
138     }
139 
140     srand((unsigned) time(0));
141 
142     curs_set(0);
143 
144     r = (double) (LINES - 4);
145     c = (double) (COLS - 4);
146     started = time((time_t *) 0);
147 
148     while (!interrupted) {
149 	int x = (int) (c * ranf()) + 2;
150 	int y = (int) (r * ranf()) + 2;
151 	int p = (ranf() > 0.9) ? '*' : ' ';
152 
153 	move(y, x);
154 	if (use_colors > 0) {
155 	    int z = (int) (ranf() * COLORS);
156 	    if (ranf() > 0.01) {
157 		set_color(my_pairs, z, last_bg);
158 		last_fg = z;
159 	    } else {
160 		set_color(my_pairs, last_fg, z);
161 		last_bg = z;
162 		napms(1);
163 	    }
164 	} else {
165 	    if (ranf() <= 0.01) {
166 		if (ranf() > 0.6)
167 		    attron(A_REVERSE);
168 		else
169 		    attroff(A_REVERSE);
170 		napms(1);
171 	    }
172 	}
173 	if (opt_r) {
174 	    AddCh(UChar(p));
175 	    refresh();
176 	} else {
177 	    echochar(UChar(p));
178 	}
179 	++total_chars;
180     }
181     cleanup();
182     free(my_pairs);
183     ExitProgram(EXIT_SUCCESS);
184 }
185