added LNM mode; re-organized kpress() to handle it.
This commit is contained in:
		
							parent
							
								
									ce27e63491
								
							
						
					
					
						commit
						6f87a39444
					
				
							
								
								
									
										47
									
								
								st.c
									
									
									
									
									
								
							
							
						
						
									
										47
									
								
								st.c
									
									
									
									
									
								
							| @ -55,7 +55,8 @@ enum { CURSOR_UP, CURSOR_DOWN, CURSOR_LEFT, CURSOR_RIGHT, | |||||||
|        CURSOR_SAVE, CURSOR_LOAD }; |        CURSOR_SAVE, CURSOR_LOAD }; | ||||||
| enum { CURSOR_DEFAULT = 0, CURSOR_HIDE = 1, CURSOR_WRAPNEXT = 2 }; | enum { CURSOR_DEFAULT = 0, CURSOR_HIDE = 1, CURSOR_WRAPNEXT = 2 }; | ||||||
| enum { GLYPH_SET=1, GLYPH_DIRTY=2 }; | enum { GLYPH_SET=1, GLYPH_DIRTY=2 }; | ||||||
| enum { MODE_WRAP=1, MODE_INSERT=2, MODE_APPKEYPAD=4, MODE_ALTSCREEN=8 }; | enum { MODE_WRAP=1, MODE_INSERT=2, MODE_APPKEYPAD=4, MODE_ALTSCREEN=8,  | ||||||
|  |        MODE_CRLF=16 }; | ||||||
| enum { ESC_START=1, ESC_CSI=2, ESC_OSC=4, ESC_TITLE=8, ESC_ALTCHARSET=16 }; | enum { ESC_START=1, ESC_CSI=2, ESC_OSC=4, ESC_TITLE=8, ESC_ALTCHARSET=16 }; | ||||||
| enum { SCREEN_UPDATE, SCREEN_REDRAW }; | enum { SCREEN_UPDATE, SCREEN_REDRAW }; | ||||||
| enum { WIN_VISIBLE=1, WIN_REDRAW=2, WIN_FOCUSED=4 }; | enum { WIN_VISIBLE=1, WIN_REDRAW=2, WIN_FOCUSED=4 }; | ||||||
| @ -164,7 +165,7 @@ static void tinsertblank(int); | |||||||
| static void tinsertblankline(int); | static void tinsertblankline(int); | ||||||
| static void tmoveto(int, int); | static void tmoveto(int, int); | ||||||
| static void tnew(int, int); | static void tnew(int, int); | ||||||
| static void tnewline(void); | static void tnewline(int); | ||||||
| static void tputtab(void); | static void tputtab(void); | ||||||
| static void tputc(char); | static void tputc(char); | ||||||
| static void tputs(char*, int); | static void tputs(char*, int); | ||||||
| @ -626,14 +627,13 @@ tscrollup(int orig, int n) { | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void | void | ||||||
| tnewline(void) { | tnewline(int first_col) { | ||||||
| 	int x = term.c.x+1 < term.col ? term.c.x : 0; |  | ||||||
| 	int y = term.c.y; | 	int y = term.c.y; | ||||||
| 	if(term.c.y == term.bot) | 	if(y == term.bot) | ||||||
| 		tscrollup(term.top, 1); | 		tscrollup(term.top, 1); | ||||||
| 	else | 	else | ||||||
| 		y++; | 		y++; | ||||||
| 	tmoveto(x, y); | 	tmoveto(first_col ? 0 : term.c.x, y); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void | void | ||||||
| @ -932,6 +932,9 @@ csihandle(void) { | |||||||
| 				break; | 				break; | ||||||
| 			case 12: /* att610 -- Stop blinking cursor (IGNORED) */ | 			case 12: /* att610 -- Stop blinking cursor (IGNORED) */ | ||||||
| 				break; | 				break; | ||||||
|  | 			case 20: | ||||||
|  | 				term.mode &= ~MODE_CRLF; | ||||||
|  | 				break; | ||||||
| 			case 25: | 			case 25: | ||||||
| 				term.c.state |= CURSOR_HIDE; | 				term.c.state |= CURSOR_HIDE; | ||||||
| 				break; | 				break; | ||||||
| @ -988,6 +991,9 @@ csihandle(void) { | |||||||
| 			case 7: | 			case 7: | ||||||
| 				term.mode |= MODE_WRAP; | 				term.mode |= MODE_WRAP; | ||||||
| 				break; | 				break; | ||||||
|  | 			case 20: | ||||||
|  | 				term.mode |= MODE_CRLF; | ||||||
|  | 				break; | ||||||
| 			case 12: /* att610 -- Start blinking cursor (IGNORED) */ | 			case 12: /* att610 -- Start blinking cursor (IGNORED) */ | ||||||
| 				 /* fallthrough for xterm cvvis = CSI [ ? 12 ; 25 h */ | 				 /* fallthrough for xterm cvvis = CSI [ ? 12 ; 25 h */ | ||||||
| 				if(escseq.narg > 1 && escseq.arg[1] != 25) | 				if(escseq.narg > 1 && escseq.arg[1] != 25) | ||||||
| @ -1116,7 +1122,7 @@ tputc(char c) { | |||||||
| 				term.esc = 0; | 				term.esc = 0; | ||||||
| 				break; | 				break; | ||||||
| 			case 'E': /* NEL -- Next line */ | 			case 'E': /* NEL -- Next line */ | ||||||
| 				tnewline(); | 				tnewline(1); /* always go to first col */ | ||||||
| 				term.esc = 0; | 				term.esc = 0; | ||||||
| 				break; | 				break; | ||||||
| 			case 'M': /* RI -- Reverse index */ | 			case 'M': /* RI -- Reverse index */ | ||||||
| @ -1163,7 +1169,8 @@ tputc(char c) { | |||||||
| 			tmoveto(0, term.c.y); | 			tmoveto(0, term.c.y); | ||||||
| 			break; | 			break; | ||||||
| 		case '\n': | 		case '\n': | ||||||
| 			tnewline(); | 			/* go to first col if the mode is set */ | ||||||
|  | 			tnewline(IS_SET(MODE_CRLF)); | ||||||
| 			break; | 			break; | ||||||
| 		case '\a': | 		case '\a': | ||||||
| 			if(!(xw.state & WIN_FOCUSED)) | 			if(!(xw.state & WIN_FOCUSED)) | ||||||
| @ -1175,7 +1182,7 @@ tputc(char c) { | |||||||
| 			break; | 			break; | ||||||
| 		default: | 		default: | ||||||
| 			if(IS_SET(MODE_WRAP) && term.c.state & CURSOR_WRAPNEXT) | 			if(IS_SET(MODE_WRAP) && term.c.state & CURSOR_WRAPNEXT) | ||||||
| 				tnewline(); | 				tnewline(1); /* always go to first col */ | ||||||
| 			tsetchar(c); | 			tsetchar(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); | ||||||
| @ -1561,14 +1568,11 @@ kpress(XEvent *ev) { | |||||||
| 	shift = e->state & ShiftMask; | 	shift = e->state & ShiftMask; | ||||||
| 	len = XmbLookupString(xw.xic, e, buf, sizeof(buf), &ksym, &status); | 	len = XmbLookupString(xw.xic, e, buf, sizeof(buf), &ksym, &status); | ||||||
| 	 | 	 | ||||||
|  | 	/* 1. custom keys from config.h */ | ||||||
| 	if((customkey = kmap(ksym))) | 	if((customkey = kmap(ksym))) | ||||||
| 		ttywrite(customkey, strlen(customkey)); | 		ttywrite(customkey, strlen(customkey)); | ||||||
| 	else if(len > 0) { | 	/* 2. hardcoded (overrides X lookup) */ | ||||||
| 		buf[sizeof(buf)-1] = '\0'; | 	else | ||||||
| 		if(meta && len == 1) |  | ||||||
| 			ttywrite("\033", 1); |  | ||||||
| 		ttywrite(buf, len); |  | ||||||
| 	} else |  | ||||||
| 		switch(ksym) { | 		switch(ksym) { | ||||||
| 		case XK_Up: | 		case XK_Up: | ||||||
| 		case XK_Down: | 		case XK_Down: | ||||||
| @ -1581,7 +1585,20 @@ kpress(XEvent *ev) { | |||||||
| 			if(shift) | 			if(shift) | ||||||
| 				selpaste(); | 				selpaste(); | ||||||
| 			break; | 			break; | ||||||
|  | 		case XK_Return: | ||||||
|  | 			if(IS_SET(MODE_CRLF)) | ||||||
|  | 				ttywrite("\r\n", 2); | ||||||
|  | 			else | ||||||
|  | 				ttywrite("\r", 1); | ||||||
|  | 			break; | ||||||
|  | 			/* 3. X lookup  */ | ||||||
| 		default: | 		default: | ||||||
|  | 			if(len > 0) { | ||||||
|  | 				buf[sizeof(buf)-1] = '\0'; | ||||||
|  | 				if(meta && len == 1) | ||||||
|  | 					ttywrite("\033", 1); | ||||||
|  | 				ttywrite(buf, len); | ||||||
|  | 			} else /* 4. nothing to send */ | ||||||
| 				fprintf(stderr, "errkey: %d\n", (int)ksym); | 				fprintf(stderr, "errkey: %d\n", (int)ksym); | ||||||
| 			break; | 			break; | ||||||
| 		} | 		} | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user