Remove ATTR_GFX and tselcs
ATTR_GFX was used long time ago to detect when terminal was in graphic mode. Today graphic mode is implemented using a charset pointer, so ATTR_GFX is not needed anymore because graphic condition can be detected directly checking if current charset is GRAPHICS C0.
This commit is contained in:
		
							
								
								
									
										30
									
								
								st.c
									
									
									
									
									
								
							
							
						
						
									
										30
									
								
								st.c
									
									
									
									
									
								
							| @@ -94,12 +94,11 @@ enum glyph_attribute { | |||||||
| 	ATTR_REVERSE   = 1, | 	ATTR_REVERSE   = 1, | ||||||
| 	ATTR_UNDERLINE = 2, | 	ATTR_UNDERLINE = 2, | ||||||
| 	ATTR_BOLD      = 4, | 	ATTR_BOLD      = 4, | ||||||
| 	ATTR_GFX       = 8, | 	ATTR_ITALIC    = 8, | ||||||
| 	ATTR_ITALIC    = 16, | 	ATTR_BLINK     = 16, | ||||||
| 	ATTR_BLINK     = 32, | 	ATTR_WRAP      = 32, | ||||||
| 	ATTR_WRAP      = 64, | 	ATTR_WIDE      = 64, | ||||||
| 	ATTR_WIDE      = 128, | 	ATTR_WDUMMY    = 128, | ||||||
| 	ATTR_WDUMMY    = 256, |  | ||||||
| }; | }; | ||||||
|  |  | ||||||
| enum cursor_movement { | enum cursor_movement { | ||||||
| @@ -396,7 +395,6 @@ static void techo(char *, int); | |||||||
| static bool tcontrolcode(uchar ); | static bool tcontrolcode(uchar ); | ||||||
| static void tdectest(char ); | static void tdectest(char ); | ||||||
| static int32_t tdefcolor(int *, int *, int); | static int32_t tdefcolor(int *, int *, int); | ||||||
| static void tselcs(void); |  | ||||||
| static void tdeftran(char); | static void tdeftran(char); | ||||||
| static inline bool match(uint, uint); | static inline bool match(uint, uint); | ||||||
| static void ttynew(void); | static void ttynew(void); | ||||||
| @@ -1535,7 +1533,7 @@ tsetchar(char *c, Glyph *attr, int x, int y) { | |||||||
| 	/* | 	/* | ||||||
| 	 * The table is proudly stolen from rxvt. | 	 * The table is proudly stolen from rxvt. | ||||||
| 	 */ | 	 */ | ||||||
| 	if(attr->mode & ATTR_GFX) { | 	if(term.trantbl[term.charset] == CS_GRAPHIC0) { | ||||||
| 		if(BETWEEN(c[0], 0x41, 0x7e) && vt100_0[c[0] - 0x41]) { | 		if(BETWEEN(c[0], 0x41, 0x7e) && vt100_0[c[0] - 0x41]) { | ||||||
| 			c = vt100_0[c[0] - 0x41]; | 			c = vt100_0[c[0] - 0x41]; | ||||||
| 		} | 		} | ||||||
| @@ -2317,9 +2315,7 @@ void | |||||||
| tdeftran(char ascii) { | tdeftran(char ascii) { | ||||||
| 	char c, (*bp)[2]; | 	char c, (*bp)[2]; | ||||||
| 	static char tbl[][2] = { | 	static char tbl[][2] = { | ||||||
| 		{'0', CS_GRAPHIC0}, {'1', CS_GRAPHIC1}, {'A', CS_UK}, | 		{'0', CS_GRAPHIC0}, {'B', CS_USA}, | ||||||
| 		{'B', CS_USA},      {'<', CS_MULTI},    {'K', CS_GER}, |  | ||||||
| 		{'5', CS_FIN},      {'C', CS_FIN}, |  | ||||||
| 		{0, 0} | 		{0, 0} | ||||||
| 	}; | 	}; | ||||||
|  |  | ||||||
| @@ -2332,13 +2328,6 @@ tdeftran(char ascii) { | |||||||
| 		term.trantbl[term.icharset] = (*bp)[1]; | 		term.trantbl[term.icharset] = (*bp)[1]; | ||||||
| } | } | ||||||
|  |  | ||||||
| void |  | ||||||
| tselcs(void) { |  | ||||||
| 	MODBIT(term.c.attr.mode, |  | ||||||
| 	       term.trantbl[term.charset] == CS_GRAPHIC0, |  | ||||||
| 	       ATTR_GFX); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| bool | bool | ||||||
| tcontrolcode(uchar ascii) { | tcontrolcode(uchar ascii) { | ||||||
| 	static char question[UTF_SIZ] = "?"; | 	static char question[UTF_SIZ] = "?"; | ||||||
| @@ -2377,11 +2366,9 @@ tcontrolcode(uchar ascii) { | |||||||
| 		return 1; | 		return 1; | ||||||
| 	case '\016': /* SO */ | 	case '\016': /* SO */ | ||||||
| 		term.charset = 0; | 		term.charset = 0; | ||||||
| 		tselcs(); |  | ||||||
| 		break; | 		break; | ||||||
| 	case '\017': /* SI */ | 	case '\017': /* SI */ | ||||||
| 		term.charset = 1; | 		term.charset = 1; | ||||||
| 		tselcs(); |  | ||||||
| 		break; | 		break; | ||||||
| 	case '\032': /* SUB */ | 	case '\032': /* SUB */ | ||||||
| 		tsetchar(question, &term.c.attr, term.c.x, term.c.y); | 		tsetchar(question, &term.c.attr, term.c.x, term.c.y); | ||||||
| @@ -2506,7 +2493,6 @@ tputc(char *c, int len) { | |||||||
| 			return; | 			return; | ||||||
| 		} else if(term.esc & ESC_ALTCHARSET) { | 		} else if(term.esc & ESC_ALTCHARSET) { | ||||||
| 			tdeftran(ascii); | 			tdeftran(ascii); | ||||||
| 			tselcs(); |  | ||||||
| 		} else if(term.esc & ESC_TEST) { | 		} else if(term.esc & ESC_TEST) { | ||||||
| 			tdectest(ascii); | 			tdectest(ascii); | ||||||
| 		} else { | 		} else { | ||||||
| @@ -2593,7 +2579,7 @@ tputc(char *c, int len) { | |||||||
| 	/* | 	/* | ||||||
| 	 * Display control codes only if we are in graphic mode | 	 * Display control codes only if we are in graphic mode | ||||||
| 	 */ | 	 */ | ||||||
| 	if(control && !(term.c.attr.mode & ATTR_GFX)) | 	if(control && term.trantbl[term.charset] != CS_GRAPHIC0) | ||||||
| 		return; | 		return; | ||||||
| 	if(sel.ob.x != -1 && BETWEEN(term.c.y, sel.ob.y, sel.oe.y)) | 	if(sel.ob.x != -1 && BETWEEN(term.c.y, sel.ob.y, sel.oe.y)) | ||||||
| 		selclear(NULL); | 		selclear(NULL); | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user