1*51ffecc1SBen Gras /* $NetBSD: delch.c,v 1.22 2009/07/22 16:57:14 roy Exp $ */
2*51ffecc1SBen Gras
3*51ffecc1SBen Gras /*
4*51ffecc1SBen Gras * Copyright (c) 1981, 1993, 1994
5*51ffecc1SBen Gras * The Regents of the University of California. All rights reserved.
6*51ffecc1SBen Gras *
7*51ffecc1SBen Gras * Redistribution and use in source and binary forms, with or without
8*51ffecc1SBen Gras * modification, are permitted provided that the following conditions
9*51ffecc1SBen Gras * are met:
10*51ffecc1SBen Gras * 1. Redistributions of source code must retain the above copyright
11*51ffecc1SBen Gras * notice, this list of conditions and the following disclaimer.
12*51ffecc1SBen Gras * 2. Redistributions in binary form must reproduce the above copyright
13*51ffecc1SBen Gras * notice, this list of conditions and the following disclaimer in the
14*51ffecc1SBen Gras * documentation and/or other materials provided with the distribution.
15*51ffecc1SBen Gras * 3. Neither the name of the University nor the names of its contributors
16*51ffecc1SBen Gras * may be used to endorse or promote products derived from this software
17*51ffecc1SBen Gras * without specific prior written permission.
18*51ffecc1SBen Gras *
19*51ffecc1SBen Gras * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
20*51ffecc1SBen Gras * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
21*51ffecc1SBen Gras * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
22*51ffecc1SBen Gras * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
23*51ffecc1SBen Gras * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
24*51ffecc1SBen Gras * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
25*51ffecc1SBen Gras * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
26*51ffecc1SBen Gras * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
27*51ffecc1SBen Gras * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
28*51ffecc1SBen Gras * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
29*51ffecc1SBen Gras * SUCH DAMAGE.
30*51ffecc1SBen Gras */
31*51ffecc1SBen Gras
32*51ffecc1SBen Gras #include <sys/cdefs.h>
33*51ffecc1SBen Gras #ifndef lint
34*51ffecc1SBen Gras #if 0
35*51ffecc1SBen Gras static char sccsid[] = "@(#)delch.c 8.2 (Berkeley) 5/4/94";
36*51ffecc1SBen Gras #else
37*51ffecc1SBen Gras __RCSID("$NetBSD: delch.c,v 1.22 2009/07/22 16:57:14 roy Exp $");
38*51ffecc1SBen Gras #endif
39*51ffecc1SBen Gras #endif /* not lint */
40*51ffecc1SBen Gras
41*51ffecc1SBen Gras #include <string.h>
42*51ffecc1SBen Gras #include <stdlib.h>
43*51ffecc1SBen Gras
44*51ffecc1SBen Gras #include "curses.h"
45*51ffecc1SBen Gras #include "curses_private.h"
46*51ffecc1SBen Gras
47*51ffecc1SBen Gras #ifndef _CURSES_USE_MACROS
48*51ffecc1SBen Gras /*
49*51ffecc1SBen Gras * delch --
50*51ffecc1SBen Gras * Do a delete-char on the line, leaving (cury, curx) unchanged.
51*51ffecc1SBen Gras */
52*51ffecc1SBen Gras int
delch(void)53*51ffecc1SBen Gras delch(void)
54*51ffecc1SBen Gras {
55*51ffecc1SBen Gras return wdelch(stdscr);
56*51ffecc1SBen Gras }
57*51ffecc1SBen Gras
58*51ffecc1SBen Gras /*
59*51ffecc1SBen Gras * mvdelch --
60*51ffecc1SBen Gras * Do a delete-char on the line at (y, x) on stdscr.
61*51ffecc1SBen Gras */
62*51ffecc1SBen Gras int
mvdelch(int y,int x)63*51ffecc1SBen Gras mvdelch(int y, int x)
64*51ffecc1SBen Gras {
65*51ffecc1SBen Gras return mvwdelch(stdscr, y, x);
66*51ffecc1SBen Gras }
67*51ffecc1SBen Gras
68*51ffecc1SBen Gras /*
69*51ffecc1SBen Gras * mvwdelch --
70*51ffecc1SBen Gras * Do a delete-char on the line at (y, x) of the given window.
71*51ffecc1SBen Gras */
72*51ffecc1SBen Gras int
mvwdelch(WINDOW * win,int y,int x)73*51ffecc1SBen Gras mvwdelch(WINDOW *win, int y, int x)
74*51ffecc1SBen Gras {
75*51ffecc1SBen Gras if (wmove(win, y, x) == ERR)
76*51ffecc1SBen Gras return ERR;
77*51ffecc1SBen Gras
78*51ffecc1SBen Gras return wdelch(win);
79*51ffecc1SBen Gras }
80*51ffecc1SBen Gras
81*51ffecc1SBen Gras #endif
82*51ffecc1SBen Gras
83*51ffecc1SBen Gras /*
84*51ffecc1SBen Gras * wdelch --
85*51ffecc1SBen Gras * Do a delete-char on the line, leaving (cury, curx) unchanged.
86*51ffecc1SBen Gras */
87*51ffecc1SBen Gras int
wdelch(WINDOW * win)88*51ffecc1SBen Gras wdelch(WINDOW *win)
89*51ffecc1SBen Gras {
90*51ffecc1SBen Gras __LDATA *end, *temp1, *temp2;
91*51ffecc1SBen Gras
92*51ffecc1SBen Gras #ifndef HAVE_WCHAR
93*51ffecc1SBen Gras end = &win->alines[win->cury]->line[win->maxx - 1];
94*51ffecc1SBen Gras temp1 = &win->alines[win->cury]->line[win->curx];
95*51ffecc1SBen Gras temp2 = temp1 + 1;
96*51ffecc1SBen Gras while (temp1 < end) {
97*51ffecc1SBen Gras (void) memcpy(temp1, temp2, sizeof(__LDATA));
98*51ffecc1SBen Gras temp1++, temp2++;
99*51ffecc1SBen Gras }
100*51ffecc1SBen Gras temp1->ch = win->bch;
101*51ffecc1SBen Gras if (__using_color && win != curscr)
102*51ffecc1SBen Gras temp1->attr = win->battr & __COLOR;
103*51ffecc1SBen Gras else
104*51ffecc1SBen Gras temp1->attr = 0;
105*51ffecc1SBen Gras __touchline(win, (int) win->cury, (int) win->curx, (int) win->maxx - 1);
106*51ffecc1SBen Gras return (OK);
107*51ffecc1SBen Gras #else
108*51ffecc1SBen Gras int cw, sx;
109*51ffecc1SBen Gras nschar_t *np, *tnp;
110*51ffecc1SBen Gras
111*51ffecc1SBen Gras end = &win->alines[win->cury]->line[win->maxx - 1];
112*51ffecc1SBen Gras sx = win->curx;
113*51ffecc1SBen Gras temp1 = &win->alines[win->cury]->line[win->curx];
114*51ffecc1SBen Gras cw = WCOL( *temp1 );
115*51ffecc1SBen Gras if ( cw < 0 ) {
116*51ffecc1SBen Gras temp1 += cw;
117*51ffecc1SBen Gras sx += cw;
118*51ffecc1SBen Gras cw = WCOL( *temp1 );
119*51ffecc1SBen Gras }
120*51ffecc1SBen Gras np = temp1->nsp;
121*51ffecc1SBen Gras if (np) {
122*51ffecc1SBen Gras while ( np ) {
123*51ffecc1SBen Gras tnp = np->next;
124*51ffecc1SBen Gras free( np );
125*51ffecc1SBen Gras np = tnp;
126*51ffecc1SBen Gras }
127*51ffecc1SBen Gras temp1->nsp = NULL;
128*51ffecc1SBen Gras }
129*51ffecc1SBen Gras if ( sx + cw < win->maxx ) {
130*51ffecc1SBen Gras temp2 = temp1 + cw;
131*51ffecc1SBen Gras while ( temp1 < end - ( cw - 1 )) {
132*51ffecc1SBen Gras ( void )memcpy( temp1, temp2, sizeof( __LDATA ));
133*51ffecc1SBen Gras temp1++, temp2++;
134*51ffecc1SBen Gras }
135*51ffecc1SBen Gras }
136*51ffecc1SBen Gras while ( temp1 <= end ) {
137*51ffecc1SBen Gras temp1->ch = ( wchar_t )btowc(( int ) win->bch );
138*51ffecc1SBen Gras temp1->attr = 0;
139*51ffecc1SBen Gras if (_cursesi_copy_nsp(win->bnsp, temp1) == ERR)
140*51ffecc1SBen Gras return ERR;
141*51ffecc1SBen Gras SET_WCOL(*temp1, 1);
142*51ffecc1SBen Gras temp1++;
143*51ffecc1SBen Gras }
144*51ffecc1SBen Gras __touchline(win, (int) win->cury, sx, (int) win->maxx - 1);
145*51ffecc1SBen Gras return (OK);
146*51ffecc1SBen Gras #endif /* HAVE_WCHAR */
147*51ffecc1SBen Gras }
148