@@ -0,0 +1,163 @@ | |||||
diff --git a/config.def.h b/config.def.h | |||||
index 0e01717..e116631 100644 | |||||
--- a/config.def.h | |||||
+++ b/config.def.h | |||||
@@ -82,6 +82,9 @@ char *termname = "st-256color"; | |||||
*/ | |||||
unsigned int tabspaces = 8; | |||||
+/* bg opacity */ | |||||
+float alpha = 0.8; | |||||
+ | |||||
/* Terminal colors (16 first used in escape sequence) */ | |||||
static const char *colorname[] = { | |||||
/* 8 normal colors */ | |||||
@@ -109,6 +112,7 @@ static const char *colorname[] = { | |||||
/* more colors can be added after 255 to use with DefaultXX */ | |||||
"#cccccc", | |||||
"#555555", | |||||
+ "black", | |||||
}; | |||||
@@ -117,7 +121,7 @@ static const char *colorname[] = { | |||||
* foreground, background, cursor, reverse cursor | |||||
*/ | |||||
unsigned int defaultfg = 7; | |||||
-unsigned int defaultbg = 0; | |||||
+unsigned int defaultbg = 258; | |||||
static unsigned int defaultcs = 256; | |||||
static unsigned int defaultrcs = 257; | |||||
diff --git a/config.mk b/config.mk | |||||
index 0cbb002..1d2f0e2 100644 | |||||
--- a/config.mk | |||||
+++ b/config.mk | |||||
@@ -16,7 +16,7 @@ PKG_CONFIG = pkg-config | |||||
INCS = -I$(X11INC) \ | |||||
`$(PKG_CONFIG) --cflags fontconfig` \ | |||||
`$(PKG_CONFIG) --cflags freetype2` | |||||
-LIBS = -L$(X11LIB) -lm -lrt -lX11 -lutil -lXft \ | |||||
+LIBS = -L$(X11LIB) -lm -lrt -lX11 -lutil -lXft -lXrender\ | |||||
`$(PKG_CONFIG) --libs fontconfig` \ | |||||
`$(PKG_CONFIG) --libs freetype2` | |||||
diff --git a/st.h b/st.h | |||||
index 38c61c4..b7634ab 100644 | |||||
--- a/st.h | |||||
+++ b/st.h | |||||
@@ -120,3 +120,4 @@ extern char *termname; | |||||
extern unsigned int tabspaces; | |||||
extern unsigned int defaultfg; | |||||
extern unsigned int defaultbg; | |||||
+extern float alpha; | |||||
diff --git a/x.c b/x.c | |||||
index 0422421..588dec3 100644 | |||||
--- a/x.c | |||||
+++ b/x.c | |||||
@@ -98,6 +98,7 @@ typedef struct { | |||||
XSetWindowAttributes attrs; | |||||
int scr; | |||||
int isfixed; /* is fixed geometry? */ | |||||
+ int depth; /* bit depth */ | |||||
int l, t; /* left and top offset */ | |||||
int gm; /* geometry mask */ | |||||
} XWindow; | |||||
@@ -229,6 +230,7 @@ static char *usedfont = NULL; | |||||
static double usedfontsize = 0; | |||||
static double defaultfontsize = 0; | |||||
+static char *opt_alpha = NULL; | |||||
static char *opt_class = NULL; | |||||
static char **opt_cmd = NULL; | |||||
static char *opt_embed = NULL; | |||||
@@ -688,7 +690,7 @@ xresize(int col, int row) | |||||
XFreePixmap(xw.dpy, xw.buf); | |||||
xw.buf = XCreatePixmap(xw.dpy, xw.win, win.w, win.h, | |||||
- DefaultDepth(xw.dpy, xw.scr)); | |||||
+ xw.depth); | |||||
XftDrawChange(xw.draw, xw.buf); | |||||
xclear(0, 0, win.w, win.h); | |||||
@@ -748,6 +750,13 @@ xloadcols(void) | |||||
else | |||||
die("could not allocate color %d\n", i); | |||||
} | |||||
+ | |||||
+ /* set alpha value of bg color */ | |||||
+ if (opt_alpha) | |||||
+ alpha = strtof(opt_alpha, NULL); | |||||
+ dc.col[defaultbg].color.alpha = (unsigned short)(0xffff * alpha); | |||||
+ dc.col[defaultbg].pixel &= 0x00FFFFFF; | |||||
+ dc.col[defaultbg].pixel |= (unsigned char)(0xff * alpha) << 24; | |||||
loaded = 1; | |||||
} | |||||
@@ -1004,11 +1013,23 @@ xinit(int cols, int rows) | |||||
Window parent; | |||||
pid_t thispid = getpid(); | |||||
XColor xmousefg, xmousebg; | |||||
+ XWindowAttributes attr; | |||||
+ XVisualInfo vis; | |||||
if (!(xw.dpy = XOpenDisplay(NULL))) | |||||
die("can't open display\n"); | |||||
xw.scr = XDefaultScreen(xw.dpy); | |||||
- xw.vis = XDefaultVisual(xw.dpy, xw.scr); | |||||
+ | |||||
+ if (!(opt_embed && (parent = strtol(opt_embed, NULL, 0)))) { | |||||
+ parent = XRootWindow(xw.dpy, xw.scr); | |||||
+ xw.depth = 32; | |||||
+ } else { | |||||
+ XGetWindowAttributes(xw.dpy, parent, &attr); | |||||
+ xw.depth = attr.depth; | |||||
+ } | |||||
+ | |||||
+ XMatchVisualInfo(xw.dpy, xw.scr, xw.depth, TrueColor, &vis); | |||||
+ xw.vis = vis.visual; | |||||
/* font */ | |||||
if (!FcInit()) | |||||
@@ -1018,7 +1039,7 @@ xinit(int cols, int rows) | |||||
xloadfonts(usedfont, 0); | |||||
/* colors */ | |||||
- xw.cmap = XDefaultColormap(xw.dpy, xw.scr); | |||||
+ xw.cmap = XCreateColormap(xw.dpy, parent, xw.vis, None); | |||||
xloadcols(); | |||||
/* adjust fixed window geometry */ | |||||
@@ -1038,19 +1059,15 @@ xinit(int cols, int rows) | |||||
| ButtonMotionMask | ButtonPressMask | ButtonReleaseMask; | |||||
xw.attrs.colormap = xw.cmap; | |||||
- if (!(opt_embed && (parent = strtol(opt_embed, NULL, 0)))) | |||||
- parent = XRootWindow(xw.dpy, xw.scr); | |||||
xw.win = XCreateWindow(xw.dpy, parent, xw.l, xw.t, | |||||
- win.w, win.h, 0, XDefaultDepth(xw.dpy, xw.scr), InputOutput, | |||||
+ win.w, win.h, 0, xw.depth, InputOutput, | |||||
xw.vis, CWBackPixel | CWBorderPixel | CWBitGravity | |||||
| CWEventMask | CWColormap, &xw.attrs); | |||||
memset(&gcvalues, 0, sizeof(gcvalues)); | |||||
gcvalues.graphics_exposures = False; | |||||
- dc.gc = XCreateGC(xw.dpy, parent, GCGraphicsExposures, | |||||
- &gcvalues); | |||||
- xw.buf = XCreatePixmap(xw.dpy, xw.win, win.w, win.h, | |||||
- DefaultDepth(xw.dpy, xw.scr)); | |||||
+ xw.buf = XCreatePixmap(xw.dpy, xw.win, win.w, win.h, xw.depth); | |||||
+ dc.gc = XCreateGC(xw.dpy, xw.buf, GCGraphicsExposures, &gcvalues); | |||||
XSetForeground(xw.dpy, dc.gc, dc.col[defaultbg].pixel); | |||||
XFillRectangle(xw.dpy, xw.buf, dc.gc, 0, 0, win.w, win.h); | |||||
@@ -1894,6 +1911,9 @@ main(int argc, char *argv[]) | |||||
case 'a': | |||||
allowaltscreen = 0; | |||||
break; | |||||
+ case 'A': | |||||
+ opt_alpha = EARGF(usage()); | |||||
+ break; | |||||
case 'c': | |||||
opt_class = EARGF(usage()); | |||||
break; |
@@ -93,6 +93,9 @@ char *termname = "st-256color"; | |||||
*/ | */ | ||||
unsigned int tabspaces = 8; | unsigned int tabspaces = 8; | ||||
/* bg opacity */ | |||||
float alpha = 0.8; | |||||
/* Terminal colors (16 first used in escape sequence) */ | /* Terminal colors (16 first used in escape sequence) */ | ||||
static const char *colorname[] = { | static const char *colorname[] = { | ||||
/* 8 normal colors */ | /* 8 normal colors */ | ||||
@@ -120,6 +123,7 @@ static const char *colorname[] = { | |||||
/* more colors can be added after 255 to use with DefaultXX */ | /* more colors can be added after 255 to use with DefaultXX */ | ||||
"#cccccc", | "#cccccc", | ||||
"#555555", | "#555555", | ||||
"black", | |||||
}; | }; | ||||
@@ -128,7 +132,7 @@ static const char *colorname[] = { | |||||
* foreground, background, cursor, reverse cursor | * foreground, background, cursor, reverse cursor | ||||
*/ | */ | ||||
unsigned int defaultfg = 7; | unsigned int defaultfg = 7; | ||||
unsigned int defaultbg = 0; | |||||
unsigned int defaultbg = 258; | |||||
static unsigned int defaultcs = 256; | static unsigned int defaultcs = 256; | ||||
static unsigned int defaultrcs = 257; | static unsigned int defaultrcs = 257; | ||||
@@ -0,0 +1,472 @@ | |||||
/* See LICENSE file for copyright and license details. */ | |||||
/* | |||||
* appearance | |||||
* | |||||
* font: see http://freedesktop.org/software/fontconfig/fontconfig-user.html | |||||
*/ | |||||
static char *font = "Liberation Mono:pixelsize=12:antialias=true:autohint=true"; | |||||
static int borderpx = 2; | |||||
/* | |||||
* What program is execed by st depends of these precedence rules: | |||||
* 1: program passed with -e | |||||
* 2: scroll and/or utmp | |||||
* 3: SHELL environment variable | |||||
* 4: value of shell in /etc/passwd | |||||
* 5: value of shell in config.h | |||||
*/ | |||||
static char *shell = "/bin/sh"; | |||||
char *utmp = NULL; | |||||
/* scroll program: to enable use a string like "scroll" */ | |||||
char *scroll = NULL; | |||||
char *stty_args = "stty raw pass8 nl -echo -iexten -cstopb 38400"; | |||||
/* identification sequence returned in DA and DECID */ | |||||
char *vtiden = "\033[?6c"; | |||||
/* Kerning / character bounding-box multipliers */ | |||||
static float cwscale = 1.0; | |||||
static float chscale = 1.0; | |||||
/* | |||||
* word delimiter string | |||||
* | |||||
* More advanced example: L" `'\"()[]{}" | |||||
*/ | |||||
wchar_t *worddelimiters = L" "; | |||||
/* selection timeouts (in milliseconds) */ | |||||
static unsigned int doubleclicktimeout = 300; | |||||
static unsigned int tripleclicktimeout = 600; | |||||
/* alt screens */ | |||||
int allowaltscreen = 1; | |||||
/* allow certain non-interactive (insecure) window operations such as: | |||||
setting the clipboard text */ | |||||
int allowwindowops = 0; | |||||
/* | |||||
* draw latency range in ms - from new content/keypress/etc until drawing. | |||||
* within this range, st draws when content stops arriving (idle). mostly it's | |||||
* near minlatency, but it waits longer for slow updates to avoid partial draw. | |||||
* low minlatency will tear/flicker more, as it can "detect" idle too early. | |||||
*/ | |||||
static double minlatency = 8; | |||||
static double maxlatency = 33; | |||||
/* | |||||
* blinking timeout (set to 0 to disable blinking) for the terminal blinking | |||||
* attribute. | |||||
*/ | |||||
static unsigned int blinktimeout = 800; | |||||
/* | |||||
* thickness of underline and bar cursors | |||||
*/ | |||||
static unsigned int cursorthickness = 2; | |||||
/* | |||||
* bell volume. It must be a value between -100 and 100. Use 0 for disabling | |||||
* it | |||||
*/ | |||||
static int bellvolume = 0; | |||||
/* default TERM value */ | |||||
char *termname = "st-256color"; | |||||
/* | |||||
* spaces per tab | |||||
* | |||||
* When you are changing this value, don't forget to adapt the »it« value in | |||||
* the st.info and appropriately install the st.info in the environment where | |||||
* you use this st version. | |||||
* | |||||
* it#$tabspaces, | |||||
* | |||||
* Secondly make sure your kernel is not expanding tabs. When running `stty | |||||
* -a` »tab0« should appear. You can tell the terminal to not expand tabs by | |||||
* running following command: | |||||
* | |||||
* stty tabs | |||||
*/ | |||||
unsigned int tabspaces = 8; | |||||
/* Terminal colors (16 first used in escape sequence) */ | |||||
static const char *colorname[] = { | |||||
/* 8 normal colors */ | |||||
"black", | |||||
"red3", | |||||
"green3", | |||||
"yellow3", | |||||
"blue2", | |||||
"magenta3", | |||||
"cyan3", | |||||
"gray90", | |||||
/* 8 bright colors */ | |||||
"gray50", | |||||
"red", | |||||
"green", | |||||
"yellow", | |||||
"#5c5cff", | |||||
"magenta", | |||||
"cyan", | |||||
"white", | |||||
[255] = 0, | |||||
/* more colors can be added after 255 to use with DefaultXX */ | |||||
"#cccccc", | |||||
"#555555", | |||||
}; | |||||
/* | |||||
* Default colors (colorname index) | |||||
* foreground, background, cursor, reverse cursor | |||||
*/ | |||||
unsigned int defaultfg = 7; | |||||
unsigned int defaultbg = 0; | |||||
static unsigned int defaultcs = 256; | |||||
static unsigned int defaultrcs = 257; | |||||
/* | |||||
* Default shape of cursor | |||||
* 2: Block ("█") | |||||
* 4: Underline ("_") | |||||
* 6: Bar ("|") | |||||
* 7: Snowman ("☃") | |||||
*/ | |||||
static unsigned int cursorshape = 2; | |||||
/* | |||||
* Default columns and rows numbers | |||||
*/ | |||||
static unsigned int cols = 80; | |||||
static unsigned int rows = 24; | |||||
/* | |||||
* Default colour and shape of the mouse cursor | |||||
*/ | |||||
static unsigned int mouseshape = XC_xterm; | |||||
static unsigned int mousefg = 7; | |||||
static unsigned int mousebg = 0; | |||||
/* | |||||
* Color used to display font attributes when fontconfig selected a font which | |||||
* doesn't match the ones requested. | |||||
*/ | |||||
static unsigned int defaultattr = 11; | |||||
/* | |||||
* Force mouse select/shortcuts while mask is active (when MODE_MOUSE is set). | |||||
* Note that if you want to use ShiftMask with selmasks, set this to an other | |||||
* modifier, set to 0 to not use it. | |||||
*/ | |||||
static uint forcemousemod = ShiftMask; | |||||
/* | |||||
* Internal mouse shortcuts. | |||||
* Beware that overloading Button1 will disable the selection. | |||||
*/ | |||||
static MouseShortcut mshortcuts[] = { | |||||
/* mask button function argument release */ | |||||
{ XK_ANY_MOD, Button2, selpaste, {.i = 0}, 1 }, | |||||
{ ShiftMask, Button4, ttysend, {.s = "\033[5;2~"} }, | |||||
{ XK_ANY_MOD, Button4, ttysend, {.s = "\031"} }, | |||||
{ ShiftMask, Button5, ttysend, {.s = "\033[6;2~"} }, | |||||
{ XK_ANY_MOD, Button5, ttysend, {.s = "\005"} }, | |||||
}; | |||||
/* Internal keyboard shortcuts. */ | |||||
#define MODKEY Mod1Mask | |||||
#define TERMMOD (ControlMask|ShiftMask) | |||||
static Shortcut shortcuts[] = { | |||||
/* mask keysym function argument */ | |||||
{ XK_ANY_MOD, XK_Break, sendbreak, {.i = 0} }, | |||||
{ ControlMask, XK_Print, toggleprinter, {.i = 0} }, | |||||
{ ShiftMask, XK_Print, printscreen, {.i = 0} }, | |||||
{ XK_ANY_MOD, XK_Print, printsel, {.i = 0} }, | |||||
{ TERMMOD, XK_Prior, zoom, {.f = +1} }, | |||||
{ TERMMOD, XK_Next, zoom, {.f = -1} }, | |||||
{ TERMMOD, XK_Home, zoomreset, {.f = 0} }, | |||||
{ TERMMOD, XK_C, clipcopy, {.i = 0} }, | |||||
{ TERMMOD, XK_V, clippaste, {.i = 0} }, | |||||
{ TERMMOD, XK_Y, selpaste, {.i = 0} }, | |||||
{ ShiftMask, XK_Insert, selpaste, {.i = 0} }, | |||||
{ TERMMOD, XK_Num_Lock, numlock, {.i = 0} }, | |||||
}; | |||||
/* | |||||
* Special keys (change & recompile st.info accordingly) | |||||
* | |||||
* Mask value: | |||||
* * Use XK_ANY_MOD to match the key no matter modifiers state | |||||
* * Use XK_NO_MOD to match the key alone (no modifiers) | |||||
* appkey value: | |||||
* * 0: no value | |||||
* * > 0: keypad application mode enabled | |||||
* * = 2: term.numlock = 1 | |||||
* * < 0: keypad application mode disabled | |||||
* appcursor value: | |||||
* * 0: no value | |||||
* * > 0: cursor application mode enabled | |||||
* * < 0: cursor application mode disabled | |||||
* | |||||
* Be careful with the order of the definitions because st searches in | |||||
* this table sequentially, so any XK_ANY_MOD must be in the last | |||||
* position for a key. | |||||
*/ | |||||
/* | |||||
* If you want keys other than the X11 function keys (0xFD00 - 0xFFFF) | |||||
* to be mapped below, add them to this array. | |||||
*/ | |||||
static KeySym mappedkeys[] = { -1 }; | |||||
/* | |||||
* State bits to ignore when matching key or button events. By default, | |||||
* numlock (Mod2Mask) and keyboard layout (XK_SWITCH_MOD) are ignored. | |||||
*/ | |||||
static uint ignoremod = Mod2Mask|XK_SWITCH_MOD; | |||||
/* | |||||
* This is the huge key array which defines all compatibility to the Linux | |||||
* world. Please decide about changes wisely. | |||||
*/ | |||||
static Key key[] = { | |||||
/* keysym mask string appkey appcursor */ | |||||
{ XK_KP_Home, ShiftMask, "\033[2J", 0, -1}, | |||||
{ XK_KP_Home, ShiftMask, "\033[1;2H", 0, +1}, | |||||
{ XK_KP_Home, XK_ANY_MOD, "\033[H", 0, -1}, | |||||
{ XK_KP_Home, XK_ANY_MOD, "\033[1~", 0, +1}, | |||||
{ XK_KP_Up, XK_ANY_MOD, "\033Ox", +1, 0}, | |||||
{ XK_KP_Up, XK_ANY_MOD, "\033[A", 0, -1}, | |||||
{ XK_KP_Up, XK_ANY_MOD, "\033OA", 0, +1}, | |||||
{ XK_KP_Down, XK_ANY_MOD, "\033Or", +1, 0}, | |||||
{ XK_KP_Down, XK_ANY_MOD, "\033[B", 0, -1}, | |||||
{ XK_KP_Down, XK_ANY_MOD, "\033OB", 0, +1}, | |||||
{ XK_KP_Left, XK_ANY_MOD, "\033Ot", +1, 0}, | |||||
{ XK_KP_Left, XK_ANY_MOD, "\033[D", 0, -1}, | |||||
{ XK_KP_Left, XK_ANY_MOD, "\033OD", 0, +1}, | |||||
{ XK_KP_Right, XK_ANY_MOD, "\033Ov", +1, 0}, | |||||
{ XK_KP_Right, XK_ANY_MOD, "\033[C", 0, -1}, | |||||
{ XK_KP_Right, XK_ANY_MOD, "\033OC", 0, +1}, | |||||
{ XK_KP_Prior, ShiftMask, "\033[5;2~", 0, 0}, | |||||
{ XK_KP_Prior, XK_ANY_MOD, "\033[5~", 0, 0}, | |||||
{ XK_KP_Begin, XK_ANY_MOD, "\033[E", 0, 0}, | |||||
{ XK_KP_End, ControlMask, "\033[J", -1, 0}, | |||||
{ XK_KP_End, ControlMask, "\033[1;5F", +1, 0}, | |||||
{ XK_KP_End, ShiftMask, "\033[K", -1, 0}, | |||||
{ XK_KP_End, ShiftMask, "\033[1;2F", +1, 0}, | |||||
{ XK_KP_End, XK_ANY_MOD, "\033[4~", 0, 0}, | |||||
{ XK_KP_Next, ShiftMask, "\033[6;2~", 0, 0}, | |||||
{ XK_KP_Next, XK_ANY_MOD, "\033[6~", 0, 0}, | |||||
{ XK_KP_Insert, ShiftMask, "\033[2;2~", +1, 0}, | |||||
{ XK_KP_Insert, ShiftMask, "\033[4l", -1, 0}, | |||||
{ XK_KP_Insert, ControlMask, "\033[L", -1, 0}, | |||||
{ XK_KP_Insert, ControlMask, "\033[2;5~", +1, 0}, | |||||
{ XK_KP_Insert, XK_ANY_MOD, "\033[4h", -1, 0}, | |||||
{ XK_KP_Insert, XK_ANY_MOD, "\033[2~", +1, 0}, | |||||
{ XK_KP_Delete, ControlMask, "\033[M", -1, 0}, | |||||
{ XK_KP_Delete, ControlMask, "\033[3;5~", +1, 0}, | |||||
{ XK_KP_Delete, ShiftMask, "\033[2K", -1, 0}, | |||||
{ XK_KP_Delete, ShiftMask, "\033[3;2~", +1, 0}, | |||||
{ XK_KP_Delete, XK_ANY_MOD, "\033[P", -1, 0}, | |||||
{ XK_KP_Delete, XK_ANY_MOD, "\033[3~", +1, 0}, | |||||
{ XK_KP_Multiply, XK_ANY_MOD, "\033Oj", +2, 0}, | |||||
{ XK_KP_Add, XK_ANY_MOD, "\033Ok", +2, 0}, | |||||
{ XK_KP_Enter, XK_ANY_MOD, "\033OM", +2, 0}, | |||||
{ XK_KP_Enter, XK_ANY_MOD, "\r", -1, 0}, | |||||
{ XK_KP_Subtract, XK_ANY_MOD, "\033Om", +2, 0}, | |||||
{ XK_KP_Decimal, XK_ANY_MOD, "\033On", +2, 0}, | |||||
{ XK_KP_Divide, XK_ANY_MOD, "\033Oo", +2, 0}, | |||||
{ XK_KP_0, XK_ANY_MOD, "\033Op", +2, 0}, | |||||
{ XK_KP_1, XK_ANY_MOD, "\033Oq", +2, 0}, | |||||
{ XK_KP_2, XK_ANY_MOD, "\033Or", +2, 0}, | |||||
{ XK_KP_3, XK_ANY_MOD, "\033Os", +2, 0}, | |||||
{ XK_KP_4, XK_ANY_MOD, "\033Ot", +2, 0}, | |||||
{ XK_KP_5, XK_ANY_MOD, "\033Ou", +2, 0}, | |||||
{ XK_KP_6, XK_ANY_MOD, "\033Ov", +2, 0}, | |||||
{ XK_KP_7, XK_ANY_MOD, "\033Ow", +2, 0}, | |||||
{ XK_KP_8, XK_ANY_MOD, "\033Ox", +2, 0}, | |||||
{ XK_KP_9, XK_ANY_MOD, "\033Oy", +2, 0}, | |||||
{ XK_Up, ShiftMask, "\033[1;2A", 0, 0}, | |||||
{ XK_Up, Mod1Mask, "\033[1;3A", 0, 0}, | |||||
{ XK_Up, ShiftMask|Mod1Mask,"\033[1;4A", 0, 0}, | |||||
{ XK_Up, ControlMask, "\033[1;5A", 0, 0}, | |||||
{ XK_Up, ShiftMask|ControlMask,"\033[1;6A", 0, 0}, | |||||
{ XK_Up, ControlMask|Mod1Mask,"\033[1;7A", 0, 0}, | |||||
{ XK_Up,ShiftMask|ControlMask|Mod1Mask,"\033[1;8A", 0, 0}, | |||||
{ XK_Up, XK_ANY_MOD, "\033[A", 0, -1}, | |||||
{ XK_Up, XK_ANY_MOD, "\033OA", 0, +1}, | |||||
{ XK_Down, ShiftMask, "\033[1;2B", 0, 0}, | |||||
{ XK_Down, Mod1Mask, "\033[1;3B", 0, 0}, | |||||
{ XK_Down, ShiftMask|Mod1Mask,"\033[1;4B", 0, 0}, | |||||
{ XK_Down, ControlMask, "\033[1;5B", 0, 0}, | |||||
{ XK_Down, ShiftMask|ControlMask,"\033[1;6B", 0, 0}, | |||||
{ XK_Down, ControlMask|Mod1Mask,"\033[1;7B", 0, 0}, | |||||
{ XK_Down,ShiftMask|ControlMask|Mod1Mask,"\033[1;8B",0, 0}, | |||||
{ XK_Down, XK_ANY_MOD, "\033[B", 0, -1}, | |||||
{ XK_Down, XK_ANY_MOD, "\033OB", 0, +1}, | |||||
{ XK_Left, ShiftMask, "\033[1;2D", 0, 0}, | |||||
{ XK_Left, Mod1Mask, "\033[1;3D", 0, 0}, | |||||
{ XK_Left, ShiftMask|Mod1Mask,"\033[1;4D", 0, 0}, | |||||
{ XK_Left, ControlMask, "\033[1;5D", 0, 0}, | |||||
{ XK_Left, ShiftMask|ControlMask,"\033[1;6D", 0, 0}, | |||||
{ XK_Left, ControlMask|Mod1Mask,"\033[1;7D", 0, 0}, | |||||
{ XK_Left,ShiftMask|ControlMask|Mod1Mask,"\033[1;8D",0, 0}, | |||||
{ XK_Left, XK_ANY_MOD, "\033[D", 0, -1}, | |||||
{ XK_Left, XK_ANY_MOD, "\033OD", 0, +1}, | |||||
{ XK_Right, ShiftMask, "\033[1;2C", 0, 0}, | |||||
{ XK_Right, Mod1Mask, "\033[1;3C", 0, 0}, | |||||
{ XK_Right, ShiftMask|Mod1Mask,"\033[1;4C", 0, 0}, | |||||
{ XK_Right, ControlMask, "\033[1;5C", 0, 0}, | |||||
{ XK_Right, ShiftMask|ControlMask,"\033[1;6C", 0, 0}, | |||||
{ XK_Right, ControlMask|Mod1Mask,"\033[1;7C", 0, 0}, | |||||
{ XK_Right,ShiftMask|ControlMask|Mod1Mask,"\033[1;8C",0, 0}, | |||||
{ XK_Right, XK_ANY_MOD, "\033[C", 0, -1}, | |||||
{ XK_Right, XK_ANY_MOD, "\033OC", 0, +1}, | |||||
{ XK_ISO_Left_Tab, ShiftMask, "\033[Z", 0, 0}, | |||||
{ XK_Return, Mod1Mask, "\033\r", 0, 0}, | |||||
{ XK_Return, XK_ANY_MOD, "\r", 0, 0}, | |||||
{ XK_Insert, ShiftMask, "\033[4l", -1, 0}, | |||||
{ XK_Insert, ShiftMask, "\033[2;2~", +1, 0}, | |||||
{ XK_Insert, ControlMask, "\033[L", -1, 0}, | |||||
{ XK_Insert, ControlMask, "\033[2;5~", +1, 0}, | |||||
{ XK_Insert, XK_ANY_MOD, "\033[4h", -1, 0}, | |||||
{ XK_Insert, XK_ANY_MOD, "\033[2~", +1, 0}, | |||||
{ XK_Delete, ControlMask, "\033[M", -1, 0}, | |||||
{ XK_Delete, ControlMask, "\033[3;5~", +1, 0}, | |||||
{ XK_Delete, ShiftMask, "\033[2K", -1, 0}, | |||||
{ XK_Delete, ShiftMask, "\033[3;2~", +1, 0}, | |||||
{ XK_Delete, XK_ANY_MOD, "\033[P", -1, 0}, | |||||
{ XK_Delete, XK_ANY_MOD, "\033[3~", +1, 0}, | |||||
{ XK_BackSpace, XK_NO_MOD, "\177", 0, 0}, | |||||
{ XK_BackSpace, Mod1Mask, "\033\177", 0, 0}, | |||||
{ XK_Home, ShiftMask, "\033[2J", 0, -1}, | |||||
{ XK_Home, ShiftMask, "\033[1;2H", 0, +1}, | |||||
{ XK_Home, XK_ANY_MOD, "\033[H", 0, -1}, | |||||
{ XK_Home, XK_ANY_MOD, "\033[1~", 0, +1}, | |||||
{ XK_End, ControlMask, "\033[J", -1, 0}, | |||||
{ XK_End, ControlMask, "\033[1;5F", +1, 0}, | |||||
{ XK_End, ShiftMask, "\033[K", -1, 0}, | |||||
{ XK_End, ShiftMask, "\033[1;2F", +1, 0}, | |||||
{ XK_End, XK_ANY_MOD, "\033[4~", 0, 0}, | |||||
{ XK_Prior, ControlMask, "\033[5;5~", 0, 0}, | |||||
{ XK_Prior, ShiftMask, "\033[5;2~", 0, 0}, | |||||
{ XK_Prior, XK_ANY_MOD, "\033[5~", 0, 0}, | |||||
{ XK_Next, ControlMask, "\033[6;5~", 0, 0}, | |||||
{ XK_Next, ShiftMask, "\033[6;2~", 0, 0}, | |||||
{ XK_Next, XK_ANY_MOD, "\033[6~", 0, 0}, | |||||
{ XK_F1, XK_NO_MOD, "\033OP" , 0, 0}, | |||||
{ XK_F1, /* F13 */ ShiftMask, "\033[1;2P", 0, 0}, | |||||
{ XK_F1, /* F25 */ ControlMask, "\033[1;5P", 0, 0}, | |||||
{ XK_F1, /* F37 */ Mod4Mask, "\033[1;6P", 0, 0}, | |||||
{ XK_F1, /* F49 */ Mod1Mask, "\033[1;3P", 0, 0}, | |||||
{ XK_F1, /* F61 */ Mod3Mask, "\033[1;4P", 0, 0}, | |||||
{ XK_F2, XK_NO_MOD, "\033OQ" , 0, 0}, | |||||
{ XK_F2, /* F14 */ ShiftMask, "\033[1;2Q", 0, 0}, | |||||
{ XK_F2, /* F26 */ ControlMask, "\033[1;5Q", 0, 0}, | |||||
{ XK_F2, /* F38 */ Mod4Mask, "\033[1;6Q", 0, 0}, | |||||
{ XK_F2, /* F50 */ Mod1Mask, "\033[1;3Q", 0, 0}, | |||||
{ XK_F2, /* F62 */ Mod3Mask, "\033[1;4Q", 0, 0}, | |||||
{ XK_F3, XK_NO_MOD, "\033OR" , 0, 0}, | |||||
{ XK_F3, /* F15 */ ShiftMask, "\033[1;2R", 0, 0}, | |||||
{ XK_F3, /* F27 */ ControlMask, "\033[1;5R", 0, 0}, | |||||
{ XK_F3, /* F39 */ Mod4Mask, "\033[1;6R", 0, 0}, | |||||
{ XK_F3, /* F51 */ Mod1Mask, "\033[1;3R", 0, 0}, | |||||
{ XK_F3, /* F63 */ Mod3Mask, "\033[1;4R", 0, 0}, | |||||
{ XK_F4, XK_NO_MOD, "\033OS" , 0, 0}, | |||||
{ XK_F4, /* F16 */ ShiftMask, "\033[1;2S", 0, 0}, | |||||
{ XK_F4, /* F28 */ ControlMask, "\033[1;5S", 0, 0}, | |||||
{ XK_F4, /* F40 */ Mod4Mask, "\033[1;6S", 0, 0}, | |||||
{ XK_F4, /* F52 */ Mod1Mask, "\033[1;3S", 0, 0}, | |||||
{ XK_F5, XK_NO_MOD, "\033[15~", 0, 0}, | |||||
{ XK_F5, /* F17 */ ShiftMask, "\033[15;2~", 0, 0}, | |||||
{ XK_F5, /* F29 */ ControlMask, "\033[15;5~", 0, 0}, | |||||
{ XK_F5, /* F41 */ Mod4Mask, "\033[15;6~", 0, 0}, | |||||
{ XK_F5, /* F53 */ Mod1Mask, "\033[15;3~", 0, 0}, | |||||
{ XK_F6, XK_NO_MOD, "\033[17~", 0, 0}, | |||||
{ XK_F6, /* F18 */ ShiftMask, "\033[17;2~", 0, 0}, | |||||
{ XK_F6, /* F30 */ ControlMask, "\033[17;5~", 0, 0}, | |||||
{ XK_F6, /* F42 */ Mod4Mask, "\033[17;6~", 0, 0}, | |||||
{ XK_F6, /* F54 */ Mod1Mask, "\033[17;3~", 0, 0}, | |||||
{ XK_F7, XK_NO_MOD, "\033[18~", 0, 0}, | |||||
{ XK_F7, /* F19 */ ShiftMask, "\033[18;2~", 0, 0}, | |||||
{ XK_F7, /* F31 */ ControlMask, "\033[18;5~", 0, 0}, | |||||
{ XK_F7, /* F43 */ Mod4Mask, "\033[18;6~", 0, 0}, | |||||
{ XK_F7, /* F55 */ Mod1Mask, "\033[18;3~", 0, 0}, | |||||
{ XK_F8, XK_NO_MOD, "\033[19~", 0, 0}, | |||||
{ XK_F8, /* F20 */ ShiftMask, "\033[19;2~", 0, 0}, | |||||
{ XK_F8, /* F32 */ ControlMask, "\033[19;5~", 0, 0}, | |||||
{ XK_F8, /* F44 */ Mod4Mask, "\033[19;6~", 0, 0}, | |||||
{ XK_F8, /* F56 */ Mod1Mask, "\033[19;3~", 0, 0}, | |||||
{ XK_F9, XK_NO_MOD, "\033[20~", 0, 0}, | |||||
{ XK_F9, /* F21 */ ShiftMask, "\033[20;2~", 0, 0}, | |||||
{ XK_F9, /* F33 */ ControlMask, "\033[20;5~", 0, 0}, | |||||
{ XK_F9, /* F45 */ Mod4Mask, "\033[20;6~", 0, 0}, | |||||
{ XK_F9, /* F57 */ Mod1Mask, "\033[20;3~", 0, 0}, | |||||
{ XK_F10, XK_NO_MOD, "\033[21~", 0, 0}, | |||||
{ XK_F10, /* F22 */ ShiftMask, "\033[21;2~", 0, 0}, | |||||
{ XK_F10, /* F34 */ ControlMask, "\033[21;5~", 0, 0}, | |||||
{ XK_F10, /* F46 */ Mod4Mask, "\033[21;6~", 0, 0}, | |||||
{ XK_F10, /* F58 */ Mod1Mask, "\033[21;3~", 0, 0}, | |||||
{ XK_F11, XK_NO_MOD, "\033[23~", 0, 0}, | |||||
{ XK_F11, /* F23 */ ShiftMask, "\033[23;2~", 0, 0}, | |||||
{ XK_F11, /* F35 */ ControlMask, "\033[23;5~", 0, 0}, | |||||
{ XK_F11, /* F47 */ Mod4Mask, "\033[23;6~", 0, 0}, | |||||
{ XK_F11, /* F59 */ Mod1Mask, "\033[23;3~", 0, 0}, | |||||
{ XK_F12, XK_NO_MOD, "\033[24~", 0, 0}, | |||||
{ XK_F12, /* F24 */ ShiftMask, "\033[24;2~", 0, 0}, | |||||
{ XK_F12, /* F36 */ ControlMask, "\033[24;5~", 0, 0}, | |||||
{ XK_F12, /* F48 */ Mod4Mask, "\033[24;6~", 0, 0}, | |||||
{ XK_F12, /* F60 */ Mod1Mask, "\033[24;3~", 0, 0}, | |||||
{ XK_F13, XK_NO_MOD, "\033[1;2P", 0, 0}, | |||||
{ XK_F14, XK_NO_MOD, "\033[1;2Q", 0, 0}, | |||||
{ XK_F15, XK_NO_MOD, "\033[1;2R", 0, 0}, | |||||
{ XK_F16, XK_NO_MOD, "\033[1;2S", 0, 0}, | |||||
{ XK_F17, XK_NO_MOD, "\033[15;2~", 0, 0}, | |||||
{ XK_F18, XK_NO_MOD, "\033[17;2~", 0, 0}, | |||||
{ XK_F19, XK_NO_MOD, "\033[18;2~", 0, 0}, | |||||
{ XK_F20, XK_NO_MOD, "\033[19;2~", 0, 0}, | |||||
{ XK_F21, XK_NO_MOD, "\033[20;2~", 0, 0}, | |||||
{ XK_F22, XK_NO_MOD, "\033[21;2~", 0, 0}, | |||||
{ XK_F23, XK_NO_MOD, "\033[23;2~", 0, 0}, | |||||
{ XK_F24, XK_NO_MOD, "\033[24;2~", 0, 0}, | |||||
{ XK_F25, XK_NO_MOD, "\033[1;5P", 0, 0}, | |||||
{ XK_F26, XK_NO_MOD, "\033[1;5Q", 0, 0}, | |||||
{ XK_F27, XK_NO_MOD, "\033[1;5R", 0, 0}, | |||||
{ XK_F28, XK_NO_MOD, "\033[1;5S", 0, 0}, | |||||
{ XK_F29, XK_NO_MOD, "\033[15;5~", 0, 0}, | |||||
{ XK_F30, XK_NO_MOD, "\033[17;5~", 0, 0}, | |||||
{ XK_F31, XK_NO_MOD, "\033[18;5~", 0, 0}, | |||||
{ XK_F32, XK_NO_MOD, "\033[19;5~", 0, 0}, | |||||
{ XK_F33, XK_NO_MOD, "\033[20;5~", 0, 0}, | |||||
{ XK_F34, XK_NO_MOD, "\033[21;5~", 0, 0}, | |||||
{ XK_F35, XK_NO_MOD, "\033[23;5~", 0, 0}, | |||||
}; | |||||
/* | |||||
* Selection types' masks. | |||||
* Use the same masks as usual. | |||||
* Button1Mask is always unset, to make masks match between ButtonPress. | |||||
* ButtonRelease and MotionNotify. | |||||
* If no match is found, regular selection is used. | |||||
*/ | |||||
static uint selmasks[] = { | |||||
[SEL_RECTANGULAR] = Mod1Mask, | |||||
}; | |||||
/* | |||||
* Printable characters in ASCII, used to estimate the advance width | |||||
* of single wide characters. | |||||
*/ | |||||
static char ascii_printable[] = | |||||
" !\"#$%&'()*+,-./0123456789:;<=>?" | |||||
"@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\\]^_" | |||||
"`abcdefghijklmnopqrstuvwxyz{|}~"; |
@@ -0,0 +1,476 @@ | |||||
/* See LICENSE file for copyright and license details. */ | |||||
/* | |||||
* appearance | |||||
* | |||||
* font: see http://freedesktop.org/software/fontconfig/fontconfig-user.html | |||||
*/ | |||||
static char *font = "Liberation Mono:pixelsize=12:antialias=true:autohint=true"; | |||||
static int borderpx = 2; | |||||
/* | |||||
* What program is execed by st depends of these precedence rules: | |||||
* 1: program passed with -e | |||||
* 2: scroll and/or utmp | |||||
* 3: SHELL environment variable | |||||
* 4: value of shell in /etc/passwd | |||||
* 5: value of shell in config.h | |||||
*/ | |||||
static char *shell = "/bin/sh"; | |||||
char *utmp = NULL; | |||||
/* scroll program: to enable use a string like "scroll" */ | |||||
char *scroll = NULL; | |||||
char *stty_args = "stty raw pass8 nl -echo -iexten -cstopb 38400"; | |||||
/* identification sequence returned in DA and DECID */ | |||||
char *vtiden = "\033[?6c"; | |||||
/* Kerning / character bounding-box multipliers */ | |||||
static float cwscale = 1.0; | |||||
static float chscale = 1.0; | |||||
/* | |||||
* word delimiter string | |||||
* | |||||
* More advanced example: L" `'\"()[]{}" | |||||
*/ | |||||
wchar_t *worddelimiters = L" "; | |||||
/* selection timeouts (in milliseconds) */ | |||||
static unsigned int doubleclicktimeout = 300; | |||||
static unsigned int tripleclicktimeout = 600; | |||||
/* alt screens */ | |||||
int allowaltscreen = 1; | |||||
/* allow certain non-interactive (insecure) window operations such as: | |||||
setting the clipboard text */ | |||||
int allowwindowops = 0; | |||||
/* | |||||
* draw latency range in ms - from new content/keypress/etc until drawing. | |||||
* within this range, st draws when content stops arriving (idle). mostly it's | |||||
* near minlatency, but it waits longer for slow updates to avoid partial draw. | |||||
* low minlatency will tear/flicker more, as it can "detect" idle too early. | |||||
*/ | |||||
static double minlatency = 8; | |||||
static double maxlatency = 33; | |||||
/* | |||||
* blinking timeout (set to 0 to disable blinking) for the terminal blinking | |||||
* attribute. | |||||
*/ | |||||
static unsigned int blinktimeout = 800; | |||||
/* | |||||
* thickness of underline and bar cursors | |||||
*/ | |||||
static unsigned int cursorthickness = 2; | |||||
/* | |||||
* bell volume. It must be a value between -100 and 100. Use 0 for disabling | |||||
* it | |||||
*/ | |||||
static int bellvolume = 0; | |||||
/* default TERM value */ | |||||
char *termname = "st-256color"; | |||||
/* | |||||
* spaces per tab | |||||
* | |||||
* When you are changing this value, don't forget to adapt the »it« value in | |||||
* the st.info and appropriately install the st.info in the environment where | |||||
* you use this st version. | |||||
* | |||||
* it#$tabspaces, | |||||
* | |||||
* Secondly make sure your kernel is not expanding tabs. When running `stty | |||||
* -a` »tab0« should appear. You can tell the terminal to not expand tabs by | |||||
* running following command: | |||||
* | |||||
* stty tabs | |||||
*/ | |||||
unsigned int tabspaces = 8; | |||||
/* bg opacity */ | |||||
float alpha = 0.8; | |||||
/* Terminal colors (16 first used in escape sequence) */ | |||||
static const char *colorname[] = { | |||||
/* 8 normal colors */ | |||||
"black", | |||||
"red3", | |||||
"green3", | |||||
"yellow3", | |||||
"blue2", | |||||
"magenta3", | |||||
"cyan3", | |||||
"gray90", | |||||
/* 8 bright colors */ | |||||
"gray50", | |||||
"red", | |||||
"green", | |||||
"yellow", | |||||
"#5c5cff", | |||||
"magenta", | |||||
"cyan", | |||||
"white", | |||||
[255] = 0, | |||||
/* more colors can be added after 255 to use with DefaultXX */ | |||||
"#cccccc", | |||||
"#555555", | |||||
"black", | |||||
}; | |||||
/* | |||||
* Default colors (colorname index) | |||||
* foreground, background, cursor, reverse cursor | |||||
*/ | |||||
unsigned int defaultfg = 7; | |||||
unsigned int defaultbg = 258; | |||||
static unsigned int defaultcs = 256; | |||||
static unsigned int defaultrcs = 257; | |||||
/* | |||||
* Default shape of cursor | |||||
* 2: Block ("█") | |||||
* 4: Underline ("_") | |||||
* 6: Bar ("|") | |||||
* 7: Snowman ("☃") | |||||
*/ | |||||
static unsigned int cursorshape = 2; | |||||
/* | |||||
* Default columns and rows numbers | |||||
*/ | |||||
static unsigned int cols = 80; | |||||
static unsigned int rows = 24; | |||||
/* | |||||
* Default colour and shape of the mouse cursor | |||||
*/ | |||||
static unsigned int mouseshape = XC_xterm; | |||||
static unsigned int mousefg = 7; | |||||
static unsigned int mousebg = 0; | |||||
/* | |||||
* Color used to display font attributes when fontconfig selected a font which | |||||
* doesn't match the ones requested. | |||||
*/ | |||||
static unsigned int defaultattr = 11; | |||||
/* | |||||
* Force mouse select/shortcuts while mask is active (when MODE_MOUSE is set). | |||||
* Note that if you want to use ShiftMask with selmasks, set this to an other | |||||
* modifier, set to 0 to not use it. | |||||
*/ | |||||
static uint forcemousemod = ShiftMask; | |||||
/* | |||||
* Internal mouse shortcuts. | |||||
* Beware that overloading Button1 will disable the selection. | |||||
*/ | |||||
static MouseShortcut mshortcuts[] = { | |||||
/* mask button function argument release */ | |||||
{ XK_ANY_MOD, Button2, selpaste, {.i = 0}, 1 }, | |||||
{ ShiftMask, Button4, ttysend, {.s = "\033[5;2~"} }, | |||||
{ XK_ANY_MOD, Button4, ttysend, {.s = "\031"} }, | |||||
{ ShiftMask, Button5, ttysend, {.s = "\033[6;2~"} }, | |||||
{ XK_ANY_MOD, Button5, ttysend, {.s = "\005"} }, | |||||
}; | |||||
/* Internal keyboard shortcuts. */ | |||||
#define MODKEY Mod1Mask | |||||
#define TERMMOD (ControlMask|ShiftMask) | |||||
static Shortcut shortcuts[] = { | |||||
/* mask keysym function argument */ | |||||
{ XK_ANY_MOD, XK_Break, sendbreak, {.i = 0} }, | |||||
{ ControlMask, XK_Print, toggleprinter, {.i = 0} }, | |||||
{ ShiftMask, XK_Print, printscreen, {.i = 0} }, | |||||
{ XK_ANY_MOD, XK_Print, printsel, {.i = 0} }, | |||||
{ TERMMOD, XK_Prior, zoom, {.f = +1} }, | |||||
{ TERMMOD, XK_Next, zoom, {.f = -1} }, | |||||
{ TERMMOD, XK_Home, zoomreset, {.f = 0} }, | |||||
{ TERMMOD, XK_C, clipcopy, {.i = 0} }, | |||||
{ TERMMOD, XK_V, clippaste, {.i = 0} }, | |||||
{ TERMMOD, XK_Y, selpaste, {.i = 0} }, | |||||
{ ShiftMask, XK_Insert, selpaste, {.i = 0} }, | |||||
{ TERMMOD, XK_Num_Lock, numlock, {.i = 0} }, | |||||
}; | |||||
/* | |||||
* Special keys (change & recompile st.info accordingly) | |||||
* | |||||
* Mask value: | |||||
* * Use XK_ANY_MOD to match the key no matter modifiers state | |||||
* * Use XK_NO_MOD to match the key alone (no modifiers) | |||||
* appkey value: | |||||
* * 0: no value | |||||
* * > 0: keypad application mode enabled | |||||
* * = 2: term.numlock = 1 | |||||
* * < 0: keypad application mode disabled | |||||
* appcursor value: | |||||
* * 0: no value | |||||
* * > 0: cursor application mode enabled | |||||
* * < 0: cursor application mode disabled | |||||
* | |||||
* Be careful with the order of the definitions because st searches in | |||||
* this table sequentially, so any XK_ANY_MOD must be in the last | |||||
* position for a key. | |||||
*/ | |||||
/* | |||||
* If you want keys other than the X11 function keys (0xFD00 - 0xFFFF) | |||||
* to be mapped below, add them to this array. | |||||
*/ | |||||
static KeySym mappedkeys[] = { -1 }; | |||||
/* | |||||
* State bits to ignore when matching key or button events. By default, | |||||
* numlock (Mod2Mask) and keyboard layout (XK_SWITCH_MOD) are ignored. | |||||
*/ | |||||
static uint ignoremod = Mod2Mask|XK_SWITCH_MOD; | |||||
/* | |||||
* This is the huge key array which defines all compatibility to the Linux | |||||
* world. Please decide about changes wisely. | |||||
*/ | |||||
static Key key[] = { | |||||
/* keysym mask string appkey appcursor */ | |||||
{ XK_KP_Home, ShiftMask, "\033[2J", 0, -1}, | |||||
{ XK_KP_Home, ShiftMask, "\033[1;2H", 0, +1}, | |||||
{ XK_KP_Home, XK_ANY_MOD, "\033[H", 0, -1}, | |||||
{ XK_KP_Home, XK_ANY_MOD, "\033[1~", 0, +1}, | |||||
{ XK_KP_Up, XK_ANY_MOD, "\033Ox", +1, 0}, | |||||
{ XK_KP_Up, XK_ANY_MOD, "\033[A", 0, -1}, | |||||
{ XK_KP_Up, XK_ANY_MOD, "\033OA", 0, +1}, | |||||
{ XK_KP_Down, XK_ANY_MOD, "\033Or", +1, 0}, | |||||
{ XK_KP_Down, XK_ANY_MOD, "\033[B", 0, -1}, | |||||
{ XK_KP_Down, XK_ANY_MOD, "\033OB", 0, +1}, | |||||
{ XK_KP_Left, XK_ANY_MOD, "\033Ot", +1, 0}, | |||||
{ XK_KP_Left, XK_ANY_MOD, "\033[D", 0, -1}, | |||||
{ XK_KP_Left, XK_ANY_MOD, "\033OD", 0, +1}, | |||||
{ XK_KP_Right, XK_ANY_MOD, "\033Ov", +1, 0}, | |||||
{ XK_KP_Right, XK_ANY_MOD, "\033[C", 0, -1}, | |||||
{ XK_KP_Right, XK_ANY_MOD, "\033OC", 0, +1}, | |||||
{ XK_KP_Prior, ShiftMask, "\033[5;2~", 0, 0}, | |||||
{ XK_KP_Prior, XK_ANY_MOD, "\033[5~", 0, 0}, | |||||
{ XK_KP_Begin, XK_ANY_MOD, "\033[E", 0, 0}, | |||||
{ XK_KP_End, ControlMask, "\033[J", -1, 0}, | |||||
{ XK_KP_End, ControlMask, "\033[1;5F", +1, 0}, | |||||
{ XK_KP_End, ShiftMask, "\033[K", -1, 0}, | |||||
{ XK_KP_End, ShiftMask, "\033[1;2F", +1, 0}, | |||||
{ XK_KP_End, XK_ANY_MOD, "\033[4~", 0, 0}, | |||||
{ XK_KP_Next, ShiftMask, "\033[6;2~", 0, 0}, | |||||
{ XK_KP_Next, XK_ANY_MOD, "\033[6~", 0, 0}, | |||||
{ XK_KP_Insert, ShiftMask, "\033[2;2~", +1, 0}, | |||||
{ XK_KP_Insert, ShiftMask, "\033[4l", -1, 0}, | |||||
{ XK_KP_Insert, ControlMask, "\033[L", -1, 0}, | |||||
{ XK_KP_Insert, ControlMask, "\033[2;5~", +1, 0}, | |||||
{ XK_KP_Insert, XK_ANY_MOD, "\033[4h", -1, 0}, | |||||
{ XK_KP_Insert, XK_ANY_MOD, "\033[2~", +1, 0}, | |||||
{ XK_KP_Delete, ControlMask, "\033[M", -1, 0}, | |||||
{ XK_KP_Delete, ControlMask, "\033[3;5~", +1, 0}, | |||||
{ XK_KP_Delete, ShiftMask, "\033[2K", -1, 0}, | |||||
{ XK_KP_Delete, ShiftMask, "\033[3;2~", +1, 0}, | |||||
{ XK_KP_Delete, XK_ANY_MOD, "\033[P", -1, 0}, | |||||
{ XK_KP_Delete, XK_ANY_MOD, "\033[3~", +1, 0}, | |||||
{ XK_KP_Multiply, XK_ANY_MOD, "\033Oj", +2, 0}, | |||||
{ XK_KP_Add, XK_ANY_MOD, "\033Ok", +2, 0}, | |||||
{ XK_KP_Enter, XK_ANY_MOD, "\033OM", +2, 0}, | |||||
{ XK_KP_Enter, XK_ANY_MOD, "\r", -1, 0}, | |||||
{ XK_KP_Subtract, XK_ANY_MOD, "\033Om", +2, 0}, | |||||
{ XK_KP_Decimal, XK_ANY_MOD, "\033On", +2, 0}, | |||||
{ XK_KP_Divide, XK_ANY_MOD, "\033Oo", +2, 0}, | |||||
{ XK_KP_0, XK_ANY_MOD, "\033Op", +2, 0}, | |||||
{ XK_KP_1, XK_ANY_MOD, "\033Oq", +2, 0}, | |||||
{ XK_KP_2, XK_ANY_MOD, "\033Or", +2, 0}, | |||||
{ XK_KP_3, XK_ANY_MOD, "\033Os", +2, 0}, | |||||
{ XK_KP_4, XK_ANY_MOD, "\033Ot", +2, 0}, | |||||
{ XK_KP_5, XK_ANY_MOD, "\033Ou", +2, 0}, | |||||
{ XK_KP_6, XK_ANY_MOD, "\033Ov", +2, 0}, | |||||
{ XK_KP_7, XK_ANY_MOD, "\033Ow", +2, 0}, | |||||
{ XK_KP_8, XK_ANY_MOD, "\033Ox", +2, 0}, | |||||
{ XK_KP_9, XK_ANY_MOD, "\033Oy", +2, 0}, | |||||
{ XK_Up, ShiftMask, "\033[1;2A", 0, 0}, | |||||
{ XK_Up, Mod1Mask, "\033[1;3A", 0, 0}, | |||||
{ XK_Up, ShiftMask|Mod1Mask,"\033[1;4A", 0, 0}, | |||||
{ XK_Up, ControlMask, "\033[1;5A", 0, 0}, | |||||
{ XK_Up, ShiftMask|ControlMask,"\033[1;6A", 0, 0}, | |||||
{ XK_Up, ControlMask|Mod1Mask,"\033[1;7A", 0, 0}, | |||||
{ XK_Up,ShiftMask|ControlMask|Mod1Mask,"\033[1;8A", 0, 0}, | |||||
{ XK_Up, XK_ANY_MOD, "\033[A", 0, -1}, | |||||
{ XK_Up, XK_ANY_MOD, "\033OA", 0, +1}, | |||||
{ XK_Down, ShiftMask, "\033[1;2B", 0, 0}, | |||||
{ XK_Down, Mod1Mask, "\033[1;3B", 0, 0}, | |||||
{ XK_Down, ShiftMask|Mod1Mask,"\033[1;4B", 0, 0}, | |||||
{ XK_Down, ControlMask, "\033[1;5B", 0, 0}, | |||||
{ XK_Down, ShiftMask|ControlMask,"\033[1;6B", 0, 0}, | |||||
{ XK_Down, ControlMask|Mod1Mask,"\033[1;7B", 0, 0}, | |||||
{ XK_Down,ShiftMask|ControlMask|Mod1Mask,"\033[1;8B",0, 0}, | |||||
{ XK_Down, XK_ANY_MOD, "\033[B", 0, -1}, | |||||
{ XK_Down, XK_ANY_MOD, "\033OB", 0, +1}, | |||||
{ XK_Left, ShiftMask, "\033[1;2D", 0, 0}, | |||||
{ XK_Left, Mod1Mask, "\033[1;3D", 0, 0}, | |||||
{ XK_Left, ShiftMask|Mod1Mask,"\033[1;4D", 0, 0}, | |||||
{ XK_Left, ControlMask, "\033[1;5D", 0, 0}, | |||||
{ XK_Left, ShiftMask|ControlMask,"\033[1;6D", 0, 0}, | |||||
{ XK_Left, ControlMask|Mod1Mask,"\033[1;7D", 0, 0}, | |||||
{ XK_Left,ShiftMask|ControlMask|Mod1Mask,"\033[1;8D",0, 0}, | |||||
{ XK_Left, XK_ANY_MOD, "\033[D", 0, -1}, | |||||
{ XK_Left, XK_ANY_MOD, "\033OD", 0, +1}, | |||||
{ XK_Right, ShiftMask, "\033[1;2C", 0, 0}, | |||||
{ XK_Right, Mod1Mask, "\033[1;3C", 0, 0}, | |||||
{ XK_Right, ShiftMask|Mod1Mask,"\033[1;4C", 0, 0}, | |||||
{ XK_Right, ControlMask, "\033[1;5C", 0, 0}, | |||||
{ XK_Right, ShiftMask|ControlMask,"\033[1;6C", 0, 0}, | |||||
{ XK_Right, ControlMask|Mod1Mask,"\033[1;7C", 0, 0}, | |||||
{ XK_Right,ShiftMask|ControlMask|Mod1Mask,"\033[1;8C",0, 0}, | |||||
{ XK_Right, XK_ANY_MOD, "\033[C", 0, -1}, | |||||
{ XK_Right, XK_ANY_MOD, "\033OC", 0, +1}, | |||||
{ XK_ISO_Left_Tab, ShiftMask, "\033[Z", 0, 0}, | |||||
{ XK_Return, Mod1Mask, "\033\r", 0, 0}, | |||||
{ XK_Return, XK_ANY_MOD, "\r", 0, 0}, | |||||
{ XK_Insert, ShiftMask, "\033[4l", -1, 0}, | |||||
{ XK_Insert, ShiftMask, "\033[2;2~", +1, 0}, | |||||
{ XK_Insert, ControlMask, "\033[L", -1, 0}, | |||||
{ XK_Insert, ControlMask, "\033[2;5~", +1, 0}, | |||||
{ XK_Insert, XK_ANY_MOD, "\033[4h", -1, 0}, | |||||
{ XK_Insert, XK_ANY_MOD, "\033[2~", +1, 0}, | |||||
{ XK_Delete, ControlMask, "\033[M", -1, 0}, | |||||
{ XK_Delete, ControlMask, "\033[3;5~", +1, 0}, | |||||
{ XK_Delete, ShiftMask, "\033[2K", -1, 0}, | |||||
{ XK_Delete, ShiftMask, "\033[3;2~", +1, 0}, | |||||
{ XK_Delete, XK_ANY_MOD, "\033[P", -1, 0}, | |||||
{ XK_Delete, XK_ANY_MOD, "\033[3~", +1, 0}, | |||||
{ XK_BackSpace, XK_NO_MOD, "\177", 0, 0}, | |||||
{ XK_BackSpace, Mod1Mask, "\033\177", 0, 0}, | |||||
{ XK_Home, ShiftMask, "\033[2J", 0, -1}, | |||||
{ XK_Home, ShiftMask, "\033[1;2H", 0, +1}, | |||||
{ XK_Home, XK_ANY_MOD, "\033[H", 0, -1}, | |||||
{ XK_Home, XK_ANY_MOD, "\033[1~", 0, +1}, | |||||
{ XK_End, ControlMask, "\033[J", -1, 0}, | |||||
{ XK_End, ControlMask, "\033[1;5F", +1, 0}, | |||||
{ XK_End, ShiftMask, "\033[K", -1, 0}, | |||||
{ XK_End, ShiftMask, "\033[1;2F", +1, 0}, | |||||
{ XK_End, XK_ANY_MOD, "\033[4~", 0, 0}, | |||||
{ XK_Prior, ControlMask, "\033[5;5~", 0, 0}, | |||||
{ XK_Prior, ShiftMask, "\033[5;2~", 0, 0}, | |||||
{ XK_Prior, XK_ANY_MOD, "\033[5~", 0, 0}, | |||||
{ XK_Next, ControlMask, "\033[6;5~", 0, 0}, | |||||
{ XK_Next, ShiftMask, "\033[6;2~", 0, 0}, | |||||
{ XK_Next, XK_ANY_MOD, "\033[6~", 0, 0}, | |||||
{ XK_F1, XK_NO_MOD, "\033OP" , 0, 0}, | |||||
{ XK_F1, /* F13 */ ShiftMask, "\033[1;2P", 0, 0}, | |||||
{ XK_F1, /* F25 */ ControlMask, "\033[1;5P", 0, 0}, | |||||
{ XK_F1, /* F37 */ Mod4Mask, "\033[1;6P", 0, 0}, | |||||
{ XK_F1, /* F49 */ Mod1Mask, "\033[1;3P", 0, 0}, | |||||
{ XK_F1, /* F61 */ Mod3Mask, "\033[1;4P", 0, 0}, | |||||
{ XK_F2, XK_NO_MOD, "\033OQ" , 0, 0}, | |||||
{ XK_F2, /* F14 */ ShiftMask, "\033[1;2Q", 0, 0}, | |||||
{ XK_F2, /* F26 */ ControlMask, "\033[1;5Q", 0, 0}, | |||||
{ XK_F2, /* F38 */ Mod4Mask, "\033[1;6Q", 0, 0}, | |||||
{ XK_F2, /* F50 */ Mod1Mask, "\033[1;3Q", 0, 0}, | |||||
{ XK_F2, /* F62 */ Mod3Mask, "\033[1;4Q", 0, 0}, | |||||
{ XK_F3, XK_NO_MOD, "\033OR" , 0, 0}, | |||||
{ XK_F3, /* F15 */ ShiftMask, "\033[1;2R", 0, 0}, | |||||
{ XK_F3, /* F27 */ ControlMask, "\033[1;5R", 0, 0}, | |||||
{ XK_F3, /* F39 */ Mod4Mask, "\033[1;6R", 0, 0}, | |||||
{ XK_F3, /* F51 */ Mod1Mask, "\033[1;3R", 0, 0}, | |||||
{ XK_F3, /* F63 */ Mod3Mask, "\033[1;4R", 0, 0}, | |||||
{ XK_F4, XK_NO_MOD, "\033OS" , 0, 0}, | |||||
{ XK_F4, /* F16 */ ShiftMask, "\033[1;2S", 0, 0}, | |||||
{ XK_F4, /* F28 */ ControlMask, "\033[1;5S", 0, 0}, | |||||
{ XK_F4, /* F40 */ Mod4Mask, "\033[1;6S", 0, 0}, | |||||
{ XK_F4, /* F52 */ Mod1Mask, "\033[1;3S", 0, 0}, | |||||
{ XK_F5, XK_NO_MOD, "\033[15~", 0, 0}, | |||||
{ XK_F5, /* F17 */ ShiftMask, "\033[15;2~", 0, 0}, | |||||
{ XK_F5, /* F29 */ ControlMask, "\033[15;5~", 0, 0}, | |||||
{ XK_F5, /* F41 */ Mod4Mask, "\033[15;6~", 0, 0}, | |||||
{ XK_F5, /* F53 */ Mod1Mask, "\033[15;3~", 0, 0}, | |||||
{ XK_F6, XK_NO_MOD, "\033[17~", 0, 0}, | |||||
{ XK_F6, /* F18 */ ShiftMask, "\033[17;2~", 0, 0}, | |||||
{ XK_F6, /* F30 */ ControlMask, "\033[17;5~", 0, 0}, | |||||
{ XK_F6, /* F42 */ Mod4Mask, "\033[17;6~", 0, 0}, | |||||
{ XK_F6, /* F54 */ Mod1Mask, "\033[17;3~", 0, 0}, | |||||
{ XK_F7, XK_NO_MOD, "\033[18~", 0, 0}, | |||||
{ XK_F7, /* F19 */ ShiftMask, "\033[18;2~", 0, 0}, | |||||
{ XK_F7, /* F31 */ ControlMask, "\033[18;5~", 0, 0}, | |||||
{ XK_F7, /* F43 */ Mod4Mask, "\033[18;6~", 0, 0}, | |||||
{ XK_F7, /* F55 */ Mod1Mask, "\033[18;3~", 0, 0}, | |||||
{ XK_F8, XK_NO_MOD, "\033[19~", 0, 0}, | |||||
{ XK_F8, /* F20 */ ShiftMask, "\033[19;2~", 0, 0}, | |||||
{ XK_F8, /* F32 */ ControlMask, "\033[19;5~", 0, 0}, | |||||
{ XK_F8, /* F44 */ Mod4Mask, "\033[19;6~", 0, 0}, | |||||
{ XK_F8, /* F56 */ Mod1Mask, "\033[19;3~", 0, 0}, | |||||
{ XK_F9, XK_NO_MOD, "\033[20~", 0, 0}, | |||||
{ XK_F9, /* F21 */ ShiftMask, "\033[20;2~", 0, 0}, | |||||
{ XK_F9, /* F33 */ ControlMask, "\033[20;5~", 0, 0}, | |||||
{ XK_F9, /* F45 */ Mod4Mask, "\033[20;6~", 0, 0}, | |||||
{ XK_F9, /* F57 */ Mod1Mask, "\033[20;3~", 0, 0}, | |||||
{ XK_F10, XK_NO_MOD, "\033[21~", 0, 0}, | |||||
{ XK_F10, /* F22 */ ShiftMask, "\033[21;2~", 0, 0}, | |||||
{ XK_F10, /* F34 */ ControlMask, "\033[21;5~", 0, 0}, | |||||
{ XK_F10, /* F46 */ Mod4Mask, "\033[21;6~", 0, 0}, | |||||
{ XK_F10, /* F58 */ Mod1Mask, "\033[21;3~", 0, 0}, | |||||
{ XK_F11, XK_NO_MOD, "\033[23~", 0, 0}, | |||||
{ XK_F11, /* F23 */ ShiftMask, "\033[23;2~", 0, 0}, | |||||
{ XK_F11, /* F35 */ ControlMask, "\033[23;5~", 0, 0}, | |||||
{ XK_F11, /* F47 */ Mod4Mask, "\033[23;6~", 0, 0}, | |||||
{ XK_F11, /* F59 */ Mod1Mask, "\033[23;3~", 0, 0}, | |||||
{ XK_F12, XK_NO_MOD, "\033[24~", 0, 0}, | |||||
{ XK_F12, /* F24 */ ShiftMask, "\033[24;2~", 0, 0}, | |||||
{ XK_F12, /* F36 */ ControlMask, "\033[24;5~", 0, 0}, | |||||
{ XK_F12, /* F48 */ Mod4Mask, "\033[24;6~", 0, 0}, | |||||
{ XK_F12, /* F60 */ Mod1Mask, "\033[24;3~", 0, 0}, | |||||
{ XK_F13, XK_NO_MOD, "\033[1;2P", 0, 0}, | |||||
{ XK_F14, XK_NO_MOD, "\033[1;2Q", 0, 0}, | |||||
{ XK_F15, XK_NO_MOD, "\033[1;2R", 0, 0}, | |||||
{ XK_F16, XK_NO_MOD, "\033[1;2S", 0, 0}, | |||||
{ XK_F17, XK_NO_MOD, "\033[15;2~", 0, 0}, | |||||
{ XK_F18, XK_NO_MOD, "\033[17;2~", 0, 0}, | |||||
{ XK_F19, XK_NO_MOD, "\033[18;2~", 0, 0}, | |||||
{ XK_F20, XK_NO_MOD, "\033[19;2~", 0, 0}, | |||||
{ XK_F21, XK_NO_MOD, "\033[20;2~", 0, 0}, | |||||
{ XK_F22, XK_NO_MOD, "\033[21;2~", 0, 0}, | |||||
{ XK_F23, XK_NO_MOD, "\033[23;2~", 0, 0}, | |||||
{ XK_F24, XK_NO_MOD, "\033[24;2~", 0, 0}, | |||||
{ XK_F25, XK_NO_MOD, "\033[1;5P", 0, 0}, | |||||
{ XK_F26, XK_NO_MOD, "\033[1;5Q", 0, 0}, | |||||
{ XK_F27, XK_NO_MOD, "\033[1;5R", 0, 0}, | |||||
{ XK_F28, XK_NO_MOD, "\033[1;5S", 0, 0}, | |||||
{ XK_F29, XK_NO_MOD, "\033[15;5~", 0, 0}, | |||||
{ XK_F30, XK_NO_MOD, "\033[17;5~", 0, 0}, | |||||
{ XK_F31, XK_NO_MOD, "\033[18;5~", 0, 0}, | |||||
{ XK_F32, XK_NO_MOD, "\033[19;5~", 0, 0}, | |||||
{ XK_F33, XK_NO_MOD, "\033[20;5~", 0, 0}, | |||||
{ XK_F34, XK_NO_MOD, "\033[21;5~", 0, 0}, | |||||
{ XK_F35, XK_NO_MOD, "\033[23;5~", 0, 0}, | |||||
}; | |||||
/* | |||||
* Selection types' masks. | |||||
* Use the same masks as usual. | |||||
* Button1Mask is always unset, to make masks match between ButtonPress. | |||||
* ButtonRelease and MotionNotify. | |||||
* If no match is found, regular selection is used. | |||||
*/ | |||||
static uint selmasks[] = { | |||||
[SEL_RECTANGULAR] = Mod1Mask, | |||||
}; | |||||
/* | |||||
* Printable characters in ASCII, used to estimate the advance width | |||||
* of single wide characters. | |||||
*/ | |||||
static char ascii_printable[] = | |||||
" !\"#$%&'()*+,-./0123456789:;<=>?" | |||||
"@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\\]^_" | |||||
"`abcdefghijklmnopqrstuvwxyz{|}~"; |
@@ -16,7 +16,7 @@ PKG_CONFIG = pkg-config | |||||
INCS = -I$(X11INC) \ | INCS = -I$(X11INC) \ | ||||
`$(PKG_CONFIG) --cflags fontconfig` \ | `$(PKG_CONFIG) --cflags fontconfig` \ | ||||
`$(PKG_CONFIG) --cflags freetype2` | `$(PKG_CONFIG) --cflags freetype2` | ||||
LIBS = -L$(X11LIB) -lm -lrt -lX11 -lutil -lXft \ | |||||
LIBS = -L$(X11LIB) -lm -lrt -lX11 -lutil -lXft -lXrender\ | |||||
`$(PKG_CONFIG) --libs fontconfig` \ | `$(PKG_CONFIG) --libs fontconfig` \ | ||||
`$(PKG_CONFIG) --libs freetype2` | `$(PKG_CONFIG) --libs freetype2` | ||||
@@ -123,3 +123,4 @@ extern char *termname; | |||||
extern unsigned int tabspaces; | extern unsigned int tabspaces; | ||||
extern unsigned int defaultfg; | extern unsigned int defaultfg; | ||||
extern unsigned int defaultbg; | extern unsigned int defaultbg; | ||||
extern float alpha; |
@@ -0,0 +1,125 @@ | |||||
/* See LICENSE for license details. */ | |||||
#include <stdint.h> | |||||
#include <sys/types.h> | |||||
/* macros */ | |||||
#define MIN(a, b) ((a) < (b) ? (a) : (b)) | |||||
#define MAX(a, b) ((a) < (b) ? (b) : (a)) | |||||
#define LEN(a) (sizeof(a) / sizeof(a)[0]) | |||||
#define BETWEEN(x, a, b) ((a) <= (x) && (x) <= (b)) | |||||
#define DIVCEIL(n, d) (((n) + ((d) - 1)) / (d)) | |||||
#define DEFAULT(a, b) (a) = (a) ? (a) : (b) | |||||
#define LIMIT(x, a, b) (x) = (x) < (a) ? (a) : (x) > (b) ? (b) : (x) | |||||
#define ATTRCMP(a, b) ((a).mode != (b).mode || (a).fg != (b).fg || \ | |||||
(a).bg != (b).bg) | |||||
#define TIMEDIFF(t1, t2) ((t1.tv_sec-t2.tv_sec)*1000 + \ | |||||
(t1.tv_nsec-t2.tv_nsec)/1E6) | |||||
#define MODBIT(x, set, bit) ((set) ? ((x) |= (bit)) : ((x) &= ~(bit))) | |||||
#define TRUECOLOR(r,g,b) (1 << 24 | (r) << 16 | (g) << 8 | (b)) | |||||
#define IS_TRUECOL(x) (1 << 24 & (x)) | |||||
enum glyph_attribute { | |||||
ATTR_NULL = 0, | |||||
ATTR_BOLD = 1 << 0, | |||||
ATTR_FAINT = 1 << 1, | |||||
ATTR_ITALIC = 1 << 2, | |||||
ATTR_UNDERLINE = 1 << 3, | |||||
ATTR_BLINK = 1 << 4, | |||||
ATTR_REVERSE = 1 << 5, | |||||
ATTR_INVISIBLE = 1 << 6, | |||||
ATTR_STRUCK = 1 << 7, | |||||
ATTR_WRAP = 1 << 8, | |||||
ATTR_WIDE = 1 << 9, | |||||
ATTR_WDUMMY = 1 << 10, | |||||
ATTR_BOLD_FAINT = ATTR_BOLD | ATTR_FAINT, | |||||
}; | |||||
enum selection_mode { | |||||
SEL_IDLE = 0, | |||||
SEL_EMPTY = 1, | |||||
SEL_READY = 2 | |||||
}; | |||||
enum selection_type { | |||||
SEL_REGULAR = 1, | |||||
SEL_RECTANGULAR = 2 | |||||
}; | |||||
enum selection_snap { | |||||
SNAP_WORD = 1, | |||||
SNAP_LINE = 2 | |||||
}; | |||||
typedef unsigned char uchar; | |||||
typedef unsigned int uint; | |||||
typedef unsigned long ulong; | |||||
typedef unsigned short ushort; | |||||
typedef uint_least32_t Rune; | |||||
#define Glyph Glyph_ | |||||
typedef struct { | |||||
Rune u; /* character code */ | |||||
ushort mode; /* attribute flags */ | |||||
uint32_t fg; /* foreground */ | |||||
uint32_t bg; /* background */ | |||||
} Glyph; | |||||
typedef Glyph *Line; | |||||
typedef union { | |||||
int i; | |||||
uint ui; | |||||
float f; | |||||
const void *v; | |||||
const char *s; | |||||
} Arg; | |||||
void die(const char *, ...); | |||||
void redraw(void); | |||||
void draw(void); | |||||
void printscreen(const Arg *); | |||||
void printsel(const Arg *); | |||||
void sendbreak(const Arg *); | |||||
void toggleprinter(const Arg *); | |||||
int tattrset(int); | |||||
void tnew(int, int); | |||||
void tresize(int, int); | |||||
void tsetdirtattr(int); | |||||
void ttyhangup(void); | |||||
int ttynew(char *, char *, char *, char **); | |||||
size_t ttyread(void); | |||||
void ttyresize(int, int); | |||||
void ttywrite(const char *, size_t, int); | |||||
void resettitle(void); | |||||
void selclear(void); | |||||
void selinit(void); | |||||
void selstart(int, int, int); | |||||
void selextend(int, int, int, int); | |||||
int selected(int, int); | |||||
char *getsel(void); | |||||
size_t utf8encode(Rune, char *); | |||||
void *xmalloc(size_t); | |||||
void *xrealloc(void *, size_t); | |||||
char *xstrdup(char *); | |||||
/* config.h globals */ | |||||
extern char *utmp; | |||||
extern char *scroll; | |||||
extern char *stty_args; | |||||
extern char *vtiden; | |||||
extern wchar_t *worddelimiters; | |||||
extern int allowaltscreen; | |||||
extern int allowwindowops; | |||||
extern char *termname; | |||||
extern unsigned int tabspaces; | |||||
extern unsigned int defaultfg; | |||||
extern unsigned int defaultbg; |
@@ -105,6 +105,7 @@ typedef struct { | |||||
XSetWindowAttributes attrs; | XSetWindowAttributes attrs; | ||||
int scr; | int scr; | ||||
int isfixed; /* is fixed geometry? */ | int isfixed; /* is fixed geometry? */ | ||||
int depth; /* bit depth */ | |||||
int l, t; /* left and top offset */ | int l, t; /* left and top offset */ | ||||
int gm; /* geometry mask */ | int gm; /* geometry mask */ | ||||
} XWindow; | } XWindow; | ||||
@@ -243,6 +244,7 @@ static char *usedfont = NULL; | |||||
static double usedfontsize = 0; | static double usedfontsize = 0; | ||||
static double defaultfontsize = 0; | static double defaultfontsize = 0; | ||||
static char *opt_alpha = NULL; | |||||
static char *opt_class = NULL; | static char *opt_class = NULL; | ||||
static char **opt_cmd = NULL; | static char **opt_cmd = NULL; | ||||
static char *opt_embed = NULL; | static char *opt_embed = NULL; | ||||
@@ -734,7 +736,7 @@ xresize(int col, int row) | |||||
XFreePixmap(xw.dpy, xw.buf); | XFreePixmap(xw.dpy, xw.buf); | ||||
xw.buf = XCreatePixmap(xw.dpy, xw.win, win.w, win.h, | xw.buf = XCreatePixmap(xw.dpy, xw.win, win.w, win.h, | ||||
DefaultDepth(xw.dpy, xw.scr)); | |||||
xw.depth); | |||||
XftDrawChange(xw.draw, xw.buf); | XftDrawChange(xw.draw, xw.buf); | ||||
xclear(0, 0, win.w, win.h); | xclear(0, 0, win.w, win.h); | ||||
@@ -794,6 +796,13 @@ xloadcols(void) | |||||
else | else | ||||
die("could not allocate color %d\n", i); | die("could not allocate color %d\n", i); | ||||
} | } | ||||
/* set alpha value of bg color */ | |||||
if (opt_alpha) | |||||
alpha = strtof(opt_alpha, NULL); | |||||
dc.col[defaultbg].color.alpha = (unsigned short)(0xffff * alpha); | |||||
dc.col[defaultbg].pixel &= 0x00FFFFFF; | |||||
dc.col[defaultbg].pixel |= (unsigned char)(0xff * alpha) << 24; | |||||
loaded = 1; | loaded = 1; | ||||
} | } | ||||
@@ -1103,11 +1112,23 @@ xinit(int cols, int rows) | |||||
Window parent; | Window parent; | ||||
pid_t thispid = getpid(); | pid_t thispid = getpid(); | ||||
XColor xmousefg, xmousebg; | XColor xmousefg, xmousebg; | ||||
XWindowAttributes attr; | |||||
XVisualInfo vis; | |||||
if (!(xw.dpy = XOpenDisplay(NULL))) | if (!(xw.dpy = XOpenDisplay(NULL))) | ||||
die("can't open display\n"); | die("can't open display\n"); | ||||
xw.scr = XDefaultScreen(xw.dpy); | xw.scr = XDefaultScreen(xw.dpy); | ||||
xw.vis = XDefaultVisual(xw.dpy, xw.scr); | |||||
if (!(opt_embed && (parent = strtol(opt_embed, NULL, 0)))) { | |||||
parent = XRootWindow(xw.dpy, xw.scr); | |||||
xw.depth = 32; | |||||
} else { | |||||
XGetWindowAttributes(xw.dpy, parent, &attr); | |||||
xw.depth = attr.depth; | |||||
} | |||||
XMatchVisualInfo(xw.dpy, xw.scr, xw.depth, TrueColor, &vis); | |||||
xw.vis = vis.visual; | |||||
/* font */ | /* font */ | ||||
if (!FcInit()) | if (!FcInit()) | ||||
@@ -1117,7 +1138,7 @@ xinit(int cols, int rows) | |||||
xloadfonts(usedfont, 0); | xloadfonts(usedfont, 0); | ||||
/* colors */ | /* colors */ | ||||
xw.cmap = XDefaultColormap(xw.dpy, xw.scr); | |||||
xw.cmap = XCreateColormap(xw.dpy, parent, xw.vis, None); | |||||
xloadcols(); | xloadcols(); | ||||
/* adjust fixed window geometry */ | /* adjust fixed window geometry */ | ||||
@@ -1137,19 +1158,15 @@ xinit(int cols, int rows) | |||||
| ButtonMotionMask | ButtonPressMask | ButtonReleaseMask; | | ButtonMotionMask | ButtonPressMask | ButtonReleaseMask; | ||||
xw.attrs.colormap = xw.cmap; | xw.attrs.colormap = xw.cmap; | ||||
if (!(opt_embed && (parent = strtol(opt_embed, NULL, 0)))) | |||||
parent = XRootWindow(xw.dpy, xw.scr); | |||||
xw.win = XCreateWindow(xw.dpy, parent, xw.l, xw.t, | xw.win = XCreateWindow(xw.dpy, parent, xw.l, xw.t, | ||||
win.w, win.h, 0, XDefaultDepth(xw.dpy, xw.scr), InputOutput, | |||||
win.w, win.h, 0, xw.depth, InputOutput, | |||||
xw.vis, CWBackPixel | CWBorderPixel | CWBitGravity | xw.vis, CWBackPixel | CWBorderPixel | CWBitGravity | ||||
| CWEventMask | CWColormap, &xw.attrs); | | CWEventMask | CWColormap, &xw.attrs); | ||||
memset(&gcvalues, 0, sizeof(gcvalues)); | memset(&gcvalues, 0, sizeof(gcvalues)); | ||||
gcvalues.graphics_exposures = False; | gcvalues.graphics_exposures = False; | ||||
dc.gc = XCreateGC(xw.dpy, parent, GCGraphicsExposures, | |||||
&gcvalues); | |||||
xw.buf = XCreatePixmap(xw.dpy, xw.win, win.w, win.h, | |||||
DefaultDepth(xw.dpy, xw.scr)); | |||||
xw.buf = XCreatePixmap(xw.dpy, xw.win, win.w, win.h, xw.depth); | |||||
dc.gc = XCreateGC(xw.dpy, xw.buf, GCGraphicsExposures, &gcvalues); | |||||
XSetForeground(xw.dpy, dc.gc, dc.col[defaultbg].pixel); | XSetForeground(xw.dpy, dc.gc, dc.col[defaultbg].pixel); | ||||
XFillRectangle(xw.dpy, xw.buf, dc.gc, 0, 0, win.w, win.h); | XFillRectangle(xw.dpy, xw.buf, dc.gc, 0, 0, win.w, win.h); | ||||
@@ -1988,6 +2005,9 @@ main(int argc, char *argv[]) | |||||
case 'a': | case 'a': | ||||
allowaltscreen = 0; | allowaltscreen = 0; | ||||
break; | break; | ||||
case 'A': | |||||
opt_alpha = EARGF(usage()); | |||||
break; | |||||
case 'c': | case 'c': | ||||
opt_class = EARGF(usage()); | opt_class = EARGF(usage()); | ||||
break; | break; | ||||