Home | History | Annotate | Line # | Download | only in libcurses
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