border.c revision 1.12 1 1.12 roy /* $NetBSD: border.c,v 1.12 2009/07/22 16:57:14 roy Exp $ */
2 1.2 blymn
3 1.2 blymn /*
4 1.2 blymn * Copyright (c) 2000 The NetBSD Foundation, Inc.
5 1.2 blymn * All rights reserved.
6 1.2 blymn *
7 1.2 blymn * This code is derived from software contributed to The NetBSD Foundation
8 1.2 blymn * by Julian Coleman.
9 1.2 blymn *
10 1.2 blymn * Redistribution and use in source and binary forms, with or without
11 1.2 blymn * modification, are permitted provided that the following conditions
12 1.2 blymn * are met:
13 1.2 blymn * 1. Redistributions of source code must retain the above copyright
14 1.2 blymn * notice, this list of conditions and the following disclaimer.
15 1.2 blymn * 2. Redistributions in binary form must reproduce the above copyright
16 1.2 blymn * notice, this list of conditions and the following disclaimer in the
17 1.2 blymn * documentation and/or other materials provided with the distribution.
18 1.2 blymn *
19 1.2 blymn * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
20 1.2 blymn * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
21 1.2 blymn * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
22 1.2 blymn * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
23 1.2 blymn * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
24 1.2 blymn * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
25 1.2 blymn * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
26 1.2 blymn * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
27 1.2 blymn * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
28 1.2 blymn * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
29 1.2 blymn * POSSIBILITY OF SUCH DAMAGE.
30 1.2 blymn */
31 1.6 blymn
32 1.6 blymn #include <sys/cdefs.h>
33 1.6 blymn #ifndef lint
34 1.12 roy __RCSID("$NetBSD: border.c,v 1.12 2009/07/22 16:57:14 roy Exp $");
35 1.6 blymn #endif /* not lint */
36 1.2 blymn
37 1.10 blymn #include <stdlib.h>
38 1.10 blymn #include <string.h>
39 1.10 blymn
40 1.2 blymn #include "curses.h"
41 1.2 blymn #include "curses_private.h"
42 1.2 blymn
43 1.4 blymn #ifndef _CURSES_USE_MACROS
44 1.4 blymn
45 1.4 blymn /*
46 1.4 blymn * border --
47 1.10 blymn * Draw a border around stdscr using the specified
48 1.4 blymn * delimiting characters.
49 1.4 blymn */
50 1.4 blymn int
51 1.4 blymn border(chtype left, chtype right, chtype top, chtype bottom, chtype topleft,
52 1.4 blymn chtype topright, chtype botleft, chtype botright)
53 1.4 blymn {
54 1.4 blymn return wborder(stdscr, left, right, top, bottom, topleft, topright,
55 1.10 blymn botleft, botright);
56 1.4 blymn }
57 1.4 blymn
58 1.4 blymn #endif
59 1.4 blymn
60 1.2 blymn /*
61 1.2 blymn * wborder --
62 1.2 blymn * Draw a border around the given window using the specified delimiting
63 1.2 blymn * characters.
64 1.2 blymn */
65 1.2 blymn int
66 1.4 blymn wborder(WINDOW *win, chtype left, chtype right, chtype top, chtype bottom,
67 1.4 blymn chtype topleft, chtype topright, chtype botleft, chtype botright)
68 1.2 blymn {
69 1.2 blymn int endy, endx, i;
70 1.2 blymn __LDATA *fp, *lp;
71 1.2 blymn
72 1.7 jdc if (!(left & __CHARTEXT))
73 1.7 jdc left |= ACS_VLINE;
74 1.7 jdc if (!(right & __CHARTEXT))
75 1.7 jdc right |= ACS_VLINE;
76 1.7 jdc if (!(top & __CHARTEXT))
77 1.7 jdc top |= ACS_HLINE;
78 1.7 jdc if (!(bottom & __CHARTEXT))
79 1.7 jdc bottom |= ACS_HLINE;
80 1.7 jdc if (!(topleft & __CHARTEXT))
81 1.7 jdc topleft |= ACS_ULCORNER;
82 1.7 jdc if (!(topright & __CHARTEXT))
83 1.7 jdc topright |= ACS_URCORNER;
84 1.7 jdc if (!(botleft & __CHARTEXT))
85 1.7 jdc botleft |= ACS_LLCORNER;
86 1.7 jdc if (!(botright & __CHARTEXT))
87 1.7 jdc botright |= ACS_LRCORNER;
88 1.2 blymn
89 1.2 blymn #ifdef DEBUG
90 1.9 jdc __CTRACE(__CTRACE_INPUT, "wborder: left = %c, 0x%x\n",
91 1.9 jdc left & __CHARTEXT, left & __ATTRIBUTES);
92 1.9 jdc __CTRACE(__CTRACE_INPUT, "wborder: right = %c, 0x%x\n",
93 1.9 jdc right & __CHARTEXT, right & __ATTRIBUTES);
94 1.9 jdc __CTRACE(__CTRACE_INPUT, "wborder: top = %c, 0x%x\n",
95 1.9 jdc top & __CHARTEXT, top & __ATTRIBUTES);
96 1.9 jdc __CTRACE(__CTRACE_INPUT, "wborder: bottom = %c, 0x%x\n",
97 1.9 jdc bottom & __CHARTEXT, bottom & __ATTRIBUTES);
98 1.9 jdc __CTRACE(__CTRACE_INPUT, "wborder: topleft = %c, 0x%x\n",
99 1.9 jdc topleft & __CHARTEXT, topleft & __ATTRIBUTES);
100 1.9 jdc __CTRACE(__CTRACE_INPUT, "wborder: topright = %c, 0x%x\n",
101 1.9 jdc topright & __CHARTEXT, topright & __ATTRIBUTES);
102 1.9 jdc __CTRACE(__CTRACE_INPUT, "wborder: botleft = %c, 0x%x\n",
103 1.9 jdc botleft & __CHARTEXT, botleft & __ATTRIBUTES);
104 1.9 jdc __CTRACE(__CTRACE_INPUT, "wborder: botright = %c, 0x%x\n",
105 1.9 jdc botright & __CHARTEXT, botright & __ATTRIBUTES);
106 1.2 blymn #endif
107 1.2 blymn
108 1.8 jdc /* Merge window and background attributes */
109 1.3 jdc left |= (left & __COLOR) ? (win->wattr & ~__COLOR) : win->wattr;
110 1.8 jdc left |= (left & __COLOR) ? (win->battr & ~__COLOR) : win->battr;
111 1.3 jdc right |= (right & __COLOR) ? (win->wattr & ~__COLOR) : win->wattr;
112 1.8 jdc right |= (right & __COLOR) ? (win->battr & ~__COLOR) : win->battr;
113 1.3 jdc top |= (top & __COLOR) ? (win->wattr & ~__COLOR) : win->wattr;
114 1.8 jdc top |= (top & __COLOR) ? (win->battr & ~__COLOR) : win->battr;
115 1.3 jdc bottom |= (bottom & __COLOR) ? (win->wattr & ~__COLOR) : win->wattr;
116 1.8 jdc bottom |= (bottom & __COLOR) ? (win->battr & ~__COLOR) : win->battr;
117 1.3 jdc topleft |= (topleft & __COLOR) ? (win->wattr & ~__COLOR) : win->wattr;
118 1.8 jdc topleft |= (topleft & __COLOR) ? (win->battr & ~__COLOR) : win->battr;
119 1.3 jdc topright |= (topright & __COLOR) ? (win->wattr & ~__COLOR) : win->wattr;
120 1.8 jdc topright |= (topright & __COLOR) ? (win->battr & ~__COLOR) : win->battr;
121 1.3 jdc botleft |= (botleft & __COLOR) ? (win->wattr & ~__COLOR) : win->wattr;
122 1.8 jdc botleft |= (botleft & __COLOR) ? (win->battr & ~__COLOR) : win->battr;
123 1.3 jdc botright |= (botright & __COLOR) ? (win->wattr & ~__COLOR) : win->wattr;
124 1.8 jdc botright |= (botright & __COLOR) ? (win->battr & ~__COLOR) : win->battr;
125 1.2 blymn
126 1.2 blymn endx = win->maxx - 1;
127 1.2 blymn endy = win->maxy - 1;
128 1.12 roy fp = win->alines[0]->line;
129 1.12 roy lp = win->alines[endy]->line;
130 1.2 blymn
131 1.2 blymn /* Sides */
132 1.2 blymn for (i = 1; i < endy; i++) {
133 1.12 roy win->alines[i]->line[0].ch = (wchar_t) left & __CHARTEXT;
134 1.12 roy win->alines[i]->line[0].attr = (attr_t) left & __ATTRIBUTES;
135 1.12 roy win->alines[i]->line[endx].ch = (wchar_t) right & __CHARTEXT;
136 1.12 roy win->alines[i]->line[endx].attr = (attr_t) right & __ATTRIBUTES;
137 1.10 blymn #ifdef HAVE_WCHAR
138 1.12 roy SET_WCOL(win->alines[i]->line[0], 1);
139 1.12 roy SET_WCOL(win->alines[i]->line[endx], 1);
140 1.10 blymn #endif
141 1.2 blymn }
142 1.2 blymn for (i = 1; i < endx; i++) {
143 1.2 blymn fp[i].ch = (wchar_t) top & __CHARTEXT;
144 1.2 blymn fp[i].attr = (attr_t) top & __ATTRIBUTES;
145 1.2 blymn lp[i].ch = (wchar_t) bottom & __CHARTEXT;
146 1.2 blymn lp[i].attr = (attr_t) bottom & __ATTRIBUTES;
147 1.10 blymn #ifdef HAVE_WCHAR
148 1.10 blymn SET_WCOL(fp[i], 1);
149 1.10 blymn SET_WCOL(lp[i], 1);
150 1.10 blymn #endif
151 1.2 blymn }
152 1.2 blymn
153 1.2 blymn /* Corners */
154 1.2 blymn if (!(win->maxx == LINES && win->maxy == COLS &&
155 1.2 blymn (win->flags & __SCROLLOK) && (win->flags & __SCROLLWIN))) {
156 1.2 blymn fp[0].ch = (wchar_t) topleft & __CHARTEXT;
157 1.2 blymn fp[0].attr = (attr_t) topleft & __ATTRIBUTES;
158 1.2 blymn fp[endx].ch = (wchar_t) topright & __CHARTEXT;
159 1.2 blymn fp[endx].attr = (attr_t) topright & __ATTRIBUTES;
160 1.2 blymn lp[0].ch = (wchar_t) botleft & __CHARTEXT;
161 1.2 blymn lp[0].attr = (attr_t) botleft & __ATTRIBUTES;
162 1.2 blymn lp[endx].ch = (wchar_t) botright & __CHARTEXT;
163 1.2 blymn lp[endx].attr = (attr_t) botright & __ATTRIBUTES;
164 1.10 blymn #ifdef HAVE_WCHAR
165 1.10 blymn SET_WCOL(fp[0], 1);
166 1.10 blymn SET_WCOL(fp[endx], 1);
167 1.10 blymn SET_WCOL(lp[0], 1);
168 1.10 blymn SET_WCOL(lp[endx], 1);
169 1.10 blymn #endif
170 1.10 blymn }
171 1.10 blymn __touchwin(win);
172 1.10 blymn return (OK);
173 1.10 blymn }
174 1.10 blymn
175 1.10 blymn int border_set(const cchar_t *ls, const cchar_t *rs, const cchar_t *ts,
176 1.10 blymn const cchar_t *bs, const cchar_t *tl, const cchar_t *tr,
177 1.10 blymn const cchar_t *bl, const cchar_t *br)
178 1.10 blymn {
179 1.10 blymn #ifndef HAVE_WCHAR
180 1.10 blymn return ERR;
181 1.10 blymn #else
182 1.10 blymn return wborder_set(stdscr, ls, rs, ts, bs, tl, tr, bl, br);
183 1.10 blymn #endif /* HAVE_WCHAR */
184 1.10 blymn }
185 1.10 blymn
186 1.10 blymn int wborder_set(WINDOW *win, const cchar_t *ls, const cchar_t *rs,
187 1.10 blymn const cchar_t *ts, const cchar_t *bs,
188 1.10 blymn const cchar_t *tl, const cchar_t *tr,
189 1.10 blymn const cchar_t *bl, const cchar_t *br)
190 1.10 blymn {
191 1.10 blymn #ifndef HAVE_WCHAR
192 1.10 blymn return ERR;
193 1.10 blymn #else
194 1.10 blymn int endy, endx, i, j, k, cw, pcw, tlcw, blcw, trcw, brcw;
195 1.10 blymn cchar_t left, right, bottom, top, topleft, topright, botleft, botright;
196 1.10 blymn nschar_t *np, *tnp;
197 1.10 blymn
198 1.10 blymn if ( ls && wcwidth( ls->vals[ 0 ]))
199 1.10 blymn memcpy( &left, ls, sizeof( cchar_t ));
200 1.10 blymn else
201 1.10 blymn setcchar( &left, &WACS_VLINE, win->wattr, 0, NULL );
202 1.10 blymn if ( rs && wcwidth( rs->vals[ 0 ]))
203 1.10 blymn memcpy( &right, rs, sizeof( cchar_t ));
204 1.10 blymn else
205 1.10 blymn setcchar( &right, &WACS_VLINE, win->wattr, 0, NULL );
206 1.10 blymn if ( ts && wcwidth( ts->vals[ 0 ]))
207 1.10 blymn memcpy( &top, ts, sizeof( cchar_t ));
208 1.10 blymn else
209 1.10 blymn setcchar( &top, &WACS_HLINE, win->wattr, 0, NULL );
210 1.10 blymn if ( bs && wcwidth( bs->vals[ 0 ]))
211 1.10 blymn memcpy( &bottom, bs, sizeof( cchar_t ));
212 1.10 blymn else
213 1.10 blymn setcchar( &bottom, &WACS_HLINE, win->wattr, 0, NULL );
214 1.10 blymn if ( tl && wcwidth( tl->vals[ 0 ]))
215 1.10 blymn memcpy( &topleft, tl, sizeof( cchar_t ));
216 1.10 blymn else
217 1.10 blymn setcchar( &topleft, &WACS_ULCORNER, win->wattr, 0, NULL );
218 1.10 blymn if ( tr && wcwidth( tr->vals[ 0 ]))
219 1.10 blymn memcpy( &topright, tr, sizeof( cchar_t ));
220 1.10 blymn else
221 1.10 blymn setcchar( &topright, &WACS_URCORNER, win->wattr, 0, NULL );
222 1.10 blymn if ( bl && wcwidth( bl->vals[ 0 ]))
223 1.10 blymn memcpy( &botleft, bl, sizeof( cchar_t ));
224 1.10 blymn else
225 1.10 blymn setcchar( &botleft, &WACS_LLCORNER, win->wattr, 0, NULL );
226 1.10 blymn if ( br && wcwidth( br->vals[ 0 ]))
227 1.10 blymn memcpy( &botright, br, sizeof( cchar_t ));
228 1.10 blymn else
229 1.10 blymn setcchar( &botright, &WACS_LRCORNER, win->wattr, 0, NULL );
230 1.10 blymn
231 1.10 blymn #ifdef DEBUG
232 1.10 blymn __CTRACE(__CTRACE_INPUT, "wborder_set: left = %c, 0x%x\n",
233 1.10 blymn left.vals[0], left.attributes );
234 1.10 blymn __CTRACE(__CTRACE_INPUT, "wborder_set: right = %c, 0x%x\n",
235 1.10 blymn right.vals[0], right.attributes );
236 1.10 blymn __CTRACE(__CTRACE_INPUT, "wborder_set: top = %c, 0x%x\n",
237 1.10 blymn top.vals[0], top.attributes );
238 1.10 blymn __CTRACE(__CTRACE_INPUT, "wborder_set: bottom = %c, 0x%x\n",
239 1.10 blymn bottom.vals[0], bottom.attributes );
240 1.10 blymn __CTRACE(__CTRACE_INPUT, "wborder_set: topleft = %c, 0x%x\n",
241 1.10 blymn topleft.vals[0], topleft.attributes );
242 1.10 blymn __CTRACE(__CTRACE_INPUT, "wborder_set: topright = %c, 0x%x\n",
243 1.10 blymn topright.vals[0], topright.attributes );
244 1.10 blymn __CTRACE(__CTRACE_INPUT, "wborder_set: botleft = %c, 0x%x\n",
245 1.10 blymn botleft.vals[0], botleft.attributes );
246 1.10 blymn __CTRACE(__CTRACE_INPUT, "wborder_set: botright = %c, 0x%x\n",
247 1.10 blymn botright.vals[0], botright.attributes );
248 1.10 blymn #endif
249 1.10 blymn
250 1.10 blymn /* Merge window attributes */
251 1.10 blymn left.attributes |= (left.attributes & __COLOR) ?
252 1.10 blymn (win->wattr & ~__COLOR) : win->wattr;
253 1.10 blymn right.attributes |= (right.attributes & __COLOR) ?
254 1.10 blymn (win->wattr & ~__COLOR) : win->wattr;
255 1.10 blymn top.attributes |= (top.attributes & __COLOR) ?
256 1.10 blymn (win->wattr & ~__COLOR) : win->wattr;
257 1.10 blymn bottom.attributes |= (bottom.attributes & __COLOR) ?
258 1.10 blymn (win->wattr & ~__COLOR) : win->wattr;
259 1.10 blymn topleft.attributes |= (topleft.attributes & __COLOR) ?
260 1.10 blymn (win->wattr & ~__COLOR) : win->wattr;
261 1.10 blymn topright.attributes |= (topright.attributes & __COLOR) ?
262 1.10 blymn (win->wattr & ~__COLOR) : win->wattr;
263 1.10 blymn botleft.attributes |= (botleft.attributes & __COLOR) ?
264 1.10 blymn (win->wattr & ~__COLOR) : win->wattr;
265 1.10 blymn botright.attributes |= (botright.attributes & __COLOR) ?
266 1.10 blymn (win->wattr & ~__COLOR) : win->wattr;
267 1.10 blymn
268 1.10 blymn endx = win->maxx - 1;
269 1.10 blymn endy = win->maxy - 1;
270 1.10 blymn
271 1.10 blymn /* Sides */
272 1.10 blymn for (i = 1; i < endy; i++) {
273 1.10 blymn /* left border */
274 1.10 blymn cw = wcwidth( left.vals[ 0 ]);
275 1.10 blymn for ( j = 0; j < cw; j++ ) {
276 1.12 roy win->alines[i]->line[j].ch = left.vals[ 0 ];
277 1.12 roy win->alines[i]->line[j].attr = left.attributes;
278 1.12 roy np = win->alines[i]->line[j].nsp;
279 1.10 blymn if (np) {
280 1.10 blymn while ( np ) {
281 1.10 blymn tnp = np->next;
282 1.10 blymn free( np );
283 1.10 blymn np = tnp;
284 1.10 blymn }
285 1.12 roy win->alines[i]->line[j].nsp = NULL;
286 1.10 blymn }
287 1.10 blymn if ( j )
288 1.12 roy SET_WCOL( win->alines[i]->line[j], -j );
289 1.10 blymn else {
290 1.12 roy SET_WCOL( win->alines[i]->line[j], cw );
291 1.10 blymn if ( left.elements > 1 ) {
292 1.10 blymn for (k = 1; k < left.elements; k++) {
293 1.10 blymn np = (nschar_t *)malloc(sizeof(nschar_t));
294 1.10 blymn if (!np)
295 1.10 blymn return ERR;
296 1.10 blymn np->ch = left.vals[ k ];
297 1.12 roy np->next = win->alines[i]->line[j].nsp;
298 1.12 roy win->alines[i]->line[j].nsp
299 1.10 blymn = np;
300 1.10 blymn }
301 1.10 blymn }
302 1.10 blymn }
303 1.10 blymn }
304 1.12 roy for ( j = cw; WCOL( win->alines[i]->line[j]) < 0; j++ ) {
305 1.10 blymn #ifdef DEBUG
306 1.10 blymn __CTRACE(__CTRACE_INPUT,
307 1.10 blymn "wborder_set: clean out partial char[%d]", j);
308 1.10 blymn #endif /* DEBUG */
309 1.12 roy win->alines[i]->line[j].ch = ( wchar_t )btowc(win->bch);
310 1.10 blymn if (_cursesi_copy_nsp(win->bnsp,
311 1.12 roy &win->alines[i]->line[j]) == ERR)
312 1.10 blymn return ERR;
313 1.12 roy SET_WCOL( win->alines[i]->line[j], 1 );
314 1.10 blymn }
315 1.10 blymn /* right border */
316 1.10 blymn cw = wcwidth( right.vals[ 0 ]);
317 1.12 roy pcw = WCOL( win->alines[i]->line[endx - cw]);
318 1.10 blymn for ( j = endx - cw + 1; j <= endx; j++ ) {
319 1.12 roy win->alines[i]->line[j].ch = right.vals[ 0 ];
320 1.12 roy win->alines[i]->line[j].attr = right.attributes;
321 1.12 roy np = win->alines[i]->line[j].nsp;
322 1.10 blymn if (np) {
323 1.10 blymn while ( np ) {
324 1.10 blymn tnp = np->next;
325 1.10 blymn free( np );
326 1.10 blymn np = tnp;
327 1.10 blymn }
328 1.12 roy win->alines[i]->line[j].nsp = NULL;
329 1.10 blymn }
330 1.10 blymn if ( j == endx - cw + 1 ) {
331 1.12 roy SET_WCOL( win->alines[i]->line[j], cw );
332 1.10 blymn if ( right.elements > 1 ) {
333 1.10 blymn for (k = 1; k < right.elements; k++) {
334 1.10 blymn np = (nschar_t *)malloc(sizeof(nschar_t));
335 1.10 blymn if (!np)
336 1.10 blymn return ERR;
337 1.10 blymn np->ch = right.vals[ k ];
338 1.12 roy np->next = win->alines[i]->line[j].nsp;
339 1.12 roy win->alines[i]->line[j].nsp
340 1.10 blymn = np;
341 1.10 blymn }
342 1.10 blymn }
343 1.10 blymn } else
344 1.12 roy SET_WCOL( win->alines[i]->line[j],
345 1.10 blymn endx - cw + 1 - j );
346 1.10 blymn }
347 1.10 blymn if ( pcw != 1 ) {
348 1.10 blymn #ifdef DEBUG
349 1.10 blymn __CTRACE(__CTRACE_INPUT,
350 1.10 blymn "wborder_set: clean out partial chars[%d:%d]",
351 1.10 blymn endx - cw + pcw, endx - cw );
352 1.10 blymn #endif /* DEBUG */
353 1.10 blymn k = pcw < 0 ? endx -cw + pcw : endx - cw;
354 1.10 blymn for ( j = endx - cw; j >= k; j-- ) {
355 1.12 roy win->alines[i]->line[j].ch
356 1.10 blymn = (wchar_t)btowc(win->bch);
357 1.10 blymn if (_cursesi_copy_nsp(win->bnsp,
358 1.12 roy &win->alines[i]->line[j]) == ERR)
359 1.10 blymn return ERR;
360 1.12 roy win->alines[i]->line[j].attr = win->battr;
361 1.12 roy SET_WCOL( win->alines[i]->line[j], 1 );
362 1.10 blymn }
363 1.10 blymn }
364 1.10 blymn }
365 1.10 blymn tlcw = wcwidth( topleft.vals[ 0 ]);
366 1.10 blymn blcw = wcwidth( botleft.vals[ 0 ]);
367 1.10 blymn trcw = wcwidth( topright.vals[ 0 ]);
368 1.10 blymn brcw = wcwidth( botright.vals[ 0 ]);
369 1.10 blymn /* upper border */
370 1.10 blymn cw = wcwidth( top.vals[ 0 ]);
371 1.10 blymn for (i = tlcw; i <= min( endx - cw, endx - trcw ); i += cw ) {
372 1.10 blymn for ( j = 0; j < cw; j++ ) {
373 1.12 roy win->alines[ 0 ]->line[i + j].ch = top.vals[ 0 ];
374 1.12 roy win->alines[ 0 ]->line[i + j].attr = top.attributes;
375 1.12 roy np = win->alines[ 0 ]->line[i + j].nsp;
376 1.10 blymn if (np) {
377 1.10 blymn while ( np ) {
378 1.10 blymn tnp = np->next;
379 1.10 blymn free( np );
380 1.10 blymn np = tnp;
381 1.10 blymn }
382 1.12 roy win->alines[ 0 ]->line[i + j].nsp = NULL;
383 1.10 blymn }
384 1.10 blymn if ( j )
385 1.12 roy SET_WCOL( win->alines[ 0 ]->line[ i + j ], -j );
386 1.10 blymn else {
387 1.12 roy SET_WCOL( win->alines[ 0 ]->line[ i + j ], cw );
388 1.10 blymn if ( top.elements > 1 ) {
389 1.10 blymn for ( k = 1; k < top.elements; k++ ) {
390 1.10 blymn np = (nschar_t *)malloc(sizeof(nschar_t));
391 1.10 blymn if (!np)
392 1.10 blymn return ERR;
393 1.10 blymn np->ch = top.vals[ k ];
394 1.12 roy np->next = win->alines[0]->line[i + j].nsp;
395 1.12 roy win->alines[0]->line[i + j].nsp
396 1.10 blymn = np;
397 1.10 blymn }
398 1.10 blymn }
399 1.10 blymn }
400 1.10 blymn }
401 1.10 blymn }
402 1.10 blymn while ( i <= endx - trcw ) {
403 1.12 roy win->alines[0]->line[i].ch =
404 1.10 blymn ( wchar_t )btowc(( int ) win->bch );
405 1.10 blymn if (_cursesi_copy_nsp(win->bnsp,
406 1.12 roy &win->alines[0]->line[i]) == ERR)
407 1.10 blymn return ERR;
408 1.12 roy win->alines[ 0 ]->line[ i ].attr = win->battr;
409 1.12 roy SET_WCOL( win->alines[ 0 ]->line[ i ], 1 );
410 1.10 blymn i++;
411 1.10 blymn }
412 1.10 blymn /* lower border */
413 1.10 blymn for (i = blcw; i <= min( endx - cw, endx - brcw ); i += cw ) {
414 1.10 blymn for ( j = 0; j < cw; j++ ) {
415 1.12 roy win->alines[ endy ]->line[i + j].ch = bottom.vals[ 0 ];
416 1.12 roy win->alines[endy]->line[i + j].attr = bottom.attributes;
417 1.12 roy np = win->alines[ endy ]->line[i + j].nsp;
418 1.10 blymn if (np) {
419 1.10 blymn while ( np ) {
420 1.10 blymn tnp = np->next;
421 1.10 blymn free( np );
422 1.10 blymn np = tnp;
423 1.10 blymn }
424 1.12 roy win->alines[ endy ]->line[i + j].nsp = NULL;
425 1.10 blymn }
426 1.10 blymn if ( j )
427 1.12 roy SET_WCOL( win->alines[endy]->line[i + j], -j);
428 1.10 blymn else {
429 1.12 roy SET_WCOL( win->alines[endy]->line[i + j], cw );
430 1.10 blymn if ( bottom.elements > 1 ) {
431 1.10 blymn for ( k = 1; k < bottom.elements;
432 1.10 blymn k++ ) {
433 1.10 blymn if ( !( np = ( nschar_t *)malloc( sizeof( nschar_t ))))
434 1.10 blymn return ERR;
435 1.10 blymn np->ch = bottom.vals[ k ];
436 1.12 roy np->next = win->alines[endy]->line[i + j].nsp;
437 1.12 roy win->alines[endy]->line[i + j].nsp = np;
438 1.10 blymn }
439 1.10 blymn }
440 1.10 blymn }
441 1.10 blymn }
442 1.10 blymn }
443 1.10 blymn while ( i <= endx - brcw ) {
444 1.12 roy win->alines[endy]->line[i].ch =
445 1.10 blymn (wchar_t)btowc((int) win->bch );
446 1.10 blymn if (_cursesi_copy_nsp(win->bnsp,
447 1.12 roy &win->alines[endy]->line[i]) == ERR)
448 1.10 blymn return ERR;
449 1.12 roy win->alines[ endy ]->line[ i ].attr = win->battr;
450 1.12 roy SET_WCOL( win->alines[ endy ]->line[ i ], 1 );
451 1.10 blymn i++;
452 1.10 blymn }
453 1.10 blymn
454 1.10 blymn /* Corners */
455 1.10 blymn if (!(win->maxx == LINES && win->maxy == COLS &&
456 1.10 blymn (win->flags & __SCROLLOK) && (win->flags & __SCROLLWIN))) {
457 1.10 blymn for ( i = 0; i < tlcw; i++ ) {
458 1.12 roy win->alines[ 0 ]->line[i].ch = topleft.vals[ 0 ];
459 1.12 roy win->alines[ 0 ]->line[i].attr = topleft.attributes;
460 1.12 roy np = win->alines[ 0 ]->line[i].nsp;
461 1.10 blymn if (np) {
462 1.10 blymn while ( np ) {
463 1.10 blymn tnp = np->next;
464 1.10 blymn free( np );
465 1.10 blymn np = tnp;
466 1.10 blymn }
467 1.12 roy win->alines[ 0 ]->line[i].nsp = NULL;
468 1.10 blymn }
469 1.10 blymn if ( i )
470 1.12 roy SET_WCOL( win->alines[ 0 ]->line[ i ], -i );
471 1.10 blymn else {
472 1.12 roy SET_WCOL( win->alines[ 0 ]->line[ i ], tlcw );
473 1.10 blymn if ( topleft.elements > 1 ) {
474 1.10 blymn for ( k = 1; k < topleft.elements;
475 1.10 blymn k++ ) {
476 1.10 blymn np = (nschar_t *)malloc(sizeof(nschar_t));
477 1.10 blymn if (!np)
478 1.10 blymn return ERR;
479 1.10 blymn np->ch = topleft.vals[ k ];
480 1.12 roy np->next = win->alines[ 0 ]->line[i].nsp;
481 1.12 roy win->alines[ 0 ]->line[i].nsp
482 1.10 blymn = np;
483 1.10 blymn }
484 1.10 blymn }
485 1.10 blymn }
486 1.10 blymn }
487 1.10 blymn for ( i = endx - trcw + 1; i <= endx; i++ ) {
488 1.12 roy win->alines[ 0 ]->line[i].ch = topright.vals[ 0 ];
489 1.12 roy win->alines[ 0 ]->line[i].attr = topright.attributes;
490 1.12 roy np = win->alines[ 0 ]->line[i].nsp;
491 1.10 blymn if (np) {
492 1.10 blymn while ( np ) {
493 1.10 blymn tnp = np->next;
494 1.10 blymn free( np );
495 1.10 blymn np = tnp;
496 1.10 blymn }
497 1.12 roy win->alines[ 0 ]->line[i].nsp = NULL;
498 1.10 blymn }
499 1.10 blymn if ( i == endx - trcw + 1 ) {
500 1.12 roy SET_WCOL( win->alines[ 0 ]->line[ i ], trcw );
501 1.10 blymn if ( topright.elements > 1 ) {
502 1.10 blymn for ( k = 1; k < topright.elements;
503 1.10 blymn k++ ) {
504 1.10 blymn np = (nschar_t *)malloc(sizeof(nschar_t));
505 1.10 blymn if (!np)
506 1.10 blymn return ERR;
507 1.10 blymn np->ch = topright.vals[ k ];
508 1.12 roy np->next = win->alines[0]->line[i].nsp;
509 1.12 roy win->alines[ 0 ]->line[i].nsp
510 1.10 blymn = np;
511 1.10 blymn }
512 1.10 blymn }
513 1.10 blymn } else
514 1.12 roy SET_WCOL( win->alines[ 0 ]->line[ i ],
515 1.10 blymn endx - trcw + 1 - i );
516 1.10 blymn }
517 1.10 blymn for ( i = 0; i < blcw; i++ ) {
518 1.12 roy win->alines[ endy ]->line[i].ch = botleft.vals[ 0 ];
519 1.12 roy win->alines[ endy ]->line[i].attr = botleft.attributes;
520 1.12 roy np = win->alines[ endy ]->line[i].nsp;
521 1.10 blymn if (np) {
522 1.10 blymn while ( np ) {
523 1.10 blymn tnp = np->next;
524 1.10 blymn free( np );
525 1.10 blymn np = tnp;
526 1.10 blymn }
527 1.12 roy win->alines[ endy ]->line[i].nsp = NULL;
528 1.10 blymn }
529 1.10 blymn if ( i )
530 1.12 roy SET_WCOL( win->alines[endy]->line[i], -i );
531 1.10 blymn else {
532 1.12 roy SET_WCOL( win->alines[endy]->line[i], blcw );
533 1.10 blymn if ( botleft.elements > 1 ) {
534 1.10 blymn for ( k = 1; k < botleft.elements;
535 1.10 blymn k++ ) {
536 1.10 blymn np = (nschar_t *)malloc(sizeof(nschar_t));
537 1.10 blymn if (!np)
538 1.10 blymn return ERR;
539 1.10 blymn np->ch = botleft.vals[ k ];
540 1.12 roy np->next = win->alines[endy]->line[i].nsp;
541 1.12 roy win->alines[endy]->line[i].nsp
542 1.10 blymn = np;
543 1.10 blymn }
544 1.10 blymn }
545 1.10 blymn }
546 1.10 blymn }
547 1.10 blymn for ( i = endx - brcw + 1; i <= endx; i++ ) {
548 1.12 roy win->alines[ endy ]->line[i].ch = botright.vals[ 0 ];
549 1.12 roy win->alines[ endy ]->line[i].attr = botright.attributes;
550 1.12 roy np = win->alines[ endy ]->line[i].nsp;
551 1.10 blymn if (np) {
552 1.10 blymn while ( np ) {
553 1.10 blymn tnp = np->next;
554 1.10 blymn free( np );
555 1.10 blymn np = tnp;
556 1.10 blymn }
557 1.12 roy win->alines[ endy ]->line[i].nsp = NULL;
558 1.10 blymn }
559 1.10 blymn if ( i == endx - brcw + 1 ) {
560 1.12 roy SET_WCOL( win->alines[ endy ]->line[ i ],
561 1.10 blymn brcw );
562 1.10 blymn if ( botright.elements > 1 ) {
563 1.10 blymn for ( k = 1; k < botright.elements; k++ ) {
564 1.10 blymn np = (nschar_t *)malloc(sizeof(nschar_t));
565 1.10 blymn if (!np)
566 1.10 blymn return ERR;
567 1.10 blymn np->ch = botright.vals[ k ];
568 1.12 roy np->next = win->alines[endy]->line[i].nsp;
569 1.12 roy win->alines[endy]->line[i].nsp
570 1.10 blymn = np;
571 1.10 blymn }
572 1.10 blymn }
573 1.10 blymn } else
574 1.12 roy SET_WCOL( win->alines[ endy ]->line[ i ],
575 1.10 blymn endx - brcw + 1 - i );
576 1.10 blymn }
577 1.2 blymn }
578 1.2 blymn __touchwin(win);
579 1.2 blymn return (OK);
580 1.10 blymn #endif /* HAVE_WCHAR */
581 1.2 blymn }
582