selection is removed or scrolled properly. (thx Rafa Garcia Gallego)
parent
b032814e25
commit
4bd087766f
30
st.c
30
st.c
|
@ -237,6 +237,7 @@ static void selinit(void);
|
||||||
static inline int selected(int, int);
|
static inline int selected(int, int);
|
||||||
static void selcopy(void);
|
static void selcopy(void);
|
||||||
static void selpaste();
|
static void selpaste();
|
||||||
|
static void selscroll(int, int);
|
||||||
|
|
||||||
static int utf8decode(char *, long *);
|
static int utf8decode(char *, long *);
|
||||||
static int utf8encode(long *, char *);
|
static int utf8encode(long *, char *);
|
||||||
|
@ -806,6 +807,8 @@ tscrolldown(int orig, int n) {
|
||||||
term.line[i] = term.line[i-n];
|
term.line[i] = term.line[i-n];
|
||||||
term.line[i-n] = temp;
|
term.line[i-n] = temp;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
selscroll(orig, n);
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
@ -821,6 +824,31 @@ tscrollup(int orig, int n) {
|
||||||
term.line[i] = term.line[i+n];
|
term.line[i] = term.line[i+n];
|
||||||
term.line[i+n] = temp;
|
term.line[i+n] = temp;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
selscroll(orig, -n);
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
selscroll(int orig, int n) {
|
||||||
|
if(sel.bx == -1)
|
||||||
|
return;
|
||||||
|
|
||||||
|
if(BETWEEN(sel.by, orig, term.bot) || BETWEEN(sel.ey, orig, term.bot)) {
|
||||||
|
if((sel.by += n) > term.bot || (sel.ey += n) < term.top) {
|
||||||
|
sel.bx = -1;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if(sel.by < term.top) {
|
||||||
|
sel.by = term.top;
|
||||||
|
sel.bx = 0;
|
||||||
|
}
|
||||||
|
if(sel.ey > term.bot) {
|
||||||
|
sel.ey = term.bot;
|
||||||
|
sel.ex = term.col;
|
||||||
|
}
|
||||||
|
sel.b.y = sel.by, sel.b.x = sel.bx;
|
||||||
|
sel.e.y = sel.ey, sel.e.x = sel.ex;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
@ -1077,6 +1105,7 @@ csihandle(void) {
|
||||||
break;
|
break;
|
||||||
/* XXX: (CSI n I) CHT -- Cursor Forward Tabulation <n> tab stops */
|
/* XXX: (CSI n I) CHT -- Cursor Forward Tabulation <n> tab stops */
|
||||||
case 'J': /* ED -- Clear screen */
|
case 'J': /* ED -- Clear screen */
|
||||||
|
sel.bx = -1;
|
||||||
switch(escseq.arg[0]) {
|
switch(escseq.arg[0]) {
|
||||||
case 0: /* below */
|
case 0: /* below */
|
||||||
tclearregion(term.c.x, term.c.y, term.col-1, term.c.y);
|
tclearregion(term.c.x, term.c.y, term.col-1, term.c.y);
|
||||||
|
@ -1382,6 +1411,7 @@ tputc(char *c) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
if(sel.bx != -1 && BETWEEN(term.c.y, sel.by, sel.ey)) sel.bx = -1;
|
||||||
switch(ascii) {
|
switch(ascii) {
|
||||||
case '\t':
|
case '\t':
|
||||||
tputtab();
|
tputtab();
|
||||||
|
|
Reference in New Issue