prevent losing columns on resize
This commit is contained in:
		
							parent
							
								
									0af4782a47
								
							
						
					
					
						commit
						e053bd6036
					
				
							
								
								
									
										25
									
								
								st.c
									
									
									
									
									
								
							
							
						
						
									
										25
									
								
								st.c
									
									
									
									
									
								
							| @ -118,6 +118,7 @@ typedef struct { | ||||
| typedef struct { | ||||
| 	int row;      /* nb row */ | ||||
| 	int col;      /* nb col */ | ||||
| 	int maxcol; | ||||
| 	Line *line;   /* screen */ | ||||
| 	Line *alt;    /* alternate screen */ | ||||
| 	Line hist[HISTSIZE]; /* history buffer */ | ||||
| @ -1311,8 +1312,8 @@ tclearregion(int x1, int y1, int x2, int y2) | ||||
| 	if (y1 > y2) | ||||
| 		temp = y1, y1 = y2, y2 = temp; | ||||
| 
 | ||||
| 	LIMIT(x1, 0, term.col-1); | ||||
| 	LIMIT(x2, 0, term.col-1); | ||||
| 	LIMIT(x1, 0, term.maxcol-1); | ||||
| 	LIMIT(x2, 0, term.maxcol-1); | ||||
| 	LIMIT(y1, 0, term.row-1); | ||||
| 	LIMIT(y2, 0, term.row-1); | ||||
| 
 | ||||
| @ -2607,11 +2608,18 @@ void | ||||
| tresize(int col, int row) | ||||
| { | ||||
| 	int i, j; | ||||
| 	int minrow = MIN(row, term.row); | ||||
| 	int mincol = MIN(col, term.col); | ||||
| 	int tmp; | ||||
| 	int minrow, mincol; | ||||
| 	int *bp; | ||||
| 	TCursor c; | ||||
| 
 | ||||
| 	tmp = col; | ||||
| 	if (!term.maxcol) | ||||
| 		term.maxcol = term.col; | ||||
| 	col = MAX(col, term.maxcol); | ||||
| 	minrow = MIN(row, term.row); | ||||
| 	mincol = MIN(col, term.maxcol); | ||||
| 
 | ||||
| 	if (col < 1 || row < 1) { | ||||
| 		fprintf(stderr, | ||||
| 		        "tresize: error resizing to %dx%d\n", col, row); | ||||
| @ -2662,17 +2670,18 @@ tresize(int col, int row) | ||||
| 		term.line[i] = xmalloc(col * sizeof(Glyph)); | ||||
| 		term.alt[i] = xmalloc(col * sizeof(Glyph)); | ||||
| 	} | ||||
| 	if (col > term.col) { | ||||
| 		bp = term.tabs + term.col; | ||||
| 	if (col > term.maxcol) { | ||||
| 		bp = term.tabs + term.maxcol; | ||||
| 
 | ||||
| 		memset(bp, 0, sizeof(*term.tabs) * (col - term.col)); | ||||
| 		memset(bp, 0, sizeof(*term.tabs) * (col - term.maxcol)); | ||||
| 		while (--bp > term.tabs && !*bp) | ||||
| 			/* nothing */ ; | ||||
| 		for (bp += tabspaces; bp < term.tabs + col; bp += tabspaces) | ||||
| 			*bp = 1; | ||||
| 	} | ||||
| 	/* update terminal size */ | ||||
| 	term.col = col; | ||||
| 	term.col = tmp; | ||||
| 	term.maxcol = col; | ||||
| 	term.row = row; | ||||
| 	/* reset scrolling region */ | ||||
| 	tsetscroll(0, row-1); | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Luke Smith
						Luke Smith