blob: 4a39ce0aaa68ae53e5f283aec3514c4183cf26e6 (
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
|
/* This work is copyrighted. See COPYRIGHT.OLD & COPYRIGHT.NEW for *
* details. If they are missing then this copy is in violation of *
* the copyright conditions. */
/*
** lib_insertln.c
**
** The routine winsertln().
**
*/
#include "curses.priv.h"
#include <nterm.h>
int winsertln(WINDOW *win)
{
chtype *temp, *end;
int y, touched = 0;
T(("winsertln(%x) called", win));
temp = win->_line[win->_regbottom];
if (win->_idlok && (insert_line != NULL)) {
wrefresh(win);
putp(insert_line);
touched = 1;
}
if (!touched) {
win->_firstchar[win->_cury] = 0;
win->_lastchar[win->_cury] = win->_maxx;
}
for (y = win->_regbottom; y > win->_cury; y--) {
win->_line[y] = win->_line[y-1];
if (!touched) {
win->_firstchar[y] = 0;
win->_lastchar[y] = win->_maxx;
}
}
win->_line[win->_cury] = temp;
for (end = &temp[win->_maxx]; temp <= end; temp++)
*temp = ' ';
return OK;
}
|