merged tcursorwrap() with tnewline(), added few comments and updated copyright.
This commit is contained in:
		
							
								
								
									
										25
									
								
								st.c
									
									
									
									
									
								
							
							
						
						
									
										25
									
								
								st.c
									
									
									
									
									
								
							@@ -129,7 +129,6 @@ static void csireset(void);
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
static void tclearregion(int, int, int, int);
 | 
					static void tclearregion(int, int, int, int);
 | 
				
			||||||
static void tcursor(int);
 | 
					static void tcursor(int);
 | 
				
			||||||
static void twrapcursor(void);
 | 
					 | 
				
			||||||
static void tdeletechar(int);
 | 
					static void tdeletechar(int);
 | 
				
			||||||
static void tdeleteline(int);
 | 
					static void tdeleteline(int);
 | 
				
			||||||
static void tinsertblank(int);
 | 
					static void tinsertblank(int);
 | 
				
			||||||
@@ -337,7 +336,8 @@ treset(void) {
 | 
				
			|||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void
 | 
					void
 | 
				
			||||||
tnew(int col, int row) {   /* screen size */
 | 
					tnew(int col, int row) {
 | 
				
			||||||
 | 
						/* screen size */
 | 
				
			||||||
	term.row = row, term.col = col;
 | 
						term.row = row, term.col = col;
 | 
				
			||||||
	term.top = 0, term.bot = term.row - 1;
 | 
						term.top = 0, term.bot = term.row - 1;
 | 
				
			||||||
	/* mode */
 | 
						/* mode */
 | 
				
			||||||
@@ -437,16 +437,6 @@ tmoveto(int x, int y) {
 | 
				
			|||||||
	term.c.y = y < 0 ? 0 : y >= term.row ? term.row-1 : y;
 | 
						term.c.y = y < 0 ? 0 : y >= term.row ? term.row-1 : y;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void
 | 
					 | 
				
			||||||
twrapcursor(void) {
 | 
					 | 
				
			||||||
	int y = term.c.y+1;
 | 
					 | 
				
			||||||
	if(y > term.bot) {
 | 
					 | 
				
			||||||
		tmoveto(0, term.bot);
 | 
					 | 
				
			||||||
		tscroll();
 | 
					 | 
				
			||||||
	} else 
 | 
					 | 
				
			||||||
		tmoveto(0, y);
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
	
 | 
					 | 
				
			||||||
void
 | 
					void
 | 
				
			||||||
tsetchar(char c) {
 | 
					tsetchar(char c) {
 | 
				
			||||||
	term.line[term.c.y][term.c.x] = term.c.attr;
 | 
						term.line[term.c.y][term.c.x] = term.c.attr;
 | 
				
			||||||
@@ -974,7 +964,7 @@ tputc(char c) {
 | 
				
			|||||||
			if(term.c.x+1 < term.col) {
 | 
								if(term.c.x+1 < term.col) {
 | 
				
			||||||
				tmoveto(term.c.x+1, term.c.y);
 | 
									tmoveto(term.c.x+1, term.c.y);
 | 
				
			||||||
			} else if(IS_SET(MODE_WRAP))
 | 
								} else if(IS_SET(MODE_WRAP))
 | 
				
			||||||
				twrapcursor();
 | 
									tnewline();
 | 
				
			||||||
			break;
 | 
								break;
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
@@ -995,13 +985,20 @@ tresize(int col, int row) {
 | 
				
			|||||||
	if(col < 1 || row < 1)
 | 
						if(col < 1 || row < 1)
 | 
				
			||||||
		return;
 | 
							return;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						/* free uneeded rows */
 | 
				
			||||||
	for(i = row; i < term.row; i++)
 | 
						for(i = row; i < term.row; i++)
 | 
				
			||||||
		free(term.line[i]);
 | 
							free(term.line[i]);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						/* resize to new height */
 | 
				
			||||||
	term.line = realloc(term.line, row * sizeof(Line));
 | 
						term.line = realloc(term.line, row * sizeof(Line));
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						/* resize each row to new width, zero-pad if needed */
 | 
				
			||||||
	for(i = 0; i < minrow; i++) {
 | 
						for(i = 0; i < minrow; i++) {
 | 
				
			||||||
		term.line[i] = realloc(term.line[i], col * sizeof(Glyph));
 | 
							term.line[i] = realloc(term.line[i], col * sizeof(Glyph));
 | 
				
			||||||
		memset(term.line[i] + mincol, 0, (col - mincol) * sizeof(Glyph));
 | 
							memset(term.line[i] + mincol, 0, (col - mincol) * sizeof(Glyph));
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						/* allocate any new rows */
 | 
				
			||||||
	for(/* i == minrow */; i < row; i++)
 | 
						for(/* i == minrow */; i < row; i++)
 | 
				
			||||||
		term.line[i] = calloc(col, sizeof(Glyph));
 | 
							term.line[i] = calloc(col, sizeof(Glyph));
 | 
				
			||||||
	
 | 
						
 | 
				
			||||||
@@ -1337,7 +1334,7 @@ run(void) {
 | 
				
			|||||||
int
 | 
					int
 | 
				
			||||||
main(int argc, char *argv[]) {
 | 
					main(int argc, char *argv[]) {
 | 
				
			||||||
	if(argc == 2 && !strncmp("-v", argv[1], 3))
 | 
						if(argc == 2 && !strncmp("-v", argv[1], 3))
 | 
				
			||||||
		die("st-" VERSION ", © 2009 st engineers\n");
 | 
							die("st-" VERSION ", (c) 2010 st engineers\n");
 | 
				
			||||||
	else if(argc != 1)
 | 
						else if(argc != 1)
 | 
				
			||||||
		die("usage: st [-v]\n");
 | 
							die("usage: st [-v]\n");
 | 
				
			||||||
	setlocale(LC_CTYPE, "");
 | 
						setlocale(LC_CTYPE, "");
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user