1 /* $NetBSD: ins_wch.c,v 1.6 2013/10/16 19:59:29 roy Exp $ */
4 * Copyright (c) 2005 The NetBSD Foundation Inc.
7 * This code is derived from code donated to the NetBSD Foundation
8 * by Ruibiao Qiu <ruibiao@arl.wustl.edu,ruibiao@gmail.com>.
11 * Redistribution and use in source and binary forms, with or without
12 * modification, are permitted provided that the following conditions
14 * 1. Redistributions of source code must retain the above copyright
15 * notice, this list of conditions and the following disclaimer.
16 * 2. Redistributions in binary form must reproduce the above copyright
17 * notice, this list of conditions and the following disclaimer in the
18 * documentation and/or other materials provided with the distribution.
19 * 3. Neither the name of the NetBSD Foundation nor the names of its
20 * contributors may be used to endorse or promote products derived
21 * from this software without specific prior written permission.
23 * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND
24 * CONTRIBUTORS ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES,
25 * INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
26 * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
27 * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
28 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
29 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
30 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
31 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
32 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
33 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
37 #include <sys/cdefs.h>
39 __RCSID("$NetBSD: ins_wch.c,v 1.6 2013/10/16 19:59:29 roy Exp $");
46 #include "curses_private.h"
50 * Do an insert-char on the line, leaving (cury, curx) unchanged.
53 ins_wch(const cchar_t
*wch
)
58 return wins_wch(stdscr
, wch
);
59 #endif /* HAVE_WCHAR */
64 * Do an insert-char on the line at (y, x).
67 mvins_wch(int y
, int x
, const cchar_t
*wch
)
72 return mvwins_wch(stdscr
, y
, x
, wch
);
73 #endif /* HAVE_WCHAR */
78 * Do an insert-char on the line at (y, x) in the given window.
81 mvwins_wch(WINDOW
*win
, int y
, int x
, const cchar_t
*wch
)
86 if (wmove(win
, y
, x
) == ERR
)
89 return wins_wch(stdscr
, wch
);
90 #endif /* HAVE_WCHAR */
95 * Do an insert-char on the line, leaving (cury, curx) unchanged.
98 wins_wch(WINDOW
*win
, const cchar_t
*wch
)
103 __LDATA
*start
, *temp1
, *temp2
;
105 int cw
, pcw
, x
, y
, sx
, ex
, newx
, i
, tabsize
;
109 /* check for non-spacing characters */
112 cw
= wcwidth(wch
->vals
[0]);
116 return wadd_wch( win
, wch
);
119 __CTRACE(__CTRACE_INPUT
, "--before--\n");
120 for ( x
= 0; x
< win
->maxx
; x
++ )
121 __CTRACE(__CTRACE_INPUT
, "wins_wch: (0,%d)=(%x,%x,%p)\n", x
,
122 win
->alines
[0]->line
[x
].ch
,
123 win
->alines
[0]->line
[x
].attr
,
124 win
->alines
[0]->line
[x
].nsp
);
129 __CTRACE(__CTRACE_INPUT
, "wins_wch: (%d,%d)\n", y
, x
);
131 switch ( wch
->vals
[ 0 ]) {
142 if (y
== win
->scr_b
) {
143 if (!(win
->flags
& __SCROLLOK
))
149 tabsize
= win
->screen
->TABSIZE
;
150 if (wins_nwstr(win
, ws
, min(win
->maxx
- x
,
151 tabsize
- (x
% tabsize
))) == ERR
)
156 /* locate current cell */
159 lnp
= win
->alines
[ y
];
160 start
= &win
->alines
[ y
]->line
[ x
];
162 pcw
= WCOL( *start
);
167 if ( cw
> win
->maxx
- sx
)
169 lnp
->flags
|= __ISDIRTY
;
170 newx
= sx
+ win
->ch_off
;
171 if ( newx
< *lnp
->firstchp
)
172 *lnp
->firstchp
= newx
;
174 /* shift all complete characters */
176 __CTRACE(__CTRACE_INPUT
, "wins_wch: shift all characters\n");
178 temp1
= &win
->alines
[ y
]->line
[ win
->maxx
- 1 ];
180 pcw
= WCOL(*(temp2
+ 1));
183 __CTRACE(__CTRACE_INPUT
, "wins_wch: clear EOL\n");
186 while ( temp1
> temp2
+ cw
) {
196 temp1
->ch
= ( wchar_t )btowc(( int ) win
->bch
);
197 if (_cursesi_copy_nsp(win
->bnsp
, temp1
) == ERR
)
199 temp1
->attr
= win
->battr
;
200 SET_WCOL( *temp1
, 1 );
204 while ( temp2
>= start
) {
205 ( void )memcpy( temp1
, temp2
, sizeof( __LDATA
));
209 /* update character under cursor */
211 start
->ch
= wch
->vals
[ 0 ];
212 start
->attr
= wch
->attributes
& WA_ATTRIBUTES
;
213 SET_WCOL( *start
, cw
);
214 if ( wch
->elements
> 1 ) {
215 for ( i
= 1; i
< wch
->elements
; i
++ ) {
216 np
= (nschar_t
*)malloc(sizeof(nschar_t
));
219 np
->ch
= wch
->vals
[ i
];
220 np
->next
= start
->nsp
;
225 __CTRACE(__CTRACE_INPUT
, "wins_wch: insert (%x,%x,%p)\n",
226 start
->ch
, start
->attr
, start
->nsp
);
230 while ( ex
- x
< cw
) {
231 temp1
->ch
= wch
->vals
[ 0 ];
232 SET_WCOL( *temp1
, x
- ex
);
238 __CTRACE(__CTRACE_INPUT
, "--after---\n");
239 for ( x
= 0; x
< win
->maxx
; x
++ )
240 __CTRACE(__CTRACE_INPUT
,
241 "wins_wch: (0,%d)=(%x,%x,%p)\n", x
,
242 win
->alines
[0]->line
[x
].ch
,
243 win
->alines
[0]->line
[x
].attr
,
244 win
->alines
[0]->line
[x
].nsp
);
247 newx
= win
->maxx
- 1 + win
->ch_off
;
248 if ( newx
> *lnp
->lastchp
)
249 *lnp
->lastchp
= newx
;
250 __touchline(win
, y
, sx
, (int) win
->maxx
- 1);
253 #endif /* HAVE_WCHAR */