line.c revision 1.8 1 1.8 roy /* $NetBSD: line.c,v 1.8 2017/01/02 10:28:35 roy Exp $ */
2 1.1 blymn
3 1.1 blymn /*-
4 1.1 blymn * Copyright (c) 1998-1999 Brett Lymn
5 1.5 blymn * (blymn (at) baea.com.au, brett_lymn (at) yahoo.com.au)
6 1.1 blymn * All rights reserved.
7 1.1 blymn *
8 1.1 blymn * This code has been donated to The NetBSD Foundation by the Author.
9 1.1 blymn *
10 1.1 blymn * Redistribution and use in source and binary forms, with or without
11 1.1 blymn * modification, are permitted provided that the following conditions
12 1.1 blymn * are met:
13 1.1 blymn * 1. Redistributions of source code must retain the above copyright
14 1.1 blymn * notice, this list of conditions and the following disclaimer.
15 1.1 blymn * 2. The name of the author may not be used to endorse or promote products
16 1.3 wiz * derived from this software without specific prior written permission
17 1.1 blymn *
18 1.1 blymn * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
19 1.1 blymn * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
20 1.1 blymn * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
21 1.1 blymn * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
22 1.1 blymn * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
23 1.1 blymn * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
24 1.1 blymn * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
25 1.1 blymn * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
26 1.1 blymn * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
27 1.1 blymn * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
28 1.1 blymn *
29 1.1 blymn *
30 1.1 blymn */
31 1.1 blymn
32 1.1 blymn #include <sys/cdefs.h>
33 1.1 blymn #ifndef lint
34 1.8 roy __RCSID("$NetBSD: line.c,v 1.8 2017/01/02 10:28:35 roy Exp $");
35 1.1 blymn #endif /* not lint */
36 1.1 blymn
37 1.5 blymn #include <string.h>
38 1.5 blymn
39 1.1 blymn #include "curses.h"
40 1.1 blymn #include "curses_private.h"
41 1.1 blymn
42 1.1 blymn /*
43 1.1 blymn * hline --
44 1.5 blymn * Draw a horizontal line of character c on stdscr.
45 1.1 blymn */
46 1.1 blymn int
47 1.1 blymn hline(chtype ch, int count)
48 1.1 blymn {
49 1.1 blymn return whline(stdscr, ch, count);
50 1.1 blymn }
51 1.1 blymn
52 1.1 blymn /*
53 1.1 blymn * mvhline --
54 1.5 blymn * Move to location (y, x) and draw a horizontal line of character c
55 1.5 blymn * on stdscr.
56 1.1 blymn */
57 1.1 blymn int
58 1.1 blymn mvhline(int y, int x, chtype ch, int count)
59 1.1 blymn {
60 1.1 blymn return mvwhline(stdscr, y, x, ch, count);
61 1.1 blymn }
62 1.1 blymn
63 1.1 blymn /*
64 1.1 blymn * mvwhline --
65 1.5 blymn * Move to location (y, x) and draw a horizontal line of character c
66 1.5 blymn * in the given window.
67 1.1 blymn */
68 1.1 blymn int
69 1.1 blymn mvwhline(WINDOW *win, int y, int x, chtype ch, int count)
70 1.1 blymn {
71 1.1 blymn if (wmove(win, y, x) == ERR)
72 1.1 blymn return ERR;
73 1.1 blymn
74 1.1 blymn return whline(win, ch, count);
75 1.1 blymn }
76 1.1 blymn
77 1.1 blymn /*
78 1.1 blymn * whline --
79 1.5 blymn * Draw a horizontal line of character c in the given window moving
80 1.5 blymn * towards the rightmost column. At most count characters are drawn
81 1.5 blymn * or until the edge of the screen, whichever comes first.
82 1.1 blymn */
83 1.1 blymn int
84 1.1 blymn whline(WINDOW *win, chtype ch, int count)
85 1.1 blymn {
86 1.6 drochner #ifndef HAVE_WCHAR
87 1.1 blymn int ocurx, n, i;
88 1.1 blymn
89 1.1 blymn n = min(count, win->maxx - win->curx);
90 1.1 blymn ocurx = win->curx;
91 1.4 blymn
92 1.2 jdc if (!(ch & __CHARTEXT))
93 1.2 jdc ch |= ACS_HLINE;
94 1.1 blymn for (i = 0; i < n; i++)
95 1.1 blymn mvwaddch(win, win->cury, ocurx + i, ch);
96 1.7 roy
97 1.1 blymn wmove(win, win->cury, ocurx);
98 1.1 blymn return OK;
99 1.6 drochner #else
100 1.6 drochner cchar_t cch, *cchp;
101 1.6 drochner
102 1.6 drochner if (ch & __CHARTEXT) {
103 1.6 drochner __cursesi_chtype_to_cchar(ch, &cch);
104 1.6 drochner cchp = & cch;
105 1.6 drochner } else
106 1.6 drochner cchp = WACS_HLINE;
107 1.6 drochner
108 1.6 drochner return whline_set(win, cchp, count);
109 1.6 drochner #endif
110 1.1 blymn }
111 1.1 blymn
112 1.1 blymn /*
113 1.1 blymn * vline --
114 1.5 blymn * Draw a vertical line of character ch on stdscr.
115 1.1 blymn */
116 1.1 blymn int
117 1.1 blymn vline(chtype ch, int count)
118 1.1 blymn {
119 1.1 blymn return wvline(stdscr, ch, count);
120 1.1 blymn }
121 1.1 blymn
122 1.1 blymn /*
123 1.1 blymn * mvvline --
124 1.5 blymn * Move to the given location an draw a vertical line of character ch.
125 1.1 blymn */
126 1.1 blymn int
127 1.1 blymn mvvline(int y, int x, chtype ch, int count)
128 1.1 blymn {
129 1.1 blymn return mvwvline(stdscr, y, x, ch, count);
130 1.1 blymn }
131 1.1 blymn
132 1.1 blymn /*
133 1.1 blymn * mvwvline --
134 1.5 blymn * Move to the given location and draw a vertical line of character ch
135 1.5 blymn * on the given window.
136 1.1 blymn */
137 1.1 blymn int
138 1.1 blymn mvwvline(WINDOW *win, int y, int x, chtype ch, int count)
139 1.1 blymn {
140 1.1 blymn if (wmove(win, y, x) == ERR)
141 1.1 blymn return ERR;
142 1.1 blymn
143 1.1 blymn return wvline(win, ch, count);
144 1.1 blymn }
145 1.1 blymn
146 1.1 blymn /*
147 1.1 blymn * wvline --
148 1.5 blymn * Draw a vertical line of character ch in the given window moving
149 1.5 blymn * towards the bottom of the screen. At most count characters are drawn
150 1.5 blymn * or until the edge of the screen, whichever comes first.
151 1.1 blymn */
152 1.1 blymn int
153 1.1 blymn wvline(WINDOW *win, chtype ch, int count)
154 1.1 blymn {
155 1.6 drochner #ifndef HAVE_WCHAR
156 1.1 blymn int ocury, ocurx, n, i;
157 1.1 blymn
158 1.1 blymn n = min(count, win->maxy - win->cury);
159 1.1 blymn ocury = win->cury;
160 1.1 blymn ocurx = win->curx;
161 1.1 blymn
162 1.2 jdc if (!(ch & __CHARTEXT))
163 1.2 jdc ch |= ACS_VLINE;
164 1.1 blymn for (i = 0; i < n; i++)
165 1.1 blymn mvwaddch(win, ocury + i, ocurx, ch);
166 1.1 blymn
167 1.1 blymn wmove(win, ocury, ocurx);
168 1.1 blymn return OK;
169 1.6 drochner #else
170 1.6 drochner cchar_t cch, *cchp;
171 1.6 drochner
172 1.6 drochner if (ch & __CHARTEXT) {
173 1.6 drochner __cursesi_chtype_to_cchar(ch, &cch);
174 1.6 drochner cchp = & cch;
175 1.6 drochner } else
176 1.6 drochner cchp = WACS_VLINE;
177 1.6 drochner
178 1.6 drochner return wvline_set(win, cchp, count);
179 1.6 drochner #endif
180 1.1 blymn }
181 1.5 blymn
182 1.5 blymn int hline_set(const cchar_t *wch, int n)
183 1.5 blymn {
184 1.5 blymn #ifndef HAVE_WCHAR
185 1.5 blymn return ERR;
186 1.5 blymn #else
187 1.5 blymn return whline_set( stdscr, wch, n );
188 1.5 blymn #endif /* HAVE_WCHAR */
189 1.5 blymn }
190 1.5 blymn
191 1.5 blymn int mvhline_set(int y, int x, const cchar_t *wch, int n)
192 1.5 blymn {
193 1.5 blymn #ifndef HAVE_WCHAR
194 1.5 blymn return ERR;
195 1.5 blymn #else
196 1.5 blymn return mvwhline_set( stdscr, y, x, wch, n );
197 1.5 blymn #endif /* HAVE_WCHAR */
198 1.5 blymn }
199 1.5 blymn
200 1.5 blymn int mvwhline_set(WINDOW *win, int y, int x, const cchar_t *wch, int n)
201 1.5 blymn {
202 1.5 blymn #ifndef HAVE_WCHAR
203 1.5 blymn return ERR;
204 1.5 blymn #else
205 1.5 blymn if ( wmove( win, y , x ) == ERR )
206 1.5 blymn return ERR;
207 1.5 blymn
208 1.5 blymn return whline_set( win, wch, n );
209 1.5 blymn #endif /* HAVE_WCHAR */
210 1.5 blymn }
211 1.5 blymn
212 1.5 blymn int whline_set(WINDOW *win, const cchar_t *wch, int n)
213 1.5 blymn {
214 1.5 blymn #ifndef HAVE_WCHAR
215 1.5 blymn return ERR;
216 1.5 blymn #else
217 1.5 blymn int ocurx, wcn, i, cw;
218 1.5 blymn cchar_t cc;
219 1.5 blymn
220 1.5 blymn cw = wcwidth( wch->vals[ 0 ]);
221 1.6 drochner if (cw < 0)
222 1.6 drochner cw = 1;
223 1.5 blymn if ( ( win->maxx - win->curx ) < cw )
224 1.5 blymn return ERR;
225 1.5 blymn wcn = min( n, ( win->maxx - win->curx ) / cw );
226 1.5 blymn #ifdef DEBUG
227 1.5 blymn __CTRACE(__CTRACE_LINE, "whline_set: line of %d\n", wcn);
228 1.5 blymn #endif /* DEBUG */
229 1.5 blymn ocurx = win->curx;
230 1.5 blymn
231 1.5 blymn memcpy( &cc, wch, sizeof( cchar_t ));
232 1.5 blymn if (!(wch->vals[ 0 ]))
233 1.6 drochner cc.vals[ 0 ] |= WACS_HLINE->vals[0];
234 1.5 blymn for (i = 0; i < wcn; i++ ) {
235 1.5 blymn #ifdef DEBUG
236 1.5 blymn __CTRACE(__CTRACE_LINE, "whline_set: (%d,%d)\n",
237 1.5 blymn win->cury, ocurx + i * cw);
238 1.5 blymn #endif /* DEBUG */
239 1.5 blymn mvwadd_wch(win, win->cury, ocurx + i * cw, &cc);
240 1.5 blymn }
241 1.7 roy
242 1.5 blymn wmove(win, win->cury, ocurx);
243 1.8 roy __sync(win);
244 1.5 blymn return OK;
245 1.5 blymn #endif /* HAVE_WCHAR */
246 1.5 blymn }
247 1.5 blymn
248 1.5 blymn int vline_set(const cchar_t *wch, int n)
249 1.5 blymn {
250 1.5 blymn #ifndef HAVE_WCHAR
251 1.5 blymn return ERR;
252 1.5 blymn #else
253 1.5 blymn return wvline_set( stdscr, wch, n );
254 1.5 blymn #endif /* HAVE_WCHAR */
255 1.5 blymn }
256 1.5 blymn
257 1.5 blymn int mvvline_set(int y, int x, const cchar_t *wch, int n)
258 1.5 blymn {
259 1.5 blymn #ifndef HAVE_WCHAR
260 1.5 blymn return ERR;
261 1.5 blymn #else
262 1.5 blymn return mvwvline_set( stdscr, y, x, wch, n );
263 1.5 blymn #endif /* HAVE_WCHAR */
264 1.5 blymn }
265 1.5 blymn
266 1.5 blymn int mvwvline_set(WINDOW *win, int y, int x, const cchar_t *wch, int n)
267 1.5 blymn {
268 1.5 blymn #ifndef HAVE_WCHAR
269 1.5 blymn return ERR;
270 1.5 blymn #else
271 1.5 blymn if ( wmove( win, y, x ) == ERR )
272 1.5 blymn return ERR;
273 1.5 blymn
274 1.5 blymn return wvline_set( win, wch, n );
275 1.5 blymn #endif /* HAVE_WCHAR */
276 1.5 blymn }
277 1.5 blymn
278 1.5 blymn int wvline_set(WINDOW *win, const cchar_t *wch, int n)
279 1.5 blymn {
280 1.5 blymn #ifndef HAVE_WCHAR
281 1.5 blymn return ERR;
282 1.5 blymn #else
283 1.5 blymn int ocury, ocurx, wcn, i;
284 1.5 blymn cchar_t cc;
285 1.5 blymn
286 1.5 blymn wcn = min( n, win->maxy - win->cury);
287 1.5 blymn #ifdef DEBUG
288 1.5 blymn __CTRACE(__CTRACE_LINE, "wvline_set: line of %d\n", wcn);
289 1.5 blymn #endif /* DEBUG */
290 1.5 blymn ocury = win->cury;
291 1.5 blymn ocurx = win->curx;
292 1.5 blymn
293 1.5 blymn memcpy( &cc, wch, sizeof( cchar_t ));
294 1.5 blymn if (!(wch->vals[ 0 ]))
295 1.6 drochner cc.vals[ 0 ] |= WACS_VLINE->vals[0];
296 1.5 blymn for (i = 0; i < wcn; i++) {
297 1.5 blymn mvwadd_wch(win, ocury + i, ocurx, &cc);
298 1.5 blymn #ifdef DEBUG
299 1.5 blymn __CTRACE(__CTRACE_LINE, "wvline_set: (%d,%d)\n",
300 1.5 blymn ocury + i, ocurx);
301 1.5 blymn #endif /* DEBUG */
302 1.5 blymn }
303 1.8 roy
304 1.5 blymn wmove(win, ocury, ocurx);
305 1.8 roy __sync(win);
306 1.5 blymn return OK;
307 1.5 blymn #endif /* HAVE_WCHAR */
308 1.5 blymn }
309