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