summaryrefslogtreecommitdiff
path: root/lib/libcurses/lib_clrbot.c
blob: f7feca7ec5d6c9cc54967ea5719e85b4f53eea1e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72

/***************************************************************************
*                            COPYRIGHT NOTICE                              *
****************************************************************************
*                ncurses is copyright (C) 1992-1995                        *
*                          Zeyd M. Ben-Halim                               *
*                          zmbenhal@netcom.com                             *
*                          Eric S. Raymond                                 *
*                          esr@snark.thyrsus.com                           *
*                                                                          *
*        Permission is hereby granted to reproduce and distribute ncurses  *
*        by any means and for any fee, whether alone or as part of a       *
*        larger distribution, in source or in binary form, PROVIDED        *
*        this notice is included with any such distribution, and is not    *
*        removed from any of its header files. Mention of ncurses in any   *
*        applications linked with it is highly appreciated.                *
*                                                                          *
*        ncurses comes AS IS with no warranty, implied or expressed.       *
*                                                                          *
***************************************************************************/

/*
**	lib_clrbot.c
**
**	The routine wclrtobot().
**
*/

#include "curses.priv.h"

int wclrtobot(WINDOW *win)
{
chtype	*ptr, *end, *maxx = NULL;
short	y, startx, minx;

	T(("wclrtobot(%p) called", win));

	startx = win->_curx;
	if (win->_flags & _NEED_WRAP)
		startx++;

	T(("clearing from y = %d to y = %d with maxx =  %d", win->_cury, win->_maxy, win->_maxx));

	for (y = win->_cury; y <= win->_maxy; y++) {
		minx = _NOCHANGE;
		end = &win->_line[y].text[win->_maxx];

		for (ptr = &win->_line[y].text[startx]; ptr <= end; ptr++) {
			int blank = _nc_render(win, *ptr, BLANK);

			if (*ptr != blank) {
				maxx = ptr;
				if (minx == _NOCHANGE)
					minx = ptr - win->_line[y].text;
				*ptr = blank;
			}
		}

		if (minx != _NOCHANGE) {
			if (win->_line[y].firstchar > minx
					||  win->_line[y].firstchar == _NOCHANGE)
			    win->_line[y].firstchar = minx;

			if (win->_line[y].lastchar < maxx - win->_line[y].text)
			    win->_line[y].lastchar = maxx - win->_line[y].text;
		}

		startx = 0;
	}
	_nc_synchook(win);
	return OK;
}