Home | History | Annotate | Line # | Download | only in libcurses
clrtoeol.c revision 1.26.14.1
      1  1.26.14.1  pgoyette /*	$NetBSD: clrtoeol.c,v 1.26.14.1 2017/01/07 08:56:03 pgoyette Exp $	*/
      2        1.8     mikel 
      3        1.1       cgd /*
      4        1.7       cgd  * Copyright (c) 1981, 1993, 1994
      5        1.5       cgd  *	The Regents of the University of California.  All rights reserved.
      6        1.1       cgd  *
      7        1.1       cgd  * Redistribution and use in source and binary forms, with or without
      8        1.1       cgd  * modification, are permitted provided that the following conditions
      9        1.1       cgd  * are met:
     10        1.1       cgd  * 1. Redistributions of source code must retain the above copyright
     11        1.1       cgd  *    notice, this list of conditions and the following disclaimer.
     12        1.1       cgd  * 2. Redistributions in binary form must reproduce the above copyright
     13        1.1       cgd  *    notice, this list of conditions and the following disclaimer in the
     14        1.1       cgd  *    documentation and/or other materials provided with the distribution.
     15       1.17       agc  * 3. Neither the name of the University nor the names of its contributors
     16        1.1       cgd  *    may be used to endorse or promote products derived from this software
     17        1.1       cgd  *    without specific prior written permission.
     18        1.1       cgd  *
     19        1.1       cgd  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
     20        1.1       cgd  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
     21        1.1       cgd  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
     22        1.1       cgd  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
     23        1.1       cgd  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
     24        1.1       cgd  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
     25        1.1       cgd  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
     26        1.1       cgd  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
     27        1.1       cgd  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
     28        1.1       cgd  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
     29        1.1       cgd  * SUCH DAMAGE.
     30        1.1       cgd  */
     31        1.1       cgd 
     32        1.8     mikel #include <sys/cdefs.h>
     33        1.1       cgd #ifndef lint
     34        1.8     mikel #if 0
     35        1.7       cgd static char sccsid[] = "@(#)clrtoeol.c	8.2 (Berkeley) 5/4/94";
     36        1.8     mikel #else
     37  1.26.14.1  pgoyette __RCSID("$NetBSD: clrtoeol.c,v 1.26.14.1 2017/01/07 08:56:03 pgoyette Exp $");
     38        1.8     mikel #endif
     39       1.10       mrg #endif				/* not lint */
     40        1.1       cgd 
     41       1.23     blymn #include <stdlib.h>
     42        1.7       cgd #include "curses.h"
     43       1.11     blymn #include "curses_private.h"
     44        1.1       cgd 
     45       1.12     blymn #ifndef _CURSES_USE_MACROS
     46       1.12     blymn 
     47       1.12     blymn /*
     48       1.12     blymn  * clrtoeol --
     49       1.12     blymn  *	Clear up to the end of line.
     50       1.12     blymn  */
     51       1.12     blymn int
     52       1.12     blymn clrtoeol(void)
     53       1.12     blymn {
     54       1.12     blymn 	return wclrtoeol(stdscr);
     55       1.12     blymn }
     56       1.12     blymn 
     57       1.12     blymn #endif
     58       1.15     blymn 
     59        1.1       cgd /*
     60        1.4   mycroft  * wclrtoeol --
     61        1.4   mycroft  *	Clear up to the end of line.
     62        1.1       cgd  */
     63        1.4   mycroft int
     64       1.12     blymn wclrtoeol(WINDOW *win)
     65        1.4   mycroft {
     66       1.10       mrg 	int     minx, x, y;
     67        1.9     perry 	__LDATA *end, *maxx, *sp;
     68       1.19       jdc 	attr_t	attr;
     69        1.1       cgd 
     70        1.5       cgd 	y = win->cury;
     71        1.5       cgd 	x = win->curx;
     72       1.25       roy 	if (win->alines[y]->flags & __ISPASTEOL) {
     73        1.5       cgd 		if (y < win->maxy - 1) {
     74       1.25       roy 			win->alines[y]->flags &= ~__ISPASTEOL;
     75        1.5       cgd 			y++;
     76        1.5       cgd 			x = 0;
     77       1.16       jdc 			win->cury = y;
     78       1.16       jdc 			win->curx = x;
     79        1.5       cgd 		} else
     80  1.26.14.1  pgoyette 			return OK;
     81        1.5       cgd 	}
     82       1.25       roy 	end = &win->alines[y]->line[win->maxx];
     83        1.5       cgd 	minx = -1;
     84       1.25       roy 	maxx = &win->alines[y]->line[x];
     85       1.26  christos 	if (win != curscr)
     86       1.26  christos 		attr = win->battr & __ATTRIBUTES;
     87       1.19       jdc 	else
     88       1.19       jdc 		attr = 0;
     89        1.1       cgd 	for (sp = maxx; sp < end; sp++)
     90       1.23     blymn #ifndef HAVE_WCHAR
     91       1.21       jdc 		if (sp->ch != win->bch || sp->attr != attr) {
     92       1.23     blymn #else
     93  1.26.14.1  pgoyette 		if (sp->ch != (wchar_t)btowc((int) win->bch ) ||
     94       1.23     blymn 		    (sp->attr & WA_ATTRIBUTES) != attr || sp->nsp
     95       1.23     blymn 		    || (WCOL(*sp) < 0)) {
     96       1.23     blymn #endif /* HAVE_WCHAR */
     97        1.1       cgd 			maxx = sp;
     98        1.5       cgd 			if (minx == -1)
     99       1.25       roy 				minx = (int) (sp - win->alines[y]->line);
    100       1.26  christos 			sp->attr = attr | (sp->attr & __ALTCHARSET);
    101       1.23     blymn #ifdef HAVE_WCHAR
    102  1.26.14.1  pgoyette 			sp->ch = (wchar_t)btowc((int) win->bch);
    103       1.23     blymn 			if (_cursesi_copy_nsp(win->bnsp, sp) == ERR)
    104       1.23     blymn 				return ERR;
    105  1.26.14.1  pgoyette 			SET_WCOL(*sp, 1);
    106       1.23     blymn #else
    107       1.21       jdc 			sp->ch = win->bch;
    108       1.23     blymn #endif /* HAVE_WCHAR */
    109        1.1       cgd 		}
    110        1.4   mycroft #ifdef DEBUG
    111       1.23     blymn 	__CTRACE(__CTRACE_ERASE, "CLRTOEOL: y = %d, minx = %d, maxx = %d, "
    112       1.22       jdc 	    "firstch = %d, lastch = %d\n",
    113  1.26.14.1  pgoyette 	    y, minx, (int)(maxx - win->alines[y]->line),
    114       1.25       roy 	    *win->alines[y]->firstchp, *win->alines[y]->lastchp);
    115        1.4   mycroft #endif
    116        1.4   mycroft 	/* Update firstch and lastch for the line. */
    117  1.26.14.1  pgoyette 	__touchline(win, y, x, (int)win->maxx - 1);
    118  1.26.14.1  pgoyette 	__sync(win);
    119  1.26.14.1  pgoyette 	return OK;
    120        1.1       cgd }
    121