Fixed a glitch when using using the keyboardselect and scrollback patches. (#48)
Scrolling back and then entering keyboardselect's copy mode causes glitched text to appear when moving the cursor. This is because the keyboardselect patch is not aware of the scrollback history (term.hist), so it takes the text from the last displayed screen (term.line). Co-authored-by: Àlex Ramírez <aramirez@verbio.com>
This commit is contained in:
parent
d58abd5638
commit
6ce9ec69ad
|
@ -33,6 +33,21 @@ void set_notifmode(int type, KeySym ksym)
|
||||||
drawregion(0, bot, col, bot + 1);
|
drawregion(0, bot, col, bot + 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if SCROLLBACK_PATCH && KEYBOARDSELECT_PATCH
|
||||||
|
Glyph getglyph(Term term, int y, int x)
|
||||||
|
{
|
||||||
|
Glyph g;
|
||||||
|
int realy = y - term.scr;
|
||||||
|
if(realy >= 0) {
|
||||||
|
g = term.line[realy][x];
|
||||||
|
} else {
|
||||||
|
realy = term.histi - term.scr + y + 1;
|
||||||
|
g = term.hist[realy][x];
|
||||||
|
}
|
||||||
|
return g;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
void select_or_drawcursor(int selectsearch_mode, int type)
|
void select_or_drawcursor(int selectsearch_mode, int type)
|
||||||
{
|
{
|
||||||
int done = 0;
|
int done = 0;
|
||||||
|
@ -45,6 +60,9 @@ void select_or_drawcursor(int selectsearch_mode, int type)
|
||||||
xdrawcursor(term.c.x, term.c.y, term.line[term.c.y][term.c.x],
|
xdrawcursor(term.c.x, term.c.y, term.line[term.c.y][term.c.x],
|
||||||
term.ocx, term.ocy, term.line[term.ocy][term.ocx],
|
term.ocx, term.ocy, term.line[term.ocy][term.ocx],
|
||||||
term.line[term.ocy], term.col);
|
term.line[term.ocy], term.col);
|
||||||
|
#elif SCROLLBACK_PATCH && KEYBOARDSELECT_PATCH
|
||||||
|
xdrawcursor(term.c.x, term.c.y, getglyph(term, term.c.y, term.c.x),
|
||||||
|
term.ocx, term.ocy, getglyph(term, term.ocy, term.ocx));
|
||||||
#else
|
#else
|
||||||
xdrawcursor(term.c.x, term.c.y, term.line[term.c.y][term.c.x],
|
xdrawcursor(term.c.x, term.c.y, term.line[term.c.y][term.c.x],
|
||||||
term.ocx, term.ocy, term.line[term.ocy][term.ocx]);
|
term.ocx, term.ocy, term.line[term.ocy][term.ocx]);
|
||||||
|
|
Loading…
Reference in New Issue