1 /****************************************************************************
2 * Copyright (c) 2007,2010 Free Software Foundation, Inc. *
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: *
12 * The above copyright notice and this permission notice shall be included *
13 * in all copies or substantial portions of the Software. *
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. *
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 *
27 ****************************************************************************/
29 * $Id: inchs.c,v 1.11 2010/11/13 23:41:23 tom Exp $
31 * Author: Thomas E Dickey
35 chtype winch(WINDOW *win);
36 chtype mvinch(int y, int x);
37 chtype mvwinch(WINDOW *win, int y, int x);
38 int inchstr(chtype *chstr);
39 int inchnstr(chtype *chstr, int n);
40 int winchstr(WINDOW *win, chtype *chstr);
41 int winchnstr(WINDOW *win, chtype *chstr, int n);
42 int mvinchstr(int y, int x, chtype *chstr);
43 int mvinchnstr(int y, int x, chtype *chstr, int n);
44 int mvwinchstr(WINDOW *win, int y, int x, chtype *chstr);
45 int mvwinchnstr(WINDOW *win, int y, int x, chtype *chstr, int n);
48 #include <test.priv.h>
56 return (ch
== ERR
|| ch
== 'q' || ch
== QUIT
|| ch
== ESCAPE
);
60 test_inchs(int level
, char **argv
, WINDOW
*chrwin
, WINDOW
*strwin
)
66 int txt_x
= 0, txt_y
= 0;
69 chtype text
[MAX_COLS
];
71 if (argv
[level
] == 0) {
77 txtbox
= newwin(LINES
- BASE_Y
, COLS
- level
, BASE_Y
, level
);
81 txtwin
= derwin(txtbox
,
91 keypad(txtwin
, TRUE
); /* enable keyboard mapping */
92 (void) cbreak(); /* take input chars one at a time, no wait for \n */
93 (void) noecho(); /* don't echo input */
97 wmove(txtwin
, txt_y
, txt_x
);
99 if ((fp
= fopen(argv
[level
], "r")) != 0) {
100 while ((j
= fgetc(fp
)) != EOF
) {
101 if (waddch(txtwin
, UChar(j
)) != OK
) {
107 wprintw(txtwin
, "Cannot open:\n%s", argv
[1]);
110 while (!Quit(j
= mvwgetch(txtwin
, txt_y
, txt_x
))) {
114 if (txt_y
< getmaxy(txtwin
) - 1)
135 if (txt_x
< getmaxx(txtwin
) - 1)
141 test_inchs(level
+ 1, argv
, chrwin
, strwin
);
144 wnoutrefresh(txtbox
);
147 wnoutrefresh(txtwin
);
155 MvWPrintw(chrwin
, 0, 0, "char:");
158 if (txtwin
!= stdscr
) {
159 wmove(txtwin
, txt_y
, txt_x
);
161 if ((ch
= (int) winch(txtwin
)) != ERR
) {
162 if (waddch(chrwin
, (chtype
) ch
) != ERR
) {
163 for (j
= txt_x
+ 1; j
< getmaxx(txtwin
); ++j
) {
164 if ((ch
= (int) mvwinch(txtwin
, txt_y
, j
)) != ERR
) {
165 if (waddch(chrwin
, (chtype
) ch
) == ERR
) {
177 if ((ch
= (int) inch()) != ERR
) {
178 if (waddch(chrwin
, (chtype
) ch
) != ERR
) {
179 for (j
= txt_x
+ 1; j
< getmaxx(txtwin
); ++j
) {
180 if ((ch
= (int) mvinch(txt_y
, j
)) != ERR
) {
181 if (waddch(chrwin
, (chtype
) ch
) == ERR
) {
191 wnoutrefresh(chrwin
);
193 MvWPrintw(strwin
, 0, 0, "text:");
196 limit
= getmaxx(strwin
) - 5;
198 if (txtwin
!= stdscr
) {
199 wmove(txtwin
, txt_y
, txt_x
);
200 if (winchstr(txtwin
, text
) != ERR
) {
201 MvWAddChStr(strwin
, 0, 5, text
);
204 wmove(txtwin
, txt_y
, txt_x
);
205 if (winchnstr(txtwin
, text
, limit
) != ERR
) {
206 MvWAddChStr(strwin
, 1, 5, text
);
209 if (mvwinchstr(txtwin
, txt_y
, txt_x
, text
) != ERR
) {
210 MvWAddChStr(strwin
, 2, 5, text
);
213 if (mvwinchnstr(txtwin
, txt_y
, txt_x
, text
, limit
) != ERR
) {
214 MvWAddChStr(strwin
, 3, 5, text
);
218 if (inchstr(text
) != ERR
) {
219 MvWAddChStr(strwin
, 0, 5, text
);
223 if (inchnstr(text
, limit
) != ERR
) {
224 MvWAddChStr(strwin
, 1, 5, text
);
227 if (mvinchstr(txt_y
, txt_x
, text
) != ERR
) {
228 MvWAddChStr(strwin
, 2, 5, text
);
231 if (mvinchnstr(txt_y
, txt_x
, text
, limit
) != ERR
) {
232 MvWAddChStr(strwin
, 3, 5, text
);
236 wnoutrefresh(strwin
);
246 main(int argc
, char *argv
[])
252 setlocale(LC_ALL
, "");
255 fprintf(stderr
, "usage: %s file\n", argv
[0]);
261 chrbox
= derwin(stdscr
, BASE_Y
, COLS
, 0, 0);
263 wnoutrefresh(chrbox
);
265 chrwin
= derwin(chrbox
, 1, COLS
- 2, 1, 1);
266 strwin
= derwin(chrbox
, 4, COLS
- 2, 2, 1);
268 test_inchs(1, argv
, chrwin
, strwin
);
271 ExitProgram(EXIT_SUCCESS
);