Add the possibility to have default highlight colors.
Thanks to stargrave@stargrave.org for the suggestion!
This commit is contained in:
		@@ -62,6 +62,14 @@ static unsigned int defaultbg = 0;
 | 
			
		||||
static unsigned int defaultcs = 256;
 | 
			
		||||
static unsigned int defaultucs = 257;
 | 
			
		||||
 | 
			
		||||
/*
 | 
			
		||||
 * Colors used, when the specific fg == defaultfg. So in reverse mode this
 | 
			
		||||
 * will reverse too. Another logic would only make the simple feature too
 | 
			
		||||
 * complex.
 | 
			
		||||
 */
 | 
			
		||||
static unsigned int defaultitalic = 11;
 | 
			
		||||
static unsigned int defaultunderline = 7;
 | 
			
		||||
 | 
			
		||||
/* Internal shortcuts. */
 | 
			
		||||
#define MODKEY Mod1Mask
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										32
									
								
								st.c
									
									
									
									
									
								
							
							
						
						
									
										32
									
								
								st.c
									
									
									
									
									
								
							@@ -2711,12 +2711,28 @@ xdraws(char *s, Glyph base, int x, int y, int charlen, int bytelen) {
 | 
			
		||||
	FcPattern *fcpattern, *fontpattern;
 | 
			
		||||
	FcFontSet *fcsets[] = { NULL };
 | 
			
		||||
	FcCharSet *fccharset;
 | 
			
		||||
	Colour *fg = &dc.col[base.fg], *bg = &dc.col[base.bg],
 | 
			
		||||
		 *temp, revfg, revbg;
 | 
			
		||||
	Colour *fg, *bg, *temp, revfg, revbg;
 | 
			
		||||
	XRenderColor colfg, colbg;
 | 
			
		||||
 | 
			
		||||
	frcflags = FRC_NORMAL;
 | 
			
		||||
 | 
			
		||||
	if(base.mode & ATTR_ITALIC) {
 | 
			
		||||
		if(base.fg == defaultfg)
 | 
			
		||||
			base.fg = defaultitalic;
 | 
			
		||||
		font = &dc.ifont;
 | 
			
		||||
		frcflags = FRC_ITALIC;
 | 
			
		||||
	} else if((base.mode & ATTR_ITALIC) && (base.mode & ATTR_BOLD)) {
 | 
			
		||||
		if(base.fg == defaultfg)
 | 
			
		||||
			base.fg = defaultitalic;
 | 
			
		||||
		font = &dc.ibfont;
 | 
			
		||||
		frcflags = FRC_ITALICBOLD;
 | 
			
		||||
	} else if(base.mode & ATTR_UNDERLINE) {
 | 
			
		||||
		if(base.fg == defaultfg)
 | 
			
		||||
			base.fg = defaultunderline;
 | 
			
		||||
	}
 | 
			
		||||
	fg = &dc.col[base.fg];
 | 
			
		||||
	bg = &dc.col[base.bg];
 | 
			
		||||
 | 
			
		||||
	if(base.mode & ATTR_BOLD) {
 | 
			
		||||
		if(BETWEEN(base.fg, 0, 7)) {
 | 
			
		||||
			/* basic system colors */
 | 
			
		||||
@@ -2738,15 +2754,6 @@ xdraws(char *s, Glyph base, int x, int y, int charlen, int bytelen) {
 | 
			
		||||
		frcflags = FRC_BOLD;
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	if(base.mode & ATTR_ITALIC) {
 | 
			
		||||
		font = &dc.ifont;
 | 
			
		||||
		frcflags = FRC_ITALIC;
 | 
			
		||||
	}
 | 
			
		||||
	if((base.mode & ATTR_ITALIC) && (base.mode & ATTR_BOLD)) {
 | 
			
		||||
		font = &dc.ibfont;
 | 
			
		||||
		frcflags = FRC_ITALICBOLD;
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	if(IS_SET(MODE_REVERSE)) {
 | 
			
		||||
		if(fg == &dc.col[defaultfg]) {
 | 
			
		||||
			fg = &dc.col[defaultbg];
 | 
			
		||||
@@ -2873,8 +2880,7 @@ xdraws(char *s, Glyph base, int x, int y, int charlen, int bytelen) {
 | 
			
		||||
					FcTrue, fcpattern, &fcres);
 | 
			
		||||
 | 
			
		||||
			/*
 | 
			
		||||
			 * Overwrite or create the new cache entry
 | 
			
		||||
			 * entry.
 | 
			
		||||
			 * Overwrite or create the new cache entry.
 | 
			
		||||
			 */
 | 
			
		||||
			frccur++;
 | 
			
		||||
			frclen++;
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user