Compare commits
12 Commits
master
...
patch/exte
| Author | SHA1 | Date | |
|---|---|---|---|
| 5e05d55778 | |||
| c59a6fd91f | |||
| 744509ac52 | |||
| 794a018dff | |||
| 8cc8982740 | |||
| fb4fb20688 | |||
| e4935affa7 | |||
| e9b5b01835 | |||
| dd7105ce3d | |||
| e05109b935 | |||
| 87b0917743 | |||
| bff7104e0f |
2
Makefile
2
Makefile
@ -24,7 +24,7 @@ st: $(OBJ)
|
|||||||
$(CC) -o $@ $(OBJ) $(STLDFLAGS)
|
$(CC) -o $@ $(OBJ) $(STLDFLAGS)
|
||||||
|
|
||||||
clean:
|
clean:
|
||||||
rm -f st $(OBJ) st-$(VERSION).tar.gz
|
rm -f st $(OBJ) st-$(VERSION).tar.gz config.h
|
||||||
|
|
||||||
dist: clean
|
dist: clean
|
||||||
mkdir -p st-$(VERSION)
|
mkdir -p st-$(VERSION)
|
||||||
|
|||||||
530
config.def.h
530
config.def.h
@ -5,7 +5,7 @@
|
|||||||
*
|
*
|
||||||
* font: see http://freedesktop.org/software/fontconfig/fontconfig-user.html
|
* font: see http://freedesktop.org/software/fontconfig/fontconfig-user.html
|
||||||
*/
|
*/
|
||||||
static char *font = "Liberation Mono:pixelsize=12:antialias=true:autohint=true";
|
static char *font = "FiraCode Nerd Font:pixelsize=12:antialias=true:autohint=true";
|
||||||
static int borderpx = 2;
|
static int borderpx = 2;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -93,45 +93,39 @@ 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 */
|
||||||
"black",
|
[0] = "#282828", /* hard contrast: #1d2021 / soft contrast: #32302f */
|
||||||
"red3",
|
[1] = "#cc241d", /* red */
|
||||||
"green3",
|
[2] = "#98971a", /* green */
|
||||||
"yellow3",
|
[3] = "#d79921", /* yellow */
|
||||||
"blue2",
|
[4] = "#458588", /* blue */
|
||||||
"magenta3",
|
[5] = "#b16286", /* magenta */
|
||||||
"cyan3",
|
[6] = "#689d6a", /* cyan */
|
||||||
"gray90",
|
[7] = "#a89984", /* white */
|
||||||
|
|
||||||
/* 8 bright colors */
|
/* 8 bright colors */
|
||||||
"gray50",
|
[8] = "#928374", /* black */
|
||||||
"red",
|
[9] = "#fb4934", /* red */
|
||||||
"green",
|
[10] = "#b8bb26", /* green */
|
||||||
"yellow",
|
[11] = "#fabd2f", /* yellow */
|
||||||
"#5c5cff",
|
[12] = "#83a598", /* blue */
|
||||||
"magenta",
|
[13] = "#d3869b", /* magenta */
|
||||||
"cyan",
|
[14] = "#8ec07c", /* cyan */
|
||||||
"white",
|
[15] = "#ebdbb2", /* white */
|
||||||
|
|
||||||
[255] = 0,
|
|
||||||
|
|
||||||
/* more colors can be added after 255 to use with DefaultXX */
|
|
||||||
"#cccccc",
|
|
||||||
"#555555",
|
|
||||||
"gray90", /* default foreground colour */
|
|
||||||
"black", /* default background colour */
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Default colors (colorname index)
|
* Default colors (colorname index)
|
||||||
* foreground, background, cursor, reverse cursor
|
* foreground, background, cursor, reverse cursor
|
||||||
*/
|
*/
|
||||||
unsigned int defaultfg = 258;
|
unsigned int defaultfg = 15;
|
||||||
unsigned int defaultbg = 259;
|
unsigned int defaultbg = 0;
|
||||||
unsigned int defaultcs = 256;
|
unsigned int defaultcs = 15;
|
||||||
static unsigned int defaultrcs = 257;
|
static unsigned int defaultrcs = 257;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -175,32 +169,32 @@ static uint forcemousemod = ShiftMask;
|
|||||||
* Beware that overloading Button1 will disable the selection.
|
* Beware that overloading Button1 will disable the selection.
|
||||||
*/
|
*/
|
||||||
static MouseShortcut mshortcuts[] = {
|
static MouseShortcut mshortcuts[] = {
|
||||||
/* mask button function argument release */
|
/* mask button function argument release */
|
||||||
{ XK_ANY_MOD, Button2, selpaste, {.i = 0}, 1 },
|
{XK_ANY_MOD, Button2, selpaste, {.i = 0}, 1},
|
||||||
{ ShiftMask, Button4, ttysend, {.s = "\033[5;2~"} },
|
{ShiftMask, Button4, ttysend, {.s = "\033[5;2~"}},
|
||||||
{ XK_ANY_MOD, Button4, ttysend, {.s = "\031"} },
|
{XK_ANY_MOD, Button4, ttysend, {.s = "\031"}},
|
||||||
{ ShiftMask, Button5, ttysend, {.s = "\033[6;2~"} },
|
{ShiftMask, Button5, ttysend, {.s = "\033[6;2~"}},
|
||||||
{ XK_ANY_MOD, Button5, ttysend, {.s = "\005"} },
|
{XK_ANY_MOD, Button5, ttysend, {.s = "\005"}},
|
||||||
};
|
};
|
||||||
|
|
||||||
/* Internal keyboard shortcuts. */
|
/* Internal keyboard shortcuts. */
|
||||||
#define MODKEY Mod1Mask
|
#define MODKEY Mod1Mask
|
||||||
#define TERMMOD (ControlMask|ShiftMask)
|
#define TERMMOD (ControlMask | ShiftMask)
|
||||||
|
|
||||||
static Shortcut shortcuts[] = {
|
static Shortcut shortcuts[] = {
|
||||||
/* mask keysym function argument */
|
/* mask keysym function argument */
|
||||||
{ XK_ANY_MOD, XK_Break, sendbreak, {.i = 0} },
|
{XK_ANY_MOD, XK_Break, sendbreak, {.i = 0}},
|
||||||
{ ControlMask, XK_Print, toggleprinter, {.i = 0} },
|
{ControlMask, XK_Print, toggleprinter, {.i = 0}},
|
||||||
{ ShiftMask, XK_Print, printscreen, {.i = 0} },
|
{ShiftMask, XK_Print, printscreen, {.i = 0}},
|
||||||
{ XK_ANY_MOD, XK_Print, printsel, {.i = 0} },
|
{XK_ANY_MOD, XK_Print, printsel, {.i = 0}},
|
||||||
{ TERMMOD, XK_Prior, zoom, {.f = +1} },
|
{TERMMOD, XK_Prior, zoom, {.f = +1}},
|
||||||
{ TERMMOD, XK_Next, zoom, {.f = -1} },
|
{TERMMOD, XK_Next, zoom, {.f = -1}},
|
||||||
{ TERMMOD, XK_Home, zoomreset, {.f = 0} },
|
{TERMMOD, XK_Home, zoomreset, {.f = 0}},
|
||||||
{ TERMMOD, XK_C, clipcopy, {.i = 0} },
|
{TERMMOD, XK_C, clipcopy, {.i = 0}},
|
||||||
{ TERMMOD, XK_V, clippaste, {.i = 0} },
|
{TERMMOD, XK_V, clippaste, {.i = 0}},
|
||||||
{ TERMMOD, XK_Y, selpaste, {.i = 0} },
|
{TERMMOD, XK_Y, selpaste, {.i = 0}},
|
||||||
{ ShiftMask, XK_Insert, selpaste, {.i = 0} },
|
{ShiftMask, XK_Insert, selpaste, {.i = 0}},
|
||||||
{ TERMMOD, XK_Num_Lock, numlock, {.i = 0} },
|
{TERMMOD, XK_Num_Lock, numlock, {.i = 0}},
|
||||||
};
|
};
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -228,229 +222,229 @@ static Shortcut shortcuts[] = {
|
|||||||
* If you want keys other than the X11 function keys (0xFD00 - 0xFFFF)
|
* If you want keys other than the X11 function keys (0xFD00 - 0xFFFF)
|
||||||
* to be mapped below, add them to this array.
|
* to be mapped below, add them to this array.
|
||||||
*/
|
*/
|
||||||
static KeySym mappedkeys[] = { -1 };
|
static KeySym mappedkeys[] = {-1};
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* State bits to ignore when matching key or button events. By default,
|
* State bits to ignore when matching key or button events. By default,
|
||||||
* numlock (Mod2Mask) and keyboard layout (XK_SWITCH_MOD) are ignored.
|
* numlock (Mod2Mask) and keyboard layout (XK_SWITCH_MOD) are ignored.
|
||||||
*/
|
*/
|
||||||
static uint ignoremod = Mod2Mask|XK_SWITCH_MOD;
|
static uint ignoremod = Mod2Mask | XK_SWITCH_MOD;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* This is the huge key array which defines all compatibility to the Linux
|
* This is the huge key array which defines all compatibility to the Linux
|
||||||
* world. Please decide about changes wisely.
|
* world. Please decide about changes wisely.
|
||||||
*/
|
*/
|
||||||
static Key key[] = {
|
static Key key[] = {
|
||||||
/* keysym mask string appkey appcursor */
|
/* keysym mask string appkey appcursor */
|
||||||
{ XK_KP_Home, ShiftMask, "\033[2J", 0, -1},
|
{XK_KP_Home, ShiftMask, "\033[2J", 0, -1},
|
||||||
{ XK_KP_Home, ShiftMask, "\033[1;2H", 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[H", 0, -1},
|
||||||
{ XK_KP_Home, XK_ANY_MOD, "\033[1~", 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, "\033Ox", +1, 0},
|
||||||
{ XK_KP_Up, XK_ANY_MOD, "\033[A", 0, -1},
|
{XK_KP_Up, XK_ANY_MOD, "\033[A", 0, -1},
|
||||||
{ XK_KP_Up, XK_ANY_MOD, "\033OA", 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, "\033Or", +1, 0},
|
||||||
{ XK_KP_Down, XK_ANY_MOD, "\033[B", 0, -1},
|
{XK_KP_Down, XK_ANY_MOD, "\033[B", 0, -1},
|
||||||
{ XK_KP_Down, XK_ANY_MOD, "\033OB", 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, "\033Ot", +1, 0},
|
||||||
{ XK_KP_Left, XK_ANY_MOD, "\033[D", 0, -1},
|
{XK_KP_Left, XK_ANY_MOD, "\033[D", 0, -1},
|
||||||
{ XK_KP_Left, XK_ANY_MOD, "\033OD", 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, "\033Ov", +1, 0},
|
||||||
{ XK_KP_Right, XK_ANY_MOD, "\033[C", 0, -1},
|
{XK_KP_Right, XK_ANY_MOD, "\033[C", 0, -1},
|
||||||
{ XK_KP_Right, XK_ANY_MOD, "\033OC", 0, +1},
|
{XK_KP_Right, XK_ANY_MOD, "\033OC", 0, +1},
|
||||||
{ XK_KP_Prior, ShiftMask, "\033[5;2~", 0, 0},
|
{XK_KP_Prior, ShiftMask, "\033[5;2~", 0, 0},
|
||||||
{ XK_KP_Prior, XK_ANY_MOD, "\033[5~", 0, 0},
|
{XK_KP_Prior, XK_ANY_MOD, "\033[5~", 0, 0},
|
||||||
{ XK_KP_Begin, XK_ANY_MOD, "\033[E", 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[J", -1, 0},
|
||||||
{ XK_KP_End, ControlMask, "\033[1;5F", +1, 0},
|
{XK_KP_End, ControlMask, "\033[1;5F", +1, 0},
|
||||||
{ XK_KP_End, ShiftMask, "\033[K", -1, 0},
|
{XK_KP_End, ShiftMask, "\033[K", -1, 0},
|
||||||
{ XK_KP_End, ShiftMask, "\033[1;2F", +1, 0},
|
{XK_KP_End, ShiftMask, "\033[1;2F", +1, 0},
|
||||||
{ XK_KP_End, XK_ANY_MOD, "\033[4~", 0, 0},
|
{XK_KP_End, XK_ANY_MOD, "\033[4~", 0, 0},
|
||||||
{ XK_KP_Next, ShiftMask, "\033[6;2~", 0, 0},
|
{XK_KP_Next, ShiftMask, "\033[6;2~", 0, 0},
|
||||||
{ XK_KP_Next, XK_ANY_MOD, "\033[6~", 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[2;2~", +1, 0},
|
||||||
{ XK_KP_Insert, ShiftMask, "\033[4l", -1, 0},
|
{XK_KP_Insert, ShiftMask, "\033[4l", -1, 0},
|
||||||
{ XK_KP_Insert, ControlMask, "\033[L", -1, 0},
|
{XK_KP_Insert, ControlMask, "\033[L", -1, 0},
|
||||||
{ XK_KP_Insert, ControlMask, "\033[2;5~", +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[4h", -1, 0},
|
||||||
{ XK_KP_Insert, XK_ANY_MOD, "\033[2~", +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[M", -1, 0},
|
||||||
{ XK_KP_Delete, ControlMask, "\033[3;5~", +1, 0},
|
{XK_KP_Delete, ControlMask, "\033[3;5~", +1, 0},
|
||||||
{ XK_KP_Delete, ShiftMask, "\033[2K", -1, 0},
|
{XK_KP_Delete, ShiftMask, "\033[2K", -1, 0},
|
||||||
{ XK_KP_Delete, ShiftMask, "\033[3;2~", +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[P", -1, 0},
|
||||||
{ XK_KP_Delete, XK_ANY_MOD, "\033[3~", +1, 0},
|
{XK_KP_Delete, XK_ANY_MOD, "\033[3~", +1, 0},
|
||||||
{ XK_KP_Multiply, XK_ANY_MOD, "\033Oj", +2, 0},
|
{XK_KP_Multiply, XK_ANY_MOD, "\033Oj", +2, 0},
|
||||||
{ XK_KP_Add, XK_ANY_MOD, "\033Ok", +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, "\033OM", +2, 0},
|
||||||
{ XK_KP_Enter, XK_ANY_MOD, "\r", -1, 0},
|
{XK_KP_Enter, XK_ANY_MOD, "\r", -1, 0},
|
||||||
{ XK_KP_Subtract, XK_ANY_MOD, "\033Om", +2, 0},
|
{XK_KP_Subtract, XK_ANY_MOD, "\033Om", +2, 0},
|
||||||
{ XK_KP_Decimal, XK_ANY_MOD, "\033On", +2, 0},
|
{XK_KP_Decimal, XK_ANY_MOD, "\033On", +2, 0},
|
||||||
{ XK_KP_Divide, XK_ANY_MOD, "\033Oo", +2, 0},
|
{XK_KP_Divide, XK_ANY_MOD, "\033Oo", +2, 0},
|
||||||
{ XK_KP_0, XK_ANY_MOD, "\033Op", +2, 0},
|
{XK_KP_0, XK_ANY_MOD, "\033Op", +2, 0},
|
||||||
{ XK_KP_1, XK_ANY_MOD, "\033Oq", +2, 0},
|
{XK_KP_1, XK_ANY_MOD, "\033Oq", +2, 0},
|
||||||
{ XK_KP_2, XK_ANY_MOD, "\033Or", +2, 0},
|
{XK_KP_2, XK_ANY_MOD, "\033Or", +2, 0},
|
||||||
{ XK_KP_3, XK_ANY_MOD, "\033Os", +2, 0},
|
{XK_KP_3, XK_ANY_MOD, "\033Os", +2, 0},
|
||||||
{ XK_KP_4, XK_ANY_MOD, "\033Ot", +2, 0},
|
{XK_KP_4, XK_ANY_MOD, "\033Ot", +2, 0},
|
||||||
{ XK_KP_5, XK_ANY_MOD, "\033Ou", +2, 0},
|
{XK_KP_5, XK_ANY_MOD, "\033Ou", +2, 0},
|
||||||
{ XK_KP_6, XK_ANY_MOD, "\033Ov", +2, 0},
|
{XK_KP_6, XK_ANY_MOD, "\033Ov", +2, 0},
|
||||||
{ XK_KP_7, XK_ANY_MOD, "\033Ow", +2, 0},
|
{XK_KP_7, XK_ANY_MOD, "\033Ow", +2, 0},
|
||||||
{ XK_KP_8, XK_ANY_MOD, "\033Ox", +2, 0},
|
{XK_KP_8, XK_ANY_MOD, "\033Ox", +2, 0},
|
||||||
{ XK_KP_9, XK_ANY_MOD, "\033Oy", +2, 0},
|
{XK_KP_9, XK_ANY_MOD, "\033Oy", +2, 0},
|
||||||
{ XK_Up, ShiftMask, "\033[1;2A", 0, 0},
|
{XK_Up, ShiftMask, "\033[1;2A", 0, 0},
|
||||||
{ XK_Up, Mod1Mask, "\033[1;3A", 0, 0},
|
{XK_Up, Mod1Mask, "\033[1;3A", 0, 0},
|
||||||
{ XK_Up, ShiftMask|Mod1Mask,"\033[1;4A", 0, 0},
|
{XK_Up, ShiftMask | Mod1Mask, "\033[1;4A", 0, 0},
|
||||||
{ XK_Up, ControlMask, "\033[1;5A", 0, 0},
|
{XK_Up, ControlMask, "\033[1;5A", 0, 0},
|
||||||
{ XK_Up, ShiftMask|ControlMask,"\033[1;6A", 0, 0},
|
{XK_Up, ShiftMask | ControlMask, "\033[1;6A", 0, 0},
|
||||||
{ XK_Up, ControlMask|Mod1Mask,"\033[1;7A", 0, 0},
|
{XK_Up, ControlMask | Mod1Mask, "\033[1;7A", 0, 0},
|
||||||
{ XK_Up,ShiftMask|ControlMask|Mod1Mask,"\033[1;8A", 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, "\033[A", 0, -1},
|
||||||
{ XK_Up, XK_ANY_MOD, "\033OA", 0, +1},
|
{XK_Up, XK_ANY_MOD, "\033OA", 0, +1},
|
||||||
{ XK_Down, ShiftMask, "\033[1;2B", 0, 0},
|
{XK_Down, ShiftMask, "\033[1;2B", 0, 0},
|
||||||
{ XK_Down, Mod1Mask, "\033[1;3B", 0, 0},
|
{XK_Down, Mod1Mask, "\033[1;3B", 0, 0},
|
||||||
{ XK_Down, ShiftMask|Mod1Mask,"\033[1;4B", 0, 0},
|
{XK_Down, ShiftMask | Mod1Mask, "\033[1;4B", 0, 0},
|
||||||
{ XK_Down, ControlMask, "\033[1;5B", 0, 0},
|
{XK_Down, ControlMask, "\033[1;5B", 0, 0},
|
||||||
{ XK_Down, ShiftMask|ControlMask,"\033[1;6B", 0, 0},
|
{XK_Down, ShiftMask | ControlMask, "\033[1;6B", 0, 0},
|
||||||
{ XK_Down, ControlMask|Mod1Mask,"\033[1;7B", 0, 0},
|
{XK_Down, ControlMask | Mod1Mask, "\033[1;7B", 0, 0},
|
||||||
{ XK_Down,ShiftMask|ControlMask|Mod1Mask,"\033[1;8B",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, "\033[B", 0, -1},
|
||||||
{ XK_Down, XK_ANY_MOD, "\033OB", 0, +1},
|
{XK_Down, XK_ANY_MOD, "\033OB", 0, +1},
|
||||||
{ XK_Left, ShiftMask, "\033[1;2D", 0, 0},
|
{XK_Left, ShiftMask, "\033[1;2D", 0, 0},
|
||||||
{ XK_Left, Mod1Mask, "\033[1;3D", 0, 0},
|
{XK_Left, Mod1Mask, "\033[1;3D", 0, 0},
|
||||||
{ XK_Left, ShiftMask|Mod1Mask,"\033[1;4D", 0, 0},
|
{XK_Left, ShiftMask | Mod1Mask, "\033[1;4D", 0, 0},
|
||||||
{ XK_Left, ControlMask, "\033[1;5D", 0, 0},
|
{XK_Left, ControlMask, "\033[1;5D", 0, 0},
|
||||||
{ XK_Left, ShiftMask|ControlMask,"\033[1;6D", 0, 0},
|
{XK_Left, ShiftMask | ControlMask, "\033[1;6D", 0, 0},
|
||||||
{ XK_Left, ControlMask|Mod1Mask,"\033[1;7D", 0, 0},
|
{XK_Left, ControlMask | Mod1Mask, "\033[1;7D", 0, 0},
|
||||||
{ XK_Left,ShiftMask|ControlMask|Mod1Mask,"\033[1;8D",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, "\033[D", 0, -1},
|
||||||
{ XK_Left, XK_ANY_MOD, "\033OD", 0, +1},
|
{XK_Left, XK_ANY_MOD, "\033OD", 0, +1},
|
||||||
{ XK_Right, ShiftMask, "\033[1;2C", 0, 0},
|
{XK_Right, ShiftMask, "\033[1;2C", 0, 0},
|
||||||
{ XK_Right, Mod1Mask, "\033[1;3C", 0, 0},
|
{XK_Right, Mod1Mask, "\033[1;3C", 0, 0},
|
||||||
{ XK_Right, ShiftMask|Mod1Mask,"\033[1;4C", 0, 0},
|
{XK_Right, ShiftMask | Mod1Mask, "\033[1;4C", 0, 0},
|
||||||
{ XK_Right, ControlMask, "\033[1;5C", 0, 0},
|
{XK_Right, ControlMask, "\033[1;5C", 0, 0},
|
||||||
{ XK_Right, ShiftMask|ControlMask,"\033[1;6C", 0, 0},
|
{XK_Right, ShiftMask | ControlMask, "\033[1;6C", 0, 0},
|
||||||
{ XK_Right, ControlMask|Mod1Mask,"\033[1;7C", 0, 0},
|
{XK_Right, ControlMask | Mod1Mask, "\033[1;7C", 0, 0},
|
||||||
{ XK_Right,ShiftMask|ControlMask|Mod1Mask,"\033[1;8C",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, "\033[C", 0, -1},
|
||||||
{ XK_Right, XK_ANY_MOD, "\033OC", 0, +1},
|
{XK_Right, XK_ANY_MOD, "\033OC", 0, +1},
|
||||||
{ XK_ISO_Left_Tab, ShiftMask, "\033[Z", 0, 0},
|
{XK_ISO_Left_Tab, ShiftMask, "\033[Z", 0, 0},
|
||||||
{ XK_Return, Mod1Mask, "\033\r", 0, 0},
|
{XK_Return, Mod1Mask, "\033\r", 0, 0},
|
||||||
{ XK_Return, XK_ANY_MOD, "\r", 0, 0},
|
{XK_Return, XK_ANY_MOD, "\r", 0, 0},
|
||||||
{ XK_Insert, ShiftMask, "\033[4l", -1, 0},
|
{XK_Insert, ShiftMask, "\033[4l", -1, 0},
|
||||||
{ XK_Insert, ShiftMask, "\033[2;2~", +1, 0},
|
{XK_Insert, ShiftMask, "\033[2;2~", +1, 0},
|
||||||
{ XK_Insert, ControlMask, "\033[L", -1, 0},
|
{XK_Insert, ControlMask, "\033[L", -1, 0},
|
||||||
{ XK_Insert, ControlMask, "\033[2;5~", +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[4h", -1, 0},
|
||||||
{ XK_Insert, XK_ANY_MOD, "\033[2~", +1, 0},
|
{XK_Insert, XK_ANY_MOD, "\033[2~", +1, 0},
|
||||||
{ XK_Delete, ControlMask, "\033[M", -1, 0},
|
{XK_Delete, ControlMask, "\033[M", -1, 0},
|
||||||
{ XK_Delete, ControlMask, "\033[3;5~", +1, 0},
|
{XK_Delete, ControlMask, "\033[3;5~", +1, 0},
|
||||||
{ XK_Delete, ShiftMask, "\033[2K", -1, 0},
|
{XK_Delete, ShiftMask, "\033[2K", -1, 0},
|
||||||
{ XK_Delete, ShiftMask, "\033[3;2~", +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[P", -1, 0},
|
||||||
{ XK_Delete, XK_ANY_MOD, "\033[3~", +1, 0},
|
{XK_Delete, XK_ANY_MOD, "\033[3~", +1, 0},
|
||||||
{ XK_BackSpace, XK_NO_MOD, "\177", 0, 0},
|
{XK_BackSpace, XK_NO_MOD, "\177", 0, 0},
|
||||||
{ XK_BackSpace, Mod1Mask, "\033\177", 0, 0},
|
{XK_BackSpace, Mod1Mask, "\033\177", 0, 0},
|
||||||
{ XK_Home, ShiftMask, "\033[2J", 0, -1},
|
{XK_Home, ShiftMask, "\033[2J", 0, -1},
|
||||||
{ XK_Home, ShiftMask, "\033[1;2H", 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[H", 0, -1},
|
||||||
{ XK_Home, XK_ANY_MOD, "\033[1~", 0, +1},
|
{XK_Home, XK_ANY_MOD, "\033[1~", 0, +1},
|
||||||
{ XK_End, ControlMask, "\033[J", -1, 0},
|
{XK_End, ControlMask, "\033[J", -1, 0},
|
||||||
{ XK_End, ControlMask, "\033[1;5F", +1, 0},
|
{XK_End, ControlMask, "\033[1;5F", +1, 0},
|
||||||
{ XK_End, ShiftMask, "\033[K", -1, 0},
|
{XK_End, ShiftMask, "\033[K", -1, 0},
|
||||||
{ XK_End, ShiftMask, "\033[1;2F", +1, 0},
|
{XK_End, ShiftMask, "\033[1;2F", +1, 0},
|
||||||
{ XK_End, XK_ANY_MOD, "\033[4~", 0, 0},
|
{XK_End, XK_ANY_MOD, "\033[4~", 0, 0},
|
||||||
{ XK_Prior, ControlMask, "\033[5;5~", 0, 0},
|
{XK_Prior, ControlMask, "\033[5;5~", 0, 0},
|
||||||
{ XK_Prior, ShiftMask, "\033[5;2~", 0, 0},
|
{XK_Prior, ShiftMask, "\033[5;2~", 0, 0},
|
||||||
{ XK_Prior, XK_ANY_MOD, "\033[5~", 0, 0},
|
{XK_Prior, XK_ANY_MOD, "\033[5~", 0, 0},
|
||||||
{ XK_Next, ControlMask, "\033[6;5~", 0, 0},
|
{XK_Next, ControlMask, "\033[6;5~", 0, 0},
|
||||||
{ XK_Next, ShiftMask, "\033[6;2~", 0, 0},
|
{XK_Next, ShiftMask, "\033[6;2~", 0, 0},
|
||||||
{ XK_Next, XK_ANY_MOD, "\033[6~", 0, 0},
|
{XK_Next, XK_ANY_MOD, "\033[6~", 0, 0},
|
||||||
{ XK_F1, XK_NO_MOD, "\033OP" , 0, 0},
|
{XK_F1, XK_NO_MOD, "\033OP", 0, 0},
|
||||||
{ XK_F1, /* F13 */ ShiftMask, "\033[1;2P", 0, 0},
|
{XK_F1, /* F13 */ ShiftMask, "\033[1;2P", 0, 0},
|
||||||
{ XK_F1, /* F25 */ ControlMask, "\033[1;5P", 0, 0},
|
{XK_F1, /* F25 */ ControlMask, "\033[1;5P", 0, 0},
|
||||||
{ XK_F1, /* F37 */ Mod4Mask, "\033[1;6P", 0, 0},
|
{XK_F1, /* F37 */ Mod4Mask, "\033[1;6P", 0, 0},
|
||||||
{ XK_F1, /* F49 */ Mod1Mask, "\033[1;3P", 0, 0},
|
{XK_F1, /* F49 */ Mod1Mask, "\033[1;3P", 0, 0},
|
||||||
{ XK_F1, /* F61 */ Mod3Mask, "\033[1;4P", 0, 0},
|
{XK_F1, /* F61 */ Mod3Mask, "\033[1;4P", 0, 0},
|
||||||
{ XK_F2, XK_NO_MOD, "\033OQ" , 0, 0},
|
{XK_F2, XK_NO_MOD, "\033OQ", 0, 0},
|
||||||
{ XK_F2, /* F14 */ ShiftMask, "\033[1;2Q", 0, 0},
|
{XK_F2, /* F14 */ ShiftMask, "\033[1;2Q", 0, 0},
|
||||||
{ XK_F2, /* F26 */ ControlMask, "\033[1;5Q", 0, 0},
|
{XK_F2, /* F26 */ ControlMask, "\033[1;5Q", 0, 0},
|
||||||
{ XK_F2, /* F38 */ Mod4Mask, "\033[1;6Q", 0, 0},
|
{XK_F2, /* F38 */ Mod4Mask, "\033[1;6Q", 0, 0},
|
||||||
{ XK_F2, /* F50 */ Mod1Mask, "\033[1;3Q", 0, 0},
|
{XK_F2, /* F50 */ Mod1Mask, "\033[1;3Q", 0, 0},
|
||||||
{ XK_F2, /* F62 */ Mod3Mask, "\033[1;4Q", 0, 0},
|
{XK_F2, /* F62 */ Mod3Mask, "\033[1;4Q", 0, 0},
|
||||||
{ XK_F3, XK_NO_MOD, "\033OR" , 0, 0},
|
{XK_F3, XK_NO_MOD, "\033OR", 0, 0},
|
||||||
{ XK_F3, /* F15 */ ShiftMask, "\033[1;2R", 0, 0},
|
{XK_F3, /* F15 */ ShiftMask, "\033[1;2R", 0, 0},
|
||||||
{ XK_F3, /* F27 */ ControlMask, "\033[1;5R", 0, 0},
|
{XK_F3, /* F27 */ ControlMask, "\033[1;5R", 0, 0},
|
||||||
{ XK_F3, /* F39 */ Mod4Mask, "\033[1;6R", 0, 0},
|
{XK_F3, /* F39 */ Mod4Mask, "\033[1;6R", 0, 0},
|
||||||
{ XK_F3, /* F51 */ Mod1Mask, "\033[1;3R", 0, 0},
|
{XK_F3, /* F51 */ Mod1Mask, "\033[1;3R", 0, 0},
|
||||||
{ XK_F3, /* F63 */ Mod3Mask, "\033[1;4R", 0, 0},
|
{XK_F3, /* F63 */ Mod3Mask, "\033[1;4R", 0, 0},
|
||||||
{ XK_F4, XK_NO_MOD, "\033OS" , 0, 0},
|
{XK_F4, XK_NO_MOD, "\033OS", 0, 0},
|
||||||
{ XK_F4, /* F16 */ ShiftMask, "\033[1;2S", 0, 0},
|
{XK_F4, /* F16 */ ShiftMask, "\033[1;2S", 0, 0},
|
||||||
{ XK_F4, /* F28 */ ControlMask, "\033[1;5S", 0, 0},
|
{XK_F4, /* F28 */ ControlMask, "\033[1;5S", 0, 0},
|
||||||
{ XK_F4, /* F40 */ Mod4Mask, "\033[1;6S", 0, 0},
|
{XK_F4, /* F40 */ Mod4Mask, "\033[1;6S", 0, 0},
|
||||||
{ XK_F4, /* F52 */ Mod1Mask, "\033[1;3S", 0, 0},
|
{XK_F4, /* F52 */ Mod1Mask, "\033[1;3S", 0, 0},
|
||||||
{ XK_F5, XK_NO_MOD, "\033[15~", 0, 0},
|
{XK_F5, XK_NO_MOD, "\033[15~", 0, 0},
|
||||||
{ XK_F5, /* F17 */ ShiftMask, "\033[15;2~", 0, 0},
|
{XK_F5, /* F17 */ ShiftMask, "\033[15;2~", 0, 0},
|
||||||
{ XK_F5, /* F29 */ ControlMask, "\033[15;5~", 0, 0},
|
{XK_F5, /* F29 */ ControlMask, "\033[15;5~", 0, 0},
|
||||||
{ XK_F5, /* F41 */ Mod4Mask, "\033[15;6~", 0, 0},
|
{XK_F5, /* F41 */ Mod4Mask, "\033[15;6~", 0, 0},
|
||||||
{ XK_F5, /* F53 */ Mod1Mask, "\033[15;3~", 0, 0},
|
{XK_F5, /* F53 */ Mod1Mask, "\033[15;3~", 0, 0},
|
||||||
{ XK_F6, XK_NO_MOD, "\033[17~", 0, 0},
|
{XK_F6, XK_NO_MOD, "\033[17~", 0, 0},
|
||||||
{ XK_F6, /* F18 */ ShiftMask, "\033[17;2~", 0, 0},
|
{XK_F6, /* F18 */ ShiftMask, "\033[17;2~", 0, 0},
|
||||||
{ XK_F6, /* F30 */ ControlMask, "\033[17;5~", 0, 0},
|
{XK_F6, /* F30 */ ControlMask, "\033[17;5~", 0, 0},
|
||||||
{ XK_F6, /* F42 */ Mod4Mask, "\033[17;6~", 0, 0},
|
{XK_F6, /* F42 */ Mod4Mask, "\033[17;6~", 0, 0},
|
||||||
{ XK_F6, /* F54 */ Mod1Mask, "\033[17;3~", 0, 0},
|
{XK_F6, /* F54 */ Mod1Mask, "\033[17;3~", 0, 0},
|
||||||
{ XK_F7, XK_NO_MOD, "\033[18~", 0, 0},
|
{XK_F7, XK_NO_MOD, "\033[18~", 0, 0},
|
||||||
{ XK_F7, /* F19 */ ShiftMask, "\033[18;2~", 0, 0},
|
{XK_F7, /* F19 */ ShiftMask, "\033[18;2~", 0, 0},
|
||||||
{ XK_F7, /* F31 */ ControlMask, "\033[18;5~", 0, 0},
|
{XK_F7, /* F31 */ ControlMask, "\033[18;5~", 0, 0},
|
||||||
{ XK_F7, /* F43 */ Mod4Mask, "\033[18;6~", 0, 0},
|
{XK_F7, /* F43 */ Mod4Mask, "\033[18;6~", 0, 0},
|
||||||
{ XK_F7, /* F55 */ Mod1Mask, "\033[18;3~", 0, 0},
|
{XK_F7, /* F55 */ Mod1Mask, "\033[18;3~", 0, 0},
|
||||||
{ XK_F8, XK_NO_MOD, "\033[19~", 0, 0},
|
{XK_F8, XK_NO_MOD, "\033[19~", 0, 0},
|
||||||
{ XK_F8, /* F20 */ ShiftMask, "\033[19;2~", 0, 0},
|
{XK_F8, /* F20 */ ShiftMask, "\033[19;2~", 0, 0},
|
||||||
{ XK_F8, /* F32 */ ControlMask, "\033[19;5~", 0, 0},
|
{XK_F8, /* F32 */ ControlMask, "\033[19;5~", 0, 0},
|
||||||
{ XK_F8, /* F44 */ Mod4Mask, "\033[19;6~", 0, 0},
|
{XK_F8, /* F44 */ Mod4Mask, "\033[19;6~", 0, 0},
|
||||||
{ XK_F8, /* F56 */ Mod1Mask, "\033[19;3~", 0, 0},
|
{XK_F8, /* F56 */ Mod1Mask, "\033[19;3~", 0, 0},
|
||||||
{ XK_F9, XK_NO_MOD, "\033[20~", 0, 0},
|
{XK_F9, XK_NO_MOD, "\033[20~", 0, 0},
|
||||||
{ XK_F9, /* F21 */ ShiftMask, "\033[20;2~", 0, 0},
|
{XK_F9, /* F21 */ ShiftMask, "\033[20;2~", 0, 0},
|
||||||
{ XK_F9, /* F33 */ ControlMask, "\033[20;5~", 0, 0},
|
{XK_F9, /* F33 */ ControlMask, "\033[20;5~", 0, 0},
|
||||||
{ XK_F9, /* F45 */ Mod4Mask, "\033[20;6~", 0, 0},
|
{XK_F9, /* F45 */ Mod4Mask, "\033[20;6~", 0, 0},
|
||||||
{ XK_F9, /* F57 */ Mod1Mask, "\033[20;3~", 0, 0},
|
{XK_F9, /* F57 */ Mod1Mask, "\033[20;3~", 0, 0},
|
||||||
{ XK_F10, XK_NO_MOD, "\033[21~", 0, 0},
|
{XK_F10, XK_NO_MOD, "\033[21~", 0, 0},
|
||||||
{ XK_F10, /* F22 */ ShiftMask, "\033[21;2~", 0, 0},
|
{XK_F10, /* F22 */ ShiftMask, "\033[21;2~", 0, 0},
|
||||||
{ XK_F10, /* F34 */ ControlMask, "\033[21;5~", 0, 0},
|
{XK_F10, /* F34 */ ControlMask, "\033[21;5~", 0, 0},
|
||||||
{ XK_F10, /* F46 */ Mod4Mask, "\033[21;6~", 0, 0},
|
{XK_F10, /* F46 */ Mod4Mask, "\033[21;6~", 0, 0},
|
||||||
{ XK_F10, /* F58 */ Mod1Mask, "\033[21;3~", 0, 0},
|
{XK_F10, /* F58 */ Mod1Mask, "\033[21;3~", 0, 0},
|
||||||
{ XK_F11, XK_NO_MOD, "\033[23~", 0, 0},
|
{XK_F11, XK_NO_MOD, "\033[23~", 0, 0},
|
||||||
{ XK_F11, /* F23 */ ShiftMask, "\033[23;2~", 0, 0},
|
{XK_F11, /* F23 */ ShiftMask, "\033[23;2~", 0, 0},
|
||||||
{ XK_F11, /* F35 */ ControlMask, "\033[23;5~", 0, 0},
|
{XK_F11, /* F35 */ ControlMask, "\033[23;5~", 0, 0},
|
||||||
{ XK_F11, /* F47 */ Mod4Mask, "\033[23;6~", 0, 0},
|
{XK_F11, /* F47 */ Mod4Mask, "\033[23;6~", 0, 0},
|
||||||
{ XK_F11, /* F59 */ Mod1Mask, "\033[23;3~", 0, 0},
|
{XK_F11, /* F59 */ Mod1Mask, "\033[23;3~", 0, 0},
|
||||||
{ XK_F12, XK_NO_MOD, "\033[24~", 0, 0},
|
{XK_F12, XK_NO_MOD, "\033[24~", 0, 0},
|
||||||
{ XK_F12, /* F24 */ ShiftMask, "\033[24;2~", 0, 0},
|
{XK_F12, /* F24 */ ShiftMask, "\033[24;2~", 0, 0},
|
||||||
{ XK_F12, /* F36 */ ControlMask, "\033[24;5~", 0, 0},
|
{XK_F12, /* F36 */ ControlMask, "\033[24;5~", 0, 0},
|
||||||
{ XK_F12, /* F48 */ Mod4Mask, "\033[24;6~", 0, 0},
|
{XK_F12, /* F48 */ Mod4Mask, "\033[24;6~", 0, 0},
|
||||||
{ XK_F12, /* F60 */ Mod1Mask, "\033[24;3~", 0, 0},
|
{XK_F12, /* F60 */ Mod1Mask, "\033[24;3~", 0, 0},
|
||||||
{ XK_F13, XK_NO_MOD, "\033[1;2P", 0, 0},
|
{XK_F13, XK_NO_MOD, "\033[1;2P", 0, 0},
|
||||||
{ XK_F14, XK_NO_MOD, "\033[1;2Q", 0, 0},
|
{XK_F14, XK_NO_MOD, "\033[1;2Q", 0, 0},
|
||||||
{ XK_F15, XK_NO_MOD, "\033[1;2R", 0, 0},
|
{XK_F15, XK_NO_MOD, "\033[1;2R", 0, 0},
|
||||||
{ XK_F16, XK_NO_MOD, "\033[1;2S", 0, 0},
|
{XK_F16, XK_NO_MOD, "\033[1;2S", 0, 0},
|
||||||
{ XK_F17, XK_NO_MOD, "\033[15;2~", 0, 0},
|
{XK_F17, XK_NO_MOD, "\033[15;2~", 0, 0},
|
||||||
{ XK_F18, XK_NO_MOD, "\033[17;2~", 0, 0},
|
{XK_F18, XK_NO_MOD, "\033[17;2~", 0, 0},
|
||||||
{ XK_F19, XK_NO_MOD, "\033[18;2~", 0, 0},
|
{XK_F19, XK_NO_MOD, "\033[18;2~", 0, 0},
|
||||||
{ XK_F20, XK_NO_MOD, "\033[19;2~", 0, 0},
|
{XK_F20, XK_NO_MOD, "\033[19;2~", 0, 0},
|
||||||
{ XK_F21, XK_NO_MOD, "\033[20;2~", 0, 0},
|
{XK_F21, XK_NO_MOD, "\033[20;2~", 0, 0},
|
||||||
{ XK_F22, XK_NO_MOD, "\033[21;2~", 0, 0},
|
{XK_F22, XK_NO_MOD, "\033[21;2~", 0, 0},
|
||||||
{ XK_F23, XK_NO_MOD, "\033[23;2~", 0, 0},
|
{XK_F23, XK_NO_MOD, "\033[23;2~", 0, 0},
|
||||||
{ XK_F24, XK_NO_MOD, "\033[24;2~", 0, 0},
|
{XK_F24, XK_NO_MOD, "\033[24;2~", 0, 0},
|
||||||
{ XK_F25, XK_NO_MOD, "\033[1;5P", 0, 0},
|
{XK_F25, XK_NO_MOD, "\033[1;5P", 0, 0},
|
||||||
{ XK_F26, XK_NO_MOD, "\033[1;5Q", 0, 0},
|
{XK_F26, XK_NO_MOD, "\033[1;5Q", 0, 0},
|
||||||
{ XK_F27, XK_NO_MOD, "\033[1;5R", 0, 0},
|
{XK_F27, XK_NO_MOD, "\033[1;5R", 0, 0},
|
||||||
{ XK_F28, XK_NO_MOD, "\033[1;5S", 0, 0},
|
{XK_F28, XK_NO_MOD, "\033[1;5S", 0, 0},
|
||||||
{ XK_F29, XK_NO_MOD, "\033[15;5~", 0, 0},
|
{XK_F29, XK_NO_MOD, "\033[15;5~", 0, 0},
|
||||||
{ XK_F30, XK_NO_MOD, "\033[17;5~", 0, 0},
|
{XK_F30, XK_NO_MOD, "\033[17;5~", 0, 0},
|
||||||
{ XK_F31, XK_NO_MOD, "\033[18;5~", 0, 0},
|
{XK_F31, XK_NO_MOD, "\033[18;5~", 0, 0},
|
||||||
{ XK_F32, XK_NO_MOD, "\033[19;5~", 0, 0},
|
{XK_F32, XK_NO_MOD, "\033[19;5~", 0, 0},
|
||||||
{ XK_F33, XK_NO_MOD, "\033[20;5~", 0, 0},
|
{XK_F33, XK_NO_MOD, "\033[20;5~", 0, 0},
|
||||||
{ XK_F34, XK_NO_MOD, "\033[21;5~", 0, 0},
|
{XK_F34, XK_NO_MOD, "\033[21;5~", 0, 0},
|
||||||
{ XK_F35, XK_NO_MOD, "\033[23;5~", 0, 0},
|
{XK_F35, XK_NO_MOD, "\033[23;5~", 0, 0},
|
||||||
};
|
};
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -461,14 +455,14 @@ static Key key[] = {
|
|||||||
* If no match is found, regular selection is used.
|
* If no match is found, regular selection is used.
|
||||||
*/
|
*/
|
||||||
static uint selmasks[] = {
|
static uint selmasks[] = {
|
||||||
[SEL_RECTANGULAR] = Mod1Mask,
|
[SEL_RECTANGULAR] = Mod1Mask,
|
||||||
};
|
};
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Printable characters in ASCII, used to estimate the advance width
|
* Printable characters in ASCII, used to estimate the advance width
|
||||||
* of single wide characters.
|
* of single wide characters.
|
||||||
*/
|
*/
|
||||||
static char ascii_printable[] =
|
static char ascii_printable[] = " !\"#$%&'()*+,-./0123456789:;<=>?"
|
||||||
" !\"#$%&'()*+,-./0123456789:;<=>?"
|
"@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\\]^_"
|
||||||
"@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\\]^_"
|
"`abcdefghijklmnopqrstuvwxyz{|}~";
|
||||||
"`abcdefghijklmnopqrstuvwxyz{|}~";
|
|
||||||
|
|||||||
129
st-alpha-20240814-a0274bc.diff
Normal file
129
st-alpha-20240814-a0274bc.diff
Normal file
@ -0,0 +1,129 @@
|
|||||||
|
diff --git a/config.def.h b/config.def.h
|
||||||
|
index 2cd740a..019a4e1 100644
|
||||||
|
--- a/config.def.h
|
||||||
|
+++ b/config.def.h
|
||||||
|
@@ -93,6 +93,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 */
|
||||||
|
diff --git a/x.c b/x.c
|
||||||
|
index d73152b..f32fd6c 100644
|
||||||
|
--- a/x.c
|
||||||
|
+++ b/x.c
|
||||||
|
@@ -105,6 +105,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;
|
||||||
|
@@ -752,7 +753,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);
|
||||||
|
|
||||||
|
@@ -812,6 +813,10 @@ xloadcols(void)
|
||||||
|
else
|
||||||
|
die("could not allocate color %d\n", i);
|
||||||
|
}
|
||||||
|
+
|
||||||
|
+ 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;
|
||||||
|
}
|
||||||
|
|
||||||
|
@@ -842,6 +847,12 @@ xsetcolorname(int x, const char *name)
|
||||||
|
XftColorFree(xw.dpy, xw.vis, xw.cmap, &dc.col[x]);
|
||||||
|
dc.col[x] = ncolor;
|
||||||
|
|
||||||
|
+ if (x == defaultbg) {
|
||||||
|
+ dc.col[defaultbg].color.alpha = (unsigned short)(0xffff * alpha);
|
||||||
|
+ dc.col[defaultbg].pixel &= 0x00FFFFFF;
|
||||||
|
+ dc.col[defaultbg].pixel |= (unsigned char)(0xff * alpha) << 24;
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
@@ -1134,11 +1145,25 @@ xinit(int cols, int rows)
|
||||||
|
Window parent, root;
|
||||||
|
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);
|
||||||
|
+
|
||||||
|
+ root = XRootWindow(xw.dpy, xw.scr);
|
||||||
|
+ if (!(opt_embed && (parent = strtol(opt_embed, NULL, 0))))
|
||||||
|
+ parent = root;
|
||||||
|
+
|
||||||
|
+ if (XMatchVisualInfo(xw.dpy, xw.scr, 32, TrueColor, &vis) != 0) {
|
||||||
|
+ xw.vis = vis.visual;
|
||||||
|
+ xw.depth = vis.depth;
|
||||||
|
+ } else {
|
||||||
|
+ XGetWindowAttributes(xw.dpy, parent, &attr);
|
||||||
|
+ xw.vis = attr.visual;
|
||||||
|
+ xw.depth = attr.depth;
|
||||||
|
+ }
|
||||||
|
|
||||||
|
/* font */
|
||||||
|
if (!FcInit())
|
||||||
|
@@ -1148,7 +1173,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 */
|
||||||
|
@@ -1168,11 +1193,8 @@ xinit(int cols, int rows)
|
||||||
|
| ButtonMotionMask | ButtonPressMask | ButtonReleaseMask;
|
||||||
|
xw.attrs.colormap = xw.cmap;
|
||||||
|
|
||||||
|
- root = XRootWindow(xw.dpy, xw.scr);
|
||||||
|
- if (!(opt_embed && (parent = strtol(opt_embed, NULL, 0))))
|
||||||
|
- parent = root;
|
||||||
|
- xw.win = XCreateWindow(xw.dpy, root, xw.l, xw.t,
|
||||||
|
- win.w, win.h, 0, XDefaultDepth(xw.dpy, xw.scr), InputOutput,
|
||||||
|
+ xw.win = XCreateWindow(xw.dpy, parent, xw.l, xw.t,
|
||||||
|
+ win.w, win.h, 0, xw.depth, InputOutput,
|
||||||
|
xw.vis, CWBackPixel | CWBorderPixel | CWBitGravity
|
||||||
|
| CWEventMask | CWColormap, &xw.attrs);
|
||||||
|
if (parent != root)
|
||||||
|
@@ -1183,7 +1205,7 @@ xinit(int cols, int rows)
|
||||||
|
dc.gc = XCreateGC(xw.dpy, xw.win, GCGraphicsExposures,
|
||||||
|
&gcvalues);
|
||||||
|
xw.buf = XCreatePixmap(xw.dpy, xw.win, win.w, win.h,
|
||||||
|
- DefaultDepth(xw.dpy, xw.scr));
|
||||||
|
+ xw.depth);
|
||||||
|
XSetForeground(xw.dpy, dc.gc, dc.col[defaultbg].pixel);
|
||||||
|
XFillRectangle(xw.dpy, xw.buf, dc.gc, 0, 0, win.w, win.h);
|
||||||
|
|
||||||
|
@@ -2047,6 +2069,10 @@ main(int argc, char *argv[])
|
||||||
|
case 'a':
|
||||||
|
allowaltscreen = 0;
|
||||||
|
break;
|
||||||
|
+ case 'A':
|
||||||
|
+ alpha = strtof(EARGF(usage()), NULL);
|
||||||
|
+ LIMIT(alpha, 0.0, 1.0);
|
||||||
|
+ break;
|
||||||
|
case 'c':
|
||||||
|
opt_class = EARGF(usage());
|
||||||
|
break;
|
||||||
12
st-clipboard-0.8.3.diff
Normal file
12
st-clipboard-0.8.3.diff
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
diff --git a/x.c b/x.c
|
||||||
|
index e5f1737..5cabd60 100644
|
||||||
|
--- a/x.c
|
||||||
|
+++ b/x.c
|
||||||
|
@@ -673,6 +673,7 @@ setsel(char *str, Time t)
|
||||||
|
XSetSelectionOwner(xw.dpy, XA_PRIMARY, xw.win, t);
|
||||||
|
if (XGetSelectionOwner(xw.dpy, XA_PRIMARY) != xw.win)
|
||||||
|
selclear();
|
||||||
|
+ clipcopy(NULL);
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
104
st-externalpipe-0.8.5.diff
Normal file
104
st-externalpipe-0.8.5.diff
Normal file
@ -0,0 +1,104 @@
|
|||||||
|
diff --git a/st.c b/st.c
|
||||||
|
index 034954d..98f2589 100644
|
||||||
|
--- a/st.c
|
||||||
|
+++ b/st.c
|
||||||
|
@@ -718,8 +718,14 @@ sigchld(int a)
|
||||||
|
if ((p = waitpid(pid, &stat, WNOHANG)) < 0)
|
||||||
|
die("waiting for pid %hd failed: %s\n", pid, strerror(errno));
|
||||||
|
|
||||||
|
- if (pid != p)
|
||||||
|
+ if (pid != p) {
|
||||||
|
+ if (p == 0 && wait(&stat) < 0)
|
||||||
|
+ die("wait: %s\n", strerror(errno));
|
||||||
|
+
|
||||||
|
+ /* reinstall sigchld handler */
|
||||||
|
+ signal(SIGCHLD, sigchld);
|
||||||
|
return;
|
||||||
|
+ }
|
||||||
|
|
||||||
|
if (WIFEXITED(stat) && WEXITSTATUS(stat))
|
||||||
|
die("child exited with status %d\n", WEXITSTATUS(stat));
|
||||||
|
@@ -803,7 +809,7 @@ ttynew(const char *line, char *cmd, const char *out, char **args)
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
#ifdef __OpenBSD__
|
||||||
|
- if (pledge("stdio rpath tty proc", NULL) == -1)
|
||||||
|
+ if (pledge("stdio rpath tty proc exec", NULL) == -1)
|
||||||
|
die("pledge\n");
|
||||||
|
#endif
|
||||||
|
close(s);
|
||||||
|
@@ -1991,6 +1997,59 @@ strparse(void)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
+void
|
||||||
|
+externalpipe(const Arg *arg)
|
||||||
|
+{
|
||||||
|
+ int to[2];
|
||||||
|
+ char buf[UTF_SIZ];
|
||||||
|
+ void (*oldsigpipe)(int);
|
||||||
|
+ Glyph *bp, *end;
|
||||||
|
+ int lastpos, n, newline;
|
||||||
|
+
|
||||||
|
+ if (pipe(to) == -1)
|
||||||
|
+ return;
|
||||||
|
+
|
||||||
|
+ switch (fork()) {
|
||||||
|
+ case -1:
|
||||||
|
+ close(to[0]);
|
||||||
|
+ close(to[1]);
|
||||||
|
+ return;
|
||||||
|
+ case 0:
|
||||||
|
+ dup2(to[0], STDIN_FILENO);
|
||||||
|
+ close(to[0]);
|
||||||
|
+ close(to[1]);
|
||||||
|
+ execvp(((char **)arg->v)[0], (char **)arg->v);
|
||||||
|
+ fprintf(stderr, "st: execvp %s\n", ((char **)arg->v)[0]);
|
||||||
|
+ perror("failed");
|
||||||
|
+ exit(0);
|
||||||
|
+ }
|
||||||
|
+
|
||||||
|
+ close(to[0]);
|
||||||
|
+ /* ignore sigpipe for now, in case child exists early */
|
||||||
|
+ oldsigpipe = signal(SIGPIPE, SIG_IGN);
|
||||||
|
+ newline = 0;
|
||||||
|
+ for (n = 0; n < term.row; n++) {
|
||||||
|
+ bp = term.line[n];
|
||||||
|
+ lastpos = MIN(tlinelen(n) + 1, term.col) - 1;
|
||||||
|
+ if (lastpos < 0)
|
||||||
|
+ break;
|
||||||
|
+ end = &bp[lastpos + 1];
|
||||||
|
+ for (; bp < end; ++bp)
|
||||||
|
+ if (xwrite(to[1], buf, utf8encode(bp->u, buf)) < 0)
|
||||||
|
+ break;
|
||||||
|
+ if ((newline = term.line[n][lastpos].mode & ATTR_WRAP))
|
||||||
|
+ continue;
|
||||||
|
+ if (xwrite(to[1], "\n", 1) < 0)
|
||||||
|
+ break;
|
||||||
|
+ newline = 0;
|
||||||
|
+ }
|
||||||
|
+ if (newline)
|
||||||
|
+ (void)xwrite(to[1], "\n", 1);
|
||||||
|
+ close(to[1]);
|
||||||
|
+ /* restore */
|
||||||
|
+ signal(SIGPIPE, oldsigpipe);
|
||||||
|
+}
|
||||||
|
+
|
||||||
|
void
|
||||||
|
strdump(void)
|
||||||
|
{
|
||||||
|
diff --git a/st.h b/st.h
|
||||||
|
index fd3b0d8..754cd08 100644
|
||||||
|
--- a/st.h
|
||||||
|
+++ b/st.h
|
||||||
|
@@ -81,6 +81,7 @@ void die(const char *, ...);
|
||||||
|
void redraw(void);
|
||||||
|
void draw(void);
|
||||||
|
|
||||||
|
+void externalpipe(const Arg *);
|
||||||
|
void printscreen(const Arg *);
|
||||||
|
void printsel(const Arg *);
|
||||||
|
void sendbreak(const Arg *);
|
||||||
|
--
|
||||||
|
2.42.0
|
||||||
|
|
||||||
66
st-gruvbox-dark-0.8.5.diff
Normal file
66
st-gruvbox-dark-0.8.5.diff
Normal file
@ -0,0 +1,66 @@
|
|||||||
|
diff --git a/config.def.h b/config.def.h
|
||||||
|
index 91ab8ca..a068694 100644
|
||||||
|
--- a/config.def.h
|
||||||
|
+++ b/config.def.h
|
||||||
|
@@ -96,32 +96,24 @@ 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",
|
||||||
|
+ [0] = "#282828", /* hard contrast: #1d2021 / soft contrast: #32302f */
|
||||||
|
+ [1] = "#cc241d", /* red */
|
||||||
|
+ [2] = "#98971a", /* green */
|
||||||
|
+ [3] = "#d79921", /* yellow */
|
||||||
|
+ [4] = "#458588", /* blue */
|
||||||
|
+ [5] = "#b16286", /* magenta */
|
||||||
|
+ [6] = "#689d6a", /* cyan */
|
||||||
|
+ [7] = "#a89984", /* white */
|
||||||
|
|
||||||
|
/* 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",
|
||||||
|
- "gray90", /* default foreground colour */
|
||||||
|
- "black", /* default background colour */
|
||||||
|
+ [8] = "#928374", /* black */
|
||||||
|
+ [9] = "#fb4934", /* red */
|
||||||
|
+ [10] = "#b8bb26", /* green */
|
||||||
|
+ [11] = "#fabd2f", /* yellow */
|
||||||
|
+ [12] = "#83a598", /* blue */
|
||||||
|
+ [13] = "#d3869b", /* magenta */
|
||||||
|
+ [14] = "#8ec07c", /* cyan */
|
||||||
|
+ [15] = "#ebdbb2", /* white */
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
@@ -129,9 +121,9 @@ static const char *colorname[] = {
|
||||||
|
* Default colors (colorname index)
|
||||||
|
* foreground, background, cursor, reverse cursor
|
||||||
|
*/
|
||||||
|
-unsigned int defaultfg = 258;
|
||||||
|
-unsigned int defaultbg = 259;
|
||||||
|
-unsigned int defaultcs = 256;
|
||||||
|
+unsigned int defaultfg = 15;
|
||||||
|
+unsigned int defaultbg = 0;
|
||||||
|
+unsigned int defaultcs = 15;
|
||||||
|
static unsigned int defaultrcs = 257;
|
||||||
|
|
||||||
|
/*
|
||||||
63
st.c
63
st.c
@ -718,8 +718,14 @@ sigchld(int a)
|
|||||||
if ((p = waitpid(pid, &stat, WNOHANG)) < 0)
|
if ((p = waitpid(pid, &stat, WNOHANG)) < 0)
|
||||||
die("waiting for pid %hd failed: %s\n", pid, strerror(errno));
|
die("waiting for pid %hd failed: %s\n", pid, strerror(errno));
|
||||||
|
|
||||||
if (pid != p)
|
if (pid != p) {
|
||||||
|
if (p == 0 && wait(&stat) < 0)
|
||||||
|
die("wait: %s\n", strerror(errno));
|
||||||
|
|
||||||
|
/* reinstall sigchld handler */
|
||||||
|
signal(SIGCHLD, sigchld);
|
||||||
return;
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
if (WIFEXITED(stat) && WEXITSTATUS(stat))
|
if (WIFEXITED(stat) && WEXITSTATUS(stat))
|
||||||
die("child exited with status %d\n", WEXITSTATUS(stat));
|
die("child exited with status %d\n", WEXITSTATUS(stat));
|
||||||
@ -803,7 +809,7 @@ ttynew(const char *line, char *cmd, const char *out, char **args)
|
|||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
#ifdef __OpenBSD__
|
#ifdef __OpenBSD__
|
||||||
if (pledge("stdio rpath tty proc", NULL) == -1)
|
if (pledge("stdio rpath tty proc exec", NULL) == -1)
|
||||||
die("pledge\n");
|
die("pledge\n");
|
||||||
#endif
|
#endif
|
||||||
close(s);
|
close(s);
|
||||||
@ -1998,6 +2004,59 @@ strparse(void)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
externalpipe(const Arg *arg)
|
||||||
|
{
|
||||||
|
int to[2];
|
||||||
|
char buf[UTF_SIZ];
|
||||||
|
void (*oldsigpipe)(int);
|
||||||
|
Glyph *bp, *end;
|
||||||
|
int lastpos, n, newline;
|
||||||
|
|
||||||
|
if (pipe(to) == -1)
|
||||||
|
return;
|
||||||
|
|
||||||
|
switch (fork()) {
|
||||||
|
case -1:
|
||||||
|
close(to[0]);
|
||||||
|
close(to[1]);
|
||||||
|
return;
|
||||||
|
case 0:
|
||||||
|
dup2(to[0], STDIN_FILENO);
|
||||||
|
close(to[0]);
|
||||||
|
close(to[1]);
|
||||||
|
execvp(((char **)arg->v)[0], (char **)arg->v);
|
||||||
|
fprintf(stderr, "st: execvp %s\n", ((char **)arg->v)[0]);
|
||||||
|
perror("failed");
|
||||||
|
exit(0);
|
||||||
|
}
|
||||||
|
|
||||||
|
close(to[0]);
|
||||||
|
/* ignore sigpipe for now, in case child exists early */
|
||||||
|
oldsigpipe = signal(SIGPIPE, SIG_IGN);
|
||||||
|
newline = 0;
|
||||||
|
for (n = 0; n < term.row; n++) {
|
||||||
|
bp = term.line[n];
|
||||||
|
lastpos = MIN(tlinelen(n) + 1, term.col) - 1;
|
||||||
|
if (lastpos < 0)
|
||||||
|
break;
|
||||||
|
end = &bp[lastpos + 1];
|
||||||
|
for (; bp < end; ++bp)
|
||||||
|
if (xwrite(to[1], buf, utf8encode(bp->u, buf)) < 0)
|
||||||
|
break;
|
||||||
|
if ((newline = term.line[n][lastpos].mode & ATTR_WRAP))
|
||||||
|
continue;
|
||||||
|
if (xwrite(to[1], "\n", 1) < 0)
|
||||||
|
break;
|
||||||
|
newline = 0;
|
||||||
|
}
|
||||||
|
if (newline)
|
||||||
|
(void)xwrite(to[1], "\n", 1);
|
||||||
|
close(to[1]);
|
||||||
|
/* restore */
|
||||||
|
signal(SIGPIPE, oldsigpipe);
|
||||||
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
strdump(void)
|
strdump(void)
|
||||||
{
|
{
|
||||||
|
|||||||
1
st.h
1
st.h
@ -81,6 +81,7 @@ void die(const char *, ...);
|
|||||||
void redraw(void);
|
void redraw(void);
|
||||||
void draw(void);
|
void draw(void);
|
||||||
|
|
||||||
|
void externalpipe(const Arg *);
|
||||||
void printscreen(const Arg *);
|
void printscreen(const Arg *);
|
||||||
void printsel(const Arg *);
|
void printsel(const Arg *);
|
||||||
void sendbreak(const Arg *);
|
void sendbreak(const Arg *);
|
||||||
|
|||||||
45
x.c
45
x.c
@ -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;
|
||||||
@ -686,6 +687,7 @@ setsel(char *str, Time t)
|
|||||||
XSetSelectionOwner(xw.dpy, XA_PRIMARY, xw.win, t);
|
XSetSelectionOwner(xw.dpy, XA_PRIMARY, xw.win, t);
|
||||||
if (XGetSelectionOwner(xw.dpy, XA_PRIMARY) != xw.win)
|
if (XGetSelectionOwner(xw.dpy, XA_PRIMARY) != xw.win)
|
||||||
selclear();
|
selclear();
|
||||||
|
clipcopy(NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
@ -752,7 +754,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);
|
||||||
|
|
||||||
@ -812,6 +814,10 @@ xloadcols(void)
|
|||||||
else
|
else
|
||||||
die("could not allocate color %d\n", i);
|
die("could not allocate color %d\n", i);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
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;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -842,6 +848,12 @@ xsetcolorname(int x, const char *name)
|
|||||||
XftColorFree(xw.dpy, xw.vis, xw.cmap, &dc.col[x]);
|
XftColorFree(xw.dpy, xw.vis, xw.cmap, &dc.col[x]);
|
||||||
dc.col[x] = ncolor;
|
dc.col[x] = ncolor;
|
||||||
|
|
||||||
|
if (x == defaultbg) {
|
||||||
|
dc.col[defaultbg].color.alpha = (unsigned short)(0xffff * alpha);
|
||||||
|
dc.col[defaultbg].pixel &= 0x00FFFFFF;
|
||||||
|
dc.col[defaultbg].pixel |= (unsigned char)(0xff * alpha) << 24;
|
||||||
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1134,11 +1146,25 @@ xinit(int cols, int rows)
|
|||||||
Window parent, root;
|
Window parent, root;
|
||||||
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);
|
|
||||||
|
root = XRootWindow(xw.dpy, xw.scr);
|
||||||
|
if (!(opt_embed && (parent = strtol(opt_embed, NULL, 0))))
|
||||||
|
parent = root;
|
||||||
|
|
||||||
|
if (XMatchVisualInfo(xw.dpy, xw.scr, 32, TrueColor, &vis) != 0) {
|
||||||
|
xw.vis = vis.visual;
|
||||||
|
xw.depth = vis.depth;
|
||||||
|
} else {
|
||||||
|
XGetWindowAttributes(xw.dpy, parent, &attr);
|
||||||
|
xw.vis = attr.visual;
|
||||||
|
xw.depth = attr.depth;
|
||||||
|
}
|
||||||
|
|
||||||
/* font */
|
/* font */
|
||||||
if (!FcInit())
|
if (!FcInit())
|
||||||
@ -1148,7 +1174,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 */
|
||||||
@ -1168,11 +1194,8 @@ xinit(int cols, int rows)
|
|||||||
| ButtonMotionMask | ButtonPressMask | ButtonReleaseMask;
|
| ButtonMotionMask | ButtonPressMask | ButtonReleaseMask;
|
||||||
xw.attrs.colormap = xw.cmap;
|
xw.attrs.colormap = xw.cmap;
|
||||||
|
|
||||||
root = XRootWindow(xw.dpy, xw.scr);
|
xw.win = XCreateWindow(xw.dpy, parent, xw.l, xw.t,
|
||||||
if (!(opt_embed && (parent = strtol(opt_embed, NULL, 0))))
|
win.w, win.h, 0, xw.depth, InputOutput,
|
||||||
parent = root;
|
|
||||||
xw.win = XCreateWindow(xw.dpy, root, xw.l, xw.t,
|
|
||||||
win.w, win.h, 0, XDefaultDepth(xw.dpy, xw.scr), InputOutput,
|
|
||||||
xw.vis, CWBackPixel | CWBorderPixel | CWBitGravity
|
xw.vis, CWBackPixel | CWBorderPixel | CWBitGravity
|
||||||
| CWEventMask | CWColormap, &xw.attrs);
|
| CWEventMask | CWColormap, &xw.attrs);
|
||||||
if (parent != root)
|
if (parent != root)
|
||||||
@ -1183,7 +1206,7 @@ xinit(int cols, int rows)
|
|||||||
dc.gc = XCreateGC(xw.dpy, xw.win, GCGraphicsExposures,
|
dc.gc = XCreateGC(xw.dpy, xw.win, GCGraphicsExposures,
|
||||||
&gcvalues);
|
&gcvalues);
|
||||||
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);
|
||||||
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);
|
||||||
|
|
||||||
@ -2047,6 +2070,10 @@ main(int argc, char *argv[])
|
|||||||
case 'a':
|
case 'a':
|
||||||
allowaltscreen = 0;
|
allowaltscreen = 0;
|
||||||
break;
|
break;
|
||||||
|
case 'A':
|
||||||
|
alpha = strtof(EARGF(usage()), NULL);
|
||||||
|
LIMIT(alpha, 0.0, 1.0);
|
||||||
|
break;
|
||||||
case 'c':
|
case 'c':
|
||||||
opt_class = EARGF(usage());
|
opt_class = EARGF(usage());
|
||||||
break;
|
break;
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user