Xinqi Bao's Git
projects
/
st.git
/ commitdiff
summary
|
log
|
commit
|
diff
|
tree
raw
|
patch
|
inline
| side by side (from parent 1:
6de1ba6
)
handle dim/bright colors.
author
Aurélien Aptel <
[email protected]
>
Wed, 15 Feb 2012 18:10:31 +0000
(19:10 +0100)
committer
Aurélien Aptel <
[email protected]
>
Wed, 15 Feb 2012 18:10:31 +0000
(19:10 +0100)
st.c
patch
|
blob
|
history
diff --git
a/st.c
b/st.c
index
fca97ce
..
627e566
100644
(file)
--- a/
st.c
+++ b/
st.c
@@
-1341,14
+1341,8
@@
csihandle(void) {
void
csidump(void) {
void
csidump(void) {
- int i;
- printf("ESC [ %s", escseq.priv ? "? " : "");
- if(escseq.narg)
- for(i = 0; i < escseq.narg; i++)
- printf("%d ", escseq.arg[i]);
- if(escseq.mode)
- putchar(escseq.mode);
- putchar('\n');
+ fwrite("\033[", 1, 2, stdout);
+ fwrite(escseq.buf, 1, escseq.len, stdout);
}
void
}
void
@@
-1761,23
+1755,29
@@
xinit(void) {
void
xdraws(char *s, Glyph base, int x, int y, int charlen, int bytelen) {
void
xdraws(char *s, Glyph base, int x, int y, int charlen, int bytelen) {
-
ulong xfg = dc.col[base.fg], xbg = dc.col[base.bg]
, temp;
+
int fg = base.fg, bg = base.bg
, temp;
int winx = x*xw.cw, winy = y*xw.ch + dc.font.ascent, width = charlen*xw.cw;
int winx = x*xw.cw, winy = y*xw.ch + dc.font.ascent, width = charlen*xw.cw;
+ XFontSet fontset = dc.font.set;
int i;
/* only switch default fg/bg if term is in RV mode */
if(IS_SET(MODE_REVERSE)) {
int i;
/* only switch default fg/bg if term is in RV mode */
if(IS_SET(MODE_REVERSE)) {
- if(
base.
fg == DefaultFG)
-
xfg = dc.col[DefaultBG]
;
- if(b
ase.b
g == DefaultBG)
-
xbg = dc.col[DefaultFG]
;
+ if(fg == DefaultFG)
+
fg = DefaultBG
;
+ if(bg == DefaultBG)
+
bg = DefaultFG
;
}
if(base.mode & ATTR_REVERSE)
}
if(base.mode & ATTR_REVERSE)
- temp = xfg, xfg = xbg, xbg = temp;
+ temp = fg, fg = bg, bg = temp;
+
+ if(base.mode & ATTR_BOLD) {
+ fg += 8;
+ fontset = dc.bfont.set;
+ }
- XSetBackground(xw.dpy, dc.gc,
xbg
);
- XSetForeground(xw.dpy, dc.gc,
xfg
);
+ XSetBackground(xw.dpy, dc.gc,
dc.col[bg]
);
+ XSetForeground(xw.dpy, dc.gc,
dc.col[fg]
);
if(base.mode & ATTR_GFX) {
for(i = 0; i < bytelen; i++) {
if(base.mode & ATTR_GFX) {
for(i = 0; i < bytelen; i++) {
@@
-1789,8
+1789,7
@@
xdraws(char *s, Glyph base, int x, int y, int charlen, int bytelen) {
}
}
}
}
- XmbDrawImageString(xw.dpy, xw.buf, base.mode & ATTR_BOLD ? dc.bfont.set : dc.font.set,
- dc.gc, winx, winy, s, bytelen);
+ XmbDrawImageString(xw.dpy, xw.buf, fontset, dc.gc, winx, winy, s, bytelen);
if(base.mode & ATTR_UNDERLINE)
XDrawLine(xw.dpy, xw.buf, dc.gc, winx, winy+1, winx+width-1, winy+1);
if(base.mode & ATTR_UNDERLINE)
XDrawLine(xw.dpy, xw.buf, dc.gc, winx, winy+1, winx+width-1, winy+1);