border.c revision 1.6 1 1.6 blymn /* $NetBSD: border.c,v 1.6 2000/04/24 14:09:42 blymn 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 * 3. All advertising materials mentioning features or use of this software
19 1.2 blymn * must display the following acknowledgement:
20 1.2 blymn * This product includes software developed by the NetBSD
21 1.2 blymn * Foundation, Inc. and its contributors.
22 1.2 blymn * 4. Neither the name of The NetBSD Foundation nor the names of its
23 1.2 blymn * contributors may be used to endorse or promote products derived
24 1.2 blymn * 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.6 blymn __RCSID("$NetBSD: border.c,v 1.6 2000/04/24 14:09:42 blymn Exp $");
42 1.6 blymn #endif /* not lint */
43 1.2 blymn
44 1.2 blymn #include "curses.h"
45 1.2 blymn #include "curses_private.h"
46 1.2 blymn
47 1.4 blymn #ifndef _CURSES_USE_MACROS
48 1.4 blymn
49 1.4 blymn /*
50 1.4 blymn * border --
51 1.4 blymn * Draw a border around stdscr using the specified
52 1.4 blymn * delimiting characters.
53 1.4 blymn */
54 1.4 blymn int
55 1.4 blymn border(chtype left, chtype right, chtype top, chtype bottom, chtype topleft,
56 1.4 blymn chtype topright, chtype botleft, chtype botright)
57 1.4 blymn {
58 1.4 blymn return wborder(stdscr, left, right, top, bottom, topleft, topright,
59 1.4 blymn botleft, botright);
60 1.4 blymn }
61 1.4 blymn
62 1.4 blymn #endif
63 1.4 blymn
64 1.2 blymn /*
65 1.2 blymn * wborder --
66 1.2 blymn * Draw a border around the given window using the specified delimiting
67 1.2 blymn * characters.
68 1.2 blymn */
69 1.2 blymn int
70 1.4 blymn wborder(WINDOW *win, chtype left, chtype right, chtype top, chtype bottom,
71 1.4 blymn chtype topleft, chtype topright, chtype botleft, chtype botright)
72 1.2 blymn {
73 1.2 blymn int endy, endx, i;
74 1.2 blymn __LDATA *fp, *lp;
75 1.2 blymn
76 1.2 blymn if (!(left & __CHARTEXT)) left = ACS_VLINE;
77 1.2 blymn if (!(right & __CHARTEXT)) right = ACS_VLINE;
78 1.2 blymn if (!(top & __CHARTEXT)) top = ACS_HLINE;
79 1.2 blymn if (!(bottom & __CHARTEXT)) bottom = ACS_HLINE;
80 1.2 blymn if (!(topleft & __CHARTEXT)) topleft = ACS_ULCORNER;
81 1.2 blymn if (!(topright & __CHARTEXT)) topright = ACS_URCORNER;
82 1.2 blymn if (!(botleft & __CHARTEXT)) botleft = ACS_LLCORNER;
83 1.2 blymn if (!(botright & __CHARTEXT)) botright = ACS_LRCORNER;
84 1.2 blymn
85 1.2 blymn #ifdef DEBUG
86 1.3 jdc __CTRACE("wborder: left = %c, 0x%x\n", left & __CHARTEXT,
87 1.3 jdc left & __ATTRIBUTES);
88 1.3 jdc __CTRACE("wborder: right = %c, 0x%x\n", right & __CHARTEXT,
89 1.3 jdc right & __ATTRIBUTES);
90 1.3 jdc __CTRACE("wborder: top = %c, 0x%x\n", top & __CHARTEXT,
91 1.3 jdc top & __ATTRIBUTES);
92 1.3 jdc __CTRACE("wborder: bottom = %c, 0x%x\n", bottom & __CHARTEXT,
93 1.3 jdc bottom & __ATTRIBUTES);
94 1.3 jdc __CTRACE("wborder: topleft = %c, 0x%x\n", topleft & __CHARTEXT,
95 1.3 jdc topleft & __ATTRIBUTES);
96 1.3 jdc __CTRACE("wborder: topright = %c, 0x%x\n", topright & __CHARTEXT,
97 1.3 jdc topright & __ATTRIBUTES);
98 1.3 jdc __CTRACE("wborder: botleft = %c, 0x%x\n", botleft & __CHARTEXT,
99 1.3 jdc botleft & __ATTRIBUTES);
100 1.3 jdc __CTRACE("wborder: botright = %c, 0x%x\n", botright & __CHARTEXT,
101 1.3 jdc botright & __ATTRIBUTES);
102 1.2 blymn #endif
103 1.2 blymn
104 1.2 blymn /* Merge window attributes */
105 1.3 jdc left |= (left & __COLOR) ? (win->wattr & ~__COLOR) : win->wattr;
106 1.3 jdc right |= (right & __COLOR) ? (win->wattr & ~__COLOR) : win->wattr;
107 1.3 jdc top |= (top & __COLOR) ? (win->wattr & ~__COLOR) : win->wattr;
108 1.3 jdc bottom |= (bottom & __COLOR) ? (win->wattr & ~__COLOR) : win->wattr;
109 1.3 jdc topleft |= (topleft & __COLOR) ? (win->wattr & ~__COLOR) : win->wattr;
110 1.3 jdc topright |= (topright & __COLOR) ? (win->wattr & ~__COLOR) : win->wattr;
111 1.3 jdc botleft |= (botleft & __COLOR) ? (win->wattr & ~__COLOR) : win->wattr;
112 1.3 jdc botright |= (botright & __COLOR) ? (win->wattr & ~__COLOR) : win->wattr;
113 1.2 blymn
114 1.2 blymn endx = win->maxx - 1;
115 1.2 blymn endy = win->maxy - 1;
116 1.2 blymn fp = win->lines[0]->line;
117 1.2 blymn lp = win->lines[endy]->line;
118 1.2 blymn
119 1.2 blymn /* Sides */
120 1.2 blymn for (i = 1; i < endy; i++) {
121 1.2 blymn win->lines[i]->line[0].ch = (wchar_t) left & __CHARTEXT;
122 1.5 jdc win->lines[i]->line[0].bch = win->bch;
123 1.2 blymn win->lines[i]->line[0].attr = (attr_t) left & __ATTRIBUTES;
124 1.5 jdc win->lines[i]->line[0].battr = win->battr;
125 1.2 blymn win->lines[i]->line[endx].ch = (wchar_t) right & __CHARTEXT;
126 1.5 jdc win->lines[i]->line[endx].bch = win->bch;
127 1.2 blymn win->lines[i]->line[endx].attr = (attr_t) right & __ATTRIBUTES;
128 1.5 jdc win->lines[i]->line[endx].battr = win->battr;
129 1.2 blymn }
130 1.2 blymn for (i = 1; i < endx; i++) {
131 1.2 blymn fp[i].ch = (wchar_t) top & __CHARTEXT;
132 1.5 jdc fp[i].bch = win->bch;
133 1.2 blymn fp[i].attr = (attr_t) top & __ATTRIBUTES;
134 1.5 jdc fp[i].battr = win->battr;
135 1.2 blymn lp[i].ch = (wchar_t) bottom & __CHARTEXT;
136 1.5 jdc lp[i].bch = win->bch;
137 1.2 blymn lp[i].attr = (attr_t) bottom & __ATTRIBUTES;
138 1.5 jdc lp[i].battr = win->battr;
139 1.2 blymn }
140 1.2 blymn
141 1.2 blymn /* Corners */
142 1.2 blymn if (!(win->maxx == LINES && win->maxy == COLS &&
143 1.2 blymn (win->flags & __SCROLLOK) && (win->flags & __SCROLLWIN))) {
144 1.2 blymn fp[0].ch = (wchar_t) topleft & __CHARTEXT;
145 1.5 jdc fp[0].bch = win->bch;
146 1.2 blymn fp[0].attr = (attr_t) topleft & __ATTRIBUTES;
147 1.5 jdc fp[0].battr = win->battr;
148 1.2 blymn fp[endx].ch = (wchar_t) topright & __CHARTEXT;
149 1.5 jdc fp[endx].bch = win->bch;
150 1.2 blymn fp[endx].attr = (attr_t) topright & __ATTRIBUTES;
151 1.5 jdc fp[endx].battr = win->battr;
152 1.2 blymn lp[0].ch = (wchar_t) botleft & __CHARTEXT;
153 1.5 jdc lp[0].bch = win->bch;
154 1.2 blymn lp[0].attr = (attr_t) botleft & __ATTRIBUTES;
155 1.5 jdc lp[0].battr = win->battr;
156 1.2 blymn lp[endx].ch = (wchar_t) botright & __CHARTEXT;
157 1.5 jdc lp[endx].bch = win->bch;
158 1.2 blymn lp[endx].attr = (attr_t) botright & __ATTRIBUTES;
159 1.5 jdc lp[endx].battr = win->battr;
160 1.2 blymn }
161 1.2 blymn __touchwin(win);
162 1.2 blymn return (OK);
163 1.2 blymn }
164