border.c revision 1.5 1 1.5 jdc /* $NetBSD: border.c,v 1.5 2000/04/18 22:45:24 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.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.2 blymn
39 1.2 blymn #include "curses.h"
40 1.2 blymn #include "curses_private.h"
41 1.2 blymn
42 1.4 blymn #ifndef _CURSES_USE_MACROS
43 1.4 blymn
44 1.4 blymn /*
45 1.4 blymn * border --
46 1.4 blymn * Draw a border around stdscr using the specified
47 1.4 blymn * delimiting characters.
48 1.4 blymn */
49 1.4 blymn int
50 1.4 blymn border(chtype left, chtype right, chtype top, chtype bottom, chtype topleft,
51 1.4 blymn chtype topright, chtype botleft, chtype botright)
52 1.4 blymn {
53 1.4 blymn return wborder(stdscr, left, right, top, bottom, topleft, topright,
54 1.4 blymn botleft, botright);
55 1.4 blymn }
56 1.4 blymn
57 1.4 blymn #endif
58 1.4 blymn
59 1.2 blymn /*
60 1.2 blymn * wborder --
61 1.2 blymn * Draw a border around the given window using the specified delimiting
62 1.2 blymn * characters.
63 1.2 blymn */
64 1.2 blymn int
65 1.4 blymn wborder(WINDOW *win, chtype left, chtype right, chtype top, chtype bottom,
66 1.4 blymn chtype topleft, chtype topright, chtype botleft, chtype botright)
67 1.2 blymn {
68 1.2 blymn int endy, endx, i;
69 1.2 blymn __LDATA *fp, *lp;
70 1.2 blymn
71 1.2 blymn if (!(left & __CHARTEXT)) left = ACS_VLINE;
72 1.2 blymn if (!(right & __CHARTEXT)) right = ACS_VLINE;
73 1.2 blymn if (!(top & __CHARTEXT)) top = ACS_HLINE;
74 1.2 blymn if (!(bottom & __CHARTEXT)) bottom = ACS_HLINE;
75 1.2 blymn if (!(topleft & __CHARTEXT)) topleft = ACS_ULCORNER;
76 1.2 blymn if (!(topright & __CHARTEXT)) topright = ACS_URCORNER;
77 1.2 blymn if (!(botleft & __CHARTEXT)) botleft = ACS_LLCORNER;
78 1.2 blymn if (!(botright & __CHARTEXT)) botright = ACS_LRCORNER;
79 1.2 blymn
80 1.2 blymn #ifdef DEBUG
81 1.3 jdc __CTRACE("wborder: left = %c, 0x%x\n", left & __CHARTEXT,
82 1.3 jdc left & __ATTRIBUTES);
83 1.3 jdc __CTRACE("wborder: right = %c, 0x%x\n", right & __CHARTEXT,
84 1.3 jdc right & __ATTRIBUTES);
85 1.3 jdc __CTRACE("wborder: top = %c, 0x%x\n", top & __CHARTEXT,
86 1.3 jdc top & __ATTRIBUTES);
87 1.3 jdc __CTRACE("wborder: bottom = %c, 0x%x\n", bottom & __CHARTEXT,
88 1.3 jdc bottom & __ATTRIBUTES);
89 1.3 jdc __CTRACE("wborder: topleft = %c, 0x%x\n", topleft & __CHARTEXT,
90 1.3 jdc topleft & __ATTRIBUTES);
91 1.3 jdc __CTRACE("wborder: topright = %c, 0x%x\n", topright & __CHARTEXT,
92 1.3 jdc topright & __ATTRIBUTES);
93 1.3 jdc __CTRACE("wborder: botleft = %c, 0x%x\n", botleft & __CHARTEXT,
94 1.3 jdc botleft & __ATTRIBUTES);
95 1.3 jdc __CTRACE("wborder: botright = %c, 0x%x\n", botright & __CHARTEXT,
96 1.3 jdc botright & __ATTRIBUTES);
97 1.2 blymn #endif
98 1.2 blymn
99 1.2 blymn /* Merge window attributes */
100 1.3 jdc left |= (left & __COLOR) ? (win->wattr & ~__COLOR) : win->wattr;
101 1.3 jdc right |= (right & __COLOR) ? (win->wattr & ~__COLOR) : win->wattr;
102 1.3 jdc top |= (top & __COLOR) ? (win->wattr & ~__COLOR) : win->wattr;
103 1.3 jdc bottom |= (bottom & __COLOR) ? (win->wattr & ~__COLOR) : win->wattr;
104 1.3 jdc topleft |= (topleft & __COLOR) ? (win->wattr & ~__COLOR) : win->wattr;
105 1.3 jdc topright |= (topright & __COLOR) ? (win->wattr & ~__COLOR) : win->wattr;
106 1.3 jdc botleft |= (botleft & __COLOR) ? (win->wattr & ~__COLOR) : win->wattr;
107 1.3 jdc botright |= (botright & __COLOR) ? (win->wattr & ~__COLOR) : win->wattr;
108 1.2 blymn
109 1.2 blymn endx = win->maxx - 1;
110 1.2 blymn endy = win->maxy - 1;
111 1.2 blymn fp = win->lines[0]->line;
112 1.2 blymn lp = win->lines[endy]->line;
113 1.2 blymn
114 1.2 blymn /* Sides */
115 1.2 blymn for (i = 1; i < endy; i++) {
116 1.2 blymn win->lines[i]->line[0].ch = (wchar_t) left & __CHARTEXT;
117 1.5 jdc win->lines[i]->line[0].bch = win->bch;
118 1.2 blymn win->lines[i]->line[0].attr = (attr_t) left & __ATTRIBUTES;
119 1.5 jdc win->lines[i]->line[0].battr = win->battr;
120 1.2 blymn win->lines[i]->line[endx].ch = (wchar_t) right & __CHARTEXT;
121 1.5 jdc win->lines[i]->line[endx].bch = win->bch;
122 1.2 blymn win->lines[i]->line[endx].attr = (attr_t) right & __ATTRIBUTES;
123 1.5 jdc win->lines[i]->line[endx].battr = win->battr;
124 1.2 blymn }
125 1.2 blymn for (i = 1; i < endx; i++) {
126 1.2 blymn fp[i].ch = (wchar_t) top & __CHARTEXT;
127 1.5 jdc fp[i].bch = win->bch;
128 1.2 blymn fp[i].attr = (attr_t) top & __ATTRIBUTES;
129 1.5 jdc fp[i].battr = win->battr;
130 1.2 blymn lp[i].ch = (wchar_t) bottom & __CHARTEXT;
131 1.5 jdc lp[i].bch = win->bch;
132 1.2 blymn lp[i].attr = (attr_t) bottom & __ATTRIBUTES;
133 1.5 jdc lp[i].battr = win->battr;
134 1.2 blymn }
135 1.2 blymn
136 1.2 blymn /* Corners */
137 1.2 blymn if (!(win->maxx == LINES && win->maxy == COLS &&
138 1.2 blymn (win->flags & __SCROLLOK) && (win->flags & __SCROLLWIN))) {
139 1.2 blymn fp[0].ch = (wchar_t) topleft & __CHARTEXT;
140 1.5 jdc fp[0].bch = win->bch;
141 1.2 blymn fp[0].attr = (attr_t) topleft & __ATTRIBUTES;
142 1.5 jdc fp[0].battr = win->battr;
143 1.2 blymn fp[endx].ch = (wchar_t) topright & __CHARTEXT;
144 1.5 jdc fp[endx].bch = win->bch;
145 1.2 blymn fp[endx].attr = (attr_t) topright & __ATTRIBUTES;
146 1.5 jdc fp[endx].battr = win->battr;
147 1.2 blymn lp[0].ch = (wchar_t) botleft & __CHARTEXT;
148 1.5 jdc lp[0].bch = win->bch;
149 1.2 blymn lp[0].attr = (attr_t) botleft & __ATTRIBUTES;
150 1.5 jdc lp[0].battr = win->battr;
151 1.2 blymn lp[endx].ch = (wchar_t) botright & __CHARTEXT;
152 1.5 jdc lp[endx].bch = win->bch;
153 1.2 blymn lp[endx].attr = (attr_t) botright & __ATTRIBUTES;
154 1.5 jdc lp[endx].battr = win->battr;
155 1.2 blymn }
156 1.2 blymn __touchwin(win);
157 1.2 blymn return (OK);
158 1.2 blymn }
159