|
|
|
@ -1060,12 +1060,25 @@ tresize(int col, int row) {
|
|
|
|
|
int i;
|
|
|
|
|
int minrow = MIN(row, term.row);
|
|
|
|
|
int mincol = MIN(col, term.col);
|
|
|
|
|
int slide = term.c.y - row + 1;
|
|
|
|
|
|
|
|
|
|
if(col < 1 || row < 1)
|
|
|
|
|
return;
|
|
|
|
|
|
|
|
|
|
/* free uneeded rows */
|
|
|
|
|
for(i = row; i < term.row; i++) {
|
|
|
|
|
/* free unneeded rows */
|
|
|
|
|
i = 0;
|
|
|
|
|
if(slide > 0) {
|
|
|
|
|
/* slide screen to keep cursor where we expect it -
|
|
|
|
|
* tscrollup would work here, but we can optimize to
|
|
|
|
|
* memmove because we're freeing the earlier lines */
|
|
|
|
|
for(/* i = 0 */; i < slide; i++) {
|
|
|
|
|
free(term.line[i]);
|
|
|
|
|
free(term.alt[i]);
|
|
|
|
|
}
|
|
|
|
|
memmove(term.line, term.line + slide, row * sizeof(Line));
|
|
|
|
|
memmove(term.alt, term.alt + slide, row * sizeof(Line));
|
|
|
|
|
}
|
|
|
|
|
for(i += row; i < term.row; i++) {
|
|
|
|
|
free(term.line[i]);
|
|
|
|
|
free(term.alt[i]);
|
|
|
|
|
}
|
|
|
|
|