|
|
@ -76,6 +76,7 @@ enum glyph_attribute {
|
|
|
|
ATTR_UNDERLINE = 2,
|
|
|
|
ATTR_UNDERLINE = 2,
|
|
|
|
ATTR_BOLD = 4,
|
|
|
|
ATTR_BOLD = 4,
|
|
|
|
ATTR_GFX = 8,
|
|
|
|
ATTR_GFX = 8,
|
|
|
|
|
|
|
|
ATTR_ITALIC = 16,
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
enum cursor_movement {
|
|
|
|
enum cursor_movement {
|
|
|
@ -238,7 +239,7 @@ typedef struct {
|
|
|
|
short lbearing;
|
|
|
|
short lbearing;
|
|
|
|
short rbearing;
|
|
|
|
short rbearing;
|
|
|
|
XFontSet set;
|
|
|
|
XFontSet set;
|
|
|
|
} font, bfont;
|
|
|
|
} font, bfont, ifont;
|
|
|
|
} DC;
|
|
|
|
} DC;
|
|
|
|
|
|
|
|
|
|
|
|
static void die(const char*, ...);
|
|
|
|
static void die(const char*, ...);
|
|
|
@ -1122,8 +1123,8 @@ tsetattr(int *attr, int l) {
|
|
|
|
case 1:
|
|
|
|
case 1:
|
|
|
|
term.c.attr.mode |= ATTR_BOLD;
|
|
|
|
term.c.attr.mode |= ATTR_BOLD;
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
case 3: /* enter standout (highlight) mode TODO: make it italic */
|
|
|
|
case 3: /* enter standout (highlight) */
|
|
|
|
term.c.attr.mode |= ATTR_REVERSE;
|
|
|
|
term.c.attr.mode |= ATTR_ITALIC;
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
case 4:
|
|
|
|
case 4:
|
|
|
|
term.c.attr.mode |= ATTR_UNDERLINE;
|
|
|
|
term.c.attr.mode |= ATTR_UNDERLINE;
|
|
|
@ -1134,8 +1135,8 @@ tsetattr(int *attr, int l) {
|
|
|
|
case 22:
|
|
|
|
case 22:
|
|
|
|
term.c.attr.mode &= ~ATTR_BOLD;
|
|
|
|
term.c.attr.mode &= ~ATTR_BOLD;
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
case 23: /* leave standout (highlight) mode TODO: make it italic */
|
|
|
|
case 23: /* leave standout (highlight) mode */
|
|
|
|
term.c.attr.mode &= ~ATTR_REVERSE;
|
|
|
|
term.c.attr.mode &= ~ATTR_ITALIC;
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
case 24:
|
|
|
|
case 24:
|
|
|
|
term.c.attr.mode &= ~ATTR_UNDERLINE;
|
|
|
|
term.c.attr.mode &= ~ATTR_UNDERLINE;
|
|
|
@ -1886,14 +1887,20 @@ xgetfontinfo(XFontSet set, int *ascent, int *descent, short *lbearing, short *rb
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void
|
|
|
|
void
|
|
|
|
initfonts(char *fontstr, char *bfontstr) {
|
|
|
|
initfonts(char *fontstr, char *bfontstr, char *ifontstr) {
|
|
|
|
if((dc.font.set = xinitfont(fontstr)) == NULL ||
|
|
|
|
if((dc.font.set = xinitfont(fontstr)) == NULL)
|
|
|
|
(dc.bfont.set = xinitfont(bfontstr)) == NULL)
|
|
|
|
die("Can't load font %s\n", fontstr);
|
|
|
|
die("Can't load font %s\n", dc.font.set ? BOLDFONT : FONT);
|
|
|
|
if((dc.bfont.set = xinitfont(bfontstr)) == NULL)
|
|
|
|
|
|
|
|
die("Can't load bfont %s\n", bfontstr);
|
|
|
|
|
|
|
|
if((dc.ifont.set = xinitfont(ifontstr)) == NULL)
|
|
|
|
|
|
|
|
die("Can't load ifont %s\n", ifontstr);
|
|
|
|
|
|
|
|
|
|
|
|
xgetfontinfo(dc.font.set, &dc.font.ascent, &dc.font.descent,
|
|
|
|
xgetfontinfo(dc.font.set, &dc.font.ascent, &dc.font.descent,
|
|
|
|
&dc.font.lbearing, &dc.font.rbearing);
|
|
|
|
&dc.font.lbearing, &dc.font.rbearing);
|
|
|
|
xgetfontinfo(dc.bfont.set, &dc.bfont.ascent, &dc.bfont.descent,
|
|
|
|
xgetfontinfo(dc.bfont.set, &dc.bfont.ascent, &dc.bfont.descent,
|
|
|
|
&dc.bfont.lbearing, &dc.bfont.rbearing);
|
|
|
|
&dc.bfont.lbearing, &dc.bfont.rbearing);
|
|
|
|
|
|
|
|
xgetfontinfo(dc.ifont.set, &dc.ifont.ascent, &dc.ifont.descent,
|
|
|
|
|
|
|
|
&dc.ifont.lbearing, &dc.ifont.rbearing);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void
|
|
|
|
void
|
|
|
@ -1927,7 +1934,7 @@ xinit(void) {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/* font */
|
|
|
|
/* font */
|
|
|
|
initfonts(FONT, BOLDFONT);
|
|
|
|
initfonts(FONT, BOLDFONT, ITALICFONT);
|
|
|
|
|
|
|
|
|
|
|
|
/* XXX: Assuming same size for bold font */
|
|
|
|
/* XXX: Assuming same size for bold font */
|
|
|
|
xw.cw = dc.font.rbearing - dc.font.lbearing;
|
|
|
|
xw.cw = dc.font.rbearing - dc.font.lbearing;
|
|
|
@ -2002,6 +2009,9 @@ xdraws(char *s, Glyph base, int x, int y, int charlen, int bytelen) {
|
|
|
|
fontset = dc.bfont.set;
|
|
|
|
fontset = dc.bfont.set;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if(base.mode & ATTR_ITALIC)
|
|
|
|
|
|
|
|
fontset = dc.ifont.set;
|
|
|
|
|
|
|
|
|
|
|
|
XSetBackground(xw.dpy, dc.gc, dc.col[bg]);
|
|
|
|
XSetBackground(xw.dpy, dc.gc, dc.col[bg]);
|
|
|
|
XSetForeground(xw.dpy, dc.gc, dc.col[fg]);
|
|
|
|
XSetForeground(xw.dpy, dc.gc, dc.col[fg]);
|
|
|
|
|
|
|
|
|
|
|
|