1
0
mirror of https://git.tartarus.org/simon/putty.git synced 2025-01-25 01:02:24 +00:00

Divide the do_paint() loop into several subloops. The activity of

going through the line and working out which bits need to be redrawn
is now in a separate loop from the subsequent activity of actually
going through and doing the redraws. This _should_ enable me to
tinker with the which-bits-to-redraw data in between the two, thus
fixing `font-overflow'. However, I thought it would be sensible to
break the work up into two commits so we can track bugs in the
restructuring separately from bugs introduced by the new feature.

Also added a couple more terminal test files.

[originally from svn r5001]
This commit is contained in:
Simon Tatham 2004-12-17 11:37:16 +00:00
parent fb6a1e9d42
commit f4246872c4
3 changed files with 62 additions and 8 deletions

View File

@ -4543,12 +4543,15 @@ static void do_paint(Terminal *term, Context ctx, int may_optimise)
#ifdef OPTIMISE_SCROLL #ifdef OPTIMISE_SCROLL
struct scrollregion *sr; struct scrollregion *sr;
#endif /* OPTIMISE_SCROLL */ #endif /* OPTIMISE_SCROLL */
termchar *newline;
cursor_background = term->basic_erase_char; cursor_background = term->basic_erase_char;
chlen = 1024; chlen = 1024;
ch = snewn(chlen, wchar_t); ch = snewn(chlen, wchar_t);
newline = snewn(term->cols, termchar);
rv = (!term->rvideo ^ !term->in_vbell ? ATTR_REVERSE : 0); rv = (!term->rvideo ^ !term->in_vbell ? ATTR_REVERSE : 0);
/* Depends on: /* Depends on:
@ -4648,10 +4651,6 @@ static void do_paint(Terminal *term, Context ctx, int may_optimise)
scrpos.y = i + term->disptop; scrpos.y = i + term->disptop;
ldata = lineptr(scrpos.y); ldata = lineptr(scrpos.y);
dirty_run = dirty_line = (ldata->lattr !=
term->disptext[i]->lattr);
term->disptext[i]->lattr = ldata->lattr;
/* Do Arabic shaping and bidi. */ /* Do Arabic shaping and bidi. */
lchars = term_bidi_line(term, ldata, i); lchars = term_bidi_line(term, ldata, i);
if (lchars) { if (lchars) {
@ -4661,10 +4660,13 @@ static void do_paint(Terminal *term, Context ctx, int may_optimise)
backward = NULL; backward = NULL;
} }
/*
* First loop: work along the line deciding what we want
* each character cell to look like.
*/
for (j = 0; j < term->cols; j++) { for (j = 0; j < term->cols; j++) {
unsigned long tattr, tchar; unsigned long tattr, tchar;
termchar *d = lchars + j; termchar *d = lchars + j;
int break_run, do_copy;
scrpos.x = backward ? backward[j] : j; scrpos.x = backward ? backward[j] : j;
tchar = d->chr; tchar = d->chr;
@ -4745,6 +4747,39 @@ static void do_paint(Terminal *term, Context ctx, int may_optimise)
term->dispcursy = i; term->dispcursy = i;
} }
/* FULL-TERMCHAR */
newline[j].attr = tattr;
newline[j].chr = tchar;
/* Combining characters are still read from lchars */
newline[j].cc_next = 0;
}
/*
* Now loop over the line again, noting where things have
* changed.
*/
for (j = 0; j < term->cols; j++) {
if (term->disptext[i]->chars[j].chr != newline[j].chr ||
term->disptext[i]->chars[j].attr != newline[j].attr) {
term->disptext[i]->chars[j].attr |= ATTR_INVALID;
}
}
/*
* Finally, loop once more and actually do the drawing.
*/
dirty_run = dirty_line = (ldata->lattr !=
term->disptext[i]->lattr);
term->disptext[i]->lattr = ldata->lattr;
for (j = 0; j < term->cols; j++) {
unsigned long tattr, tchar;
int break_run, do_copy;
termchar *d = lchars + j;
tattr = newline[j].attr;
tchar = newline[j].chr;
if ((term->disptext[i]->chars[j].attr ^ tattr) & ATTR_WIDE) if ((term->disptext[i]->chars[j].attr ^ tattr) & ATTR_WIDE)
dirty_line = TRUE; dirty_line = TRUE;
@ -4908,6 +4943,7 @@ static void do_paint(Terminal *term, Context ctx, int may_optimise)
unlineptr(ldata); unlineptr(ldata);
} }
sfree(newline);
sfree(ch); sfree(ch);
} }
@ -4920,7 +4956,7 @@ void term_invalidate(Terminal *term)
for (i = 0; i < term->rows; i++) for (i = 0; i < term->rows; i++)
for (j = 0; j < term->cols; j++) for (j = 0; j < term->cols; j++)
term->disptext[i]->chars[j].attr = ATTR_INVALID; term->disptext[i]->chars[j].attr |= ATTR_INVALID;
term_schedule_update(term); term_schedule_update(term);
} }
@ -4940,10 +4976,10 @@ void term_paint(Terminal *term, Context ctx,
for (i = top; i <= bottom && i < term->rows; i++) { for (i = top; i <= bottom && i < term->rows; i++) {
if ((term->disptext[i]->lattr & LATTR_MODE) == LATTR_NORM) if ((term->disptext[i]->lattr & LATTR_MODE) == LATTR_NORM)
for (j = left; j <= right && j < term->cols; j++) for (j = left; j <= right && j < term->cols; j++)
term->disptext[i]->chars[j].attr = ATTR_INVALID; term->disptext[i]->chars[j].attr |= ATTR_INVALID;
else else
for (j = left / 2; j <= right / 2 + 1 && j < term->cols; j++) for (j = left / 2; j <= right / 2 + 1 && j < term->cols; j++)
term->disptext[i]->chars[j].attr = ATTR_INVALID; term->disptext[i]->chars[j].attr |= ATTR_INVALID;
} }
if (immediately) { if (immediately) {

6
testdata/lattrs.txt vendored Normal file
View File

@ -0,0 +1,6 @@
Test of line attributes:
#3Double-height top
#4Double-height bottom
#5Normal text (#5)
#6Double-width only

12
testdata/vt100.txt vendored Normal file
View File

@ -0,0 +1,12 @@
VT100 line drawing characters, actually using the VT100 escapes
(B)0ooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooooo
lqqqqqqqqqqpoopqrssrqqqqqqqqqqwqqqqqqqqqqpoopqrssrqqqqqqqqqqk
x x x
x ooh, swirly! x top right corner x
x x x
tqqqqqqqqqqpoopqrssrqqqqqqqqqqnqqqqqqqqqqpoopqrssrqqqqqqqqqqu
x x x
x stuff down here x is quite inane x
x x x
mqqqqqqqqqqpoopqrssrqqqqqqqqqqvqqqqqqqqqqpoopqrssrqqqqqqqqqqj