Compare commits
15 Commits
alpha-focu
...
main
Author | SHA1 | Date |
---|---|---|
KeeganForelight | 08fb3b8990 | 2 years ago |
KeeganForelight | 9ad11a2765 | 2 years ago |
spinach | 56aba76874 | 2 years ago |
spinach | 6e25429e74 | 2 years ago |
KeeganForelight | 79381aad47 | 2 years ago |
KeeganForelight | 52fea633a1 | 2 years ago |
KeeganForelight | 462ef27cf3 | 2 years ago |
KeeganForelight | 0c79a57cf5 | 2 years ago |
spinach | f28e17de48 | 2 years ago |
spinach | d698aee479 | 2 years ago |
spinach | aa27dbe9b0 | 2 years ago |
spinach | 95383e4a31 | 2 years ago |
spinach | 6d8c5f7506 | 2 years ago |
spinach | 74531a196e | 2 years ago |
spinach | 3e535542dd | 2 years ago |
@ -1,28 +0,0 @@
|
||||
vt emulation
|
||||
------------
|
||||
|
||||
* double-height support
|
||||
|
||||
code & interface
|
||||
----------------
|
||||
|
||||
* add a simple way to do multiplexing
|
||||
|
||||
drawing
|
||||
-------
|
||||
* add diacritics support to xdraws()
|
||||
* switch to a suckless font drawing library
|
||||
* make the font cache simpler
|
||||
* add better support for brightening of the upper colors
|
||||
|
||||
bugs
|
||||
----
|
||||
|
||||
* fix shift up/down (shift selection in emacs)
|
||||
* remove DEC test sequence when appropriate
|
||||
|
||||
misc
|
||||
----
|
||||
|
||||
$ grep -nE 'XXX|TODO' st.c
|
||||
|
@ -1,474 +0,0 @@
|
||||
/* 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",
|
||||
"gray90", /* default foreground colour */
|
||||
"black", /* default background colour */
|
||||
};
|
||||
|
||||
|
||||
/*
|
||||
* Default colors (colorname index)
|
||||
* foreground, background, cursor, reverse cursor
|
||||
*/
|
||||
unsigned int defaultfg = 258;
|
||||
unsigned int defaultbg = 259;
|
||||
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{|}~";
|
@ -1,10 +0,0 @@
|
||||
--- config.def.h
|
||||
+++ config.def.h
|
||||
@@ -114,6 +117,7 @@ static const char *colorname[] = {
|
||||
/* more colors can be added after 255 to use with DefaultXX */
|
||||
"#cccccc",
|
||||
"#555555",
|
||||
+ "black",
|
||||
};
|
||||
|
||||
|
@ -0,0 +1,13 @@
|
||||
/* See LICENSE file for copyright and license details. */
|
||||
#include "base.h"
|
||||
|
||||
/*
|
||||
* appearance
|
||||
*
|
||||
* font: see http://freedesktop.org/software/fontconfig/fontconfig-user.html
|
||||
*/
|
||||
static char *font = "Hack Nerd Font:pixelsize=20:antialias=true:autohint=true";
|
||||
static int borderpx = 2;
|
||||
|
||||
/* bg opacity */
|
||||
float alpha = 0.8, alphaUnfocused = 0.6;
|
@ -0,0 +1,153 @@
|
||||
From a3cdd0753bf578cd4e6db7c6507481f3b5c38aea Mon Sep 17 00:00:00 2001
|
||||
From: Steve Ward <planet36@gmail.com>
|
||||
Date: Tue, 16 Nov 2021 14:15:06 -0500
|
||||
Subject: [PATCH] Allow blinking cursor
|
||||
|
||||
---
|
||||
config.def.h | 19 +++++++++++++------
|
||||
x.c | 47 +++++++++++++++++++++++++++++++++++------------
|
||||
2 files changed, 48 insertions(+), 18 deletions(-)
|
||||
|
||||
diff --git a/config.def.h b/config.def.h
|
||||
index 6f05dce..1a5fed0 100644
|
||||
--- a/config.def.h
|
||||
+++ b/config.def.h
|
||||
@@ -133,13 +133,20 @@ static unsigned int defaultcs = 256;
|
||||
static unsigned int defaultrcs = 257;
|
||||
|
||||
/*
|
||||
- * Default shape of cursor
|
||||
- * 2: Block ("█")
|
||||
- * 4: Underline ("_")
|
||||
- * 6: Bar ("|")
|
||||
- * 7: Snowman ("☃")
|
||||
+ * https://invisible-island.net/xterm/ctlseqs/ctlseqs.html#h4-Functions-using-CSI-_-ordered-by-the-final-character-lparen-s-rparen:CSI-Ps-SP-q.1D81
|
||||
+ * Default style of cursor
|
||||
+ * 0: blinking block
|
||||
+ * 1: blinking block (default)
|
||||
+ * 2: steady block ("█")
|
||||
+ * 3: blinking underline
|
||||
+ * 4: steady underline ("_")
|
||||
+ * 5: blinking bar
|
||||
+ * 6: steady bar ("|")
|
||||
+ * 7: blinking st cursor
|
||||
+ * 8: steady st cursor
|
||||
*/
|
||||
-static unsigned int cursorshape = 2;
|
||||
+static unsigned int cursorstyle = 1;
|
||||
+static Rune stcursor = 0x2603; /* snowman ("☃") */
|
||||
|
||||
/*
|
||||
* Default columns and rows numbers
|
||||
diff --git a/x.c b/x.c
|
||||
index 89786b8..7d2447d 100644
|
||||
--- a/x.c
|
||||
+++ b/x.c
|
||||
@@ -253,6 +253,7 @@ static char *opt_name = NULL;
|
||||
static char *opt_title = NULL;
|
||||
|
||||
static int oldbutton = 3; /* button event on startup: 3 = release */
|
||||
+static int cursorblinks = 0;
|
||||
|
||||
void
|
||||
clipcopy(const Arg *dummy)
|
||||
@@ -1529,29 +1530,44 @@ xdrawcursor(int cx, int cy, Glyph g, int ox, int oy, Glyph og)
|
||||
/* draw the new one */
|
||||
if (IS_SET(MODE_FOCUSED)) {
|
||||
switch (win.cursor) {
|
||||
- case 7: /* st extension */
|
||||
- g.u = 0x2603; /* snowman (U+2603) */
|
||||
+ default:
|
||||
+ case 0: /* blinking block */
|
||||
+ case 1: /* blinking block (default) */
|
||||
+ if (IS_SET(MODE_BLINK))
|
||||
+ break;
|
||||
/* FALLTHROUGH */
|
||||
- case 0: /* Blinking Block */
|
||||
- case 1: /* Blinking Block (Default) */
|
||||
- case 2: /* Steady Block */
|
||||
+ case 2: /* steady block */
|
||||
xdrawglyph(g, cx, cy);
|
||||
break;
|
||||
- case 3: /* Blinking Underline */
|
||||
- case 4: /* Steady Underline */
|
||||
+ case 3: /* blinking underline */
|
||||
+ if (IS_SET(MODE_BLINK))
|
||||
+ break;
|
||||
+ /* FALLTHROUGH */
|
||||
+ case 4: /* steady underline */
|
||||
XftDrawRect(xw.draw, &drawcol,
|
||||
borderpx + cx * win.cw,
|
||||
borderpx + (cy + 1) * win.ch - \
|
||||
cursorthickness,
|
||||
win.cw, cursorthickness);
|
||||
break;
|
||||
- case 5: /* Blinking bar */
|
||||
- case 6: /* Steady bar */
|
||||
+ case 5: /* blinking bar */
|
||||
+ if (IS_SET(MODE_BLINK))
|
||||
+ break;
|
||||
+ /* FALLTHROUGH */
|
||||
+ case 6: /* steady bar */
|
||||
XftDrawRect(xw.draw, &drawcol,
|
||||
borderpx + cx * win.cw,
|
||||
borderpx + cy * win.ch,
|
||||
cursorthickness, win.ch);
|
||||
break;
|
||||
+ case 7: /* blinking st cursor */
|
||||
+ if (IS_SET(MODE_BLINK))
|
||||
+ break;
|
||||
+ /* FALLTHROUGH */
|
||||
+ case 8: /* steady st cursor */
|
||||
+ g.u = stcursor;
|
||||
+ xdrawglyph(g, cx, cy);
|
||||
+ break;
|
||||
}
|
||||
} else {
|
||||
XftDrawRect(xw.draw, &drawcol,
|
||||
@@ -1708,9 +1724,12 @@ xsetmode(int set, unsigned int flags)
|
||||
int
|
||||
xsetcursor(int cursor)
|
||||
{
|
||||
- if (!BETWEEN(cursor, 0, 7)) /* 7: st extension */
|
||||
+ if (!BETWEEN(cursor, 0, 8)) /* 7-8: st extensions */
|
||||
return 1;
|
||||
win.cursor = cursor;
|
||||
+ cursorblinks = win.cursor == 0 || win.cursor == 1 ||
|
||||
+ win.cursor == 3 || win.cursor == 5 ||
|
||||
+ win.cursor == 7;
|
||||
return 0;
|
||||
}
|
||||
|
||||
@@ -1954,6 +1973,10 @@ run(void)
|
||||
if (FD_ISSET(ttyfd, &rfd) || xev) {
|
||||
if (!drawing) {
|
||||
trigger = now;
|
||||
+ if (IS_SET(MODE_BLINK)) {
|
||||
+ win.mode ^= MODE_BLINK;
|
||||
+ }
|
||||
+ lastblink = now;
|
||||
drawing = 1;
|
||||
}
|
||||
timeout = (maxlatency - TIMEDIFF(now, trigger)) \
|
||||
@@ -1964,7 +1987,7 @@ run(void)
|
||||
|
||||
/* idle detected or maxlatency exhausted -> draw */
|
||||
timeout = -1;
|
||||
- if (blinktimeout && tattrset(ATTR_BLINK)) {
|
||||
+ if (blinktimeout && (cursorblinks || tattrset(ATTR_BLINK))) {
|
||||
timeout = blinktimeout - TIMEDIFF(now, lastblink);
|
||||
if (timeout <= 0) {
|
||||
if (-timeout > blinktimeout) /* start visible */
|
||||
@@ -2000,7 +2023,7 @@ main(int argc, char *argv[])
|
||||
{
|
||||
xw.l = xw.t = 0;
|
||||
xw.isfixed = False;
|
||||
- xsetcursor(cursorshape);
|
||||
+ xsetcursor(cursorstyle);
|
||||
|
||||
ARGBEGIN {
|
||||
case 'a':
|
||||
--
|
||||
2.34.0
|
||||
|
@ -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
|
@ -0,0 +1,605 @@
|
||||
diff --git a/config.def.h b/config.def.h
|
||||
index 6f05dce..7ae1b92 100644
|
||||
--- a/config.def.h
|
||||
+++ b/config.def.h
|
||||
@@ -470,3 +470,27 @@ static char ascii_printable[] =
|
||||
" !\"#$%&'()*+,-./0123456789:;<=>?"
|
||||
"@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\\]^_"
|
||||
"`abcdefghijklmnopqrstuvwxyz{|}~";
|
||||
+
|
||||
+/**
|
||||
+ * Undercurl style. Set UNDERCURL_STYLE to one of the available styles.
|
||||
+ *
|
||||
+ * Curly: Dunno how to draw it *shrug*
|
||||
+ * _ _ _ _
|
||||
+ * ( ) ( ) ( ) ( )
|
||||
+ * (_) (_) (_) (_)
|
||||
+ *
|
||||
+ * Spiky:
|
||||
+ * /\ /\ /\ /\
|
||||
+ * \/ \/ \/
|
||||
+ *
|
||||
+ * Capped:
|
||||
+ * _ _ _
|
||||
+ * / \ / \ / \
|
||||
+ * \_/ \_/
|
||||
+ */
|
||||
+// Available styles
|
||||
+#define UNDERCURL_CURLY 0
|
||||
+#define UNDERCURL_SPIKY 1
|
||||
+#define UNDERCURL_CAPPED 2
|
||||
+// Active style
|
||||
+#define UNDERCURL_STYLE UNDERCURL_SPIKY
|
||||
diff --git a/st.c b/st.c
|
||||
index 76b7e0d..542ab3a 100644
|
||||
--- a/st.c
|
||||
+++ b/st.c
|
||||
@@ -33,6 +33,7 @@
|
||||
#define UTF_SIZ 4
|
||||
#define ESC_BUF_SIZ (128*UTF_SIZ)
|
||||
#define ESC_ARG_SIZ 16
|
||||
+#define CAR_PER_ARG 4
|
||||
#define STR_BUF_SIZ ESC_BUF_SIZ
|
||||
#define STR_ARG_SIZ ESC_ARG_SIZ
|
||||
|
||||
@@ -139,6 +140,7 @@ typedef struct {
|
||||
int arg[ESC_ARG_SIZ];
|
||||
int narg; /* nb of args */
|
||||
char mode[2];
|
||||
+ int carg[ESC_ARG_SIZ][CAR_PER_ARG]; /* colon args */
|
||||
} CSIEscape;
|
||||
|
||||
/* STR Escape sequence structs */
|
||||
@@ -159,6 +161,7 @@ static void ttywriteraw(const char *, size_t);
|
||||
|
||||
static void csidump(void);
|
||||
static void csihandle(void);
|
||||
+static void readcolonargs(char **, int, int[][CAR_PER_ARG]);
|
||||
static void csiparse(void);
|
||||
static void csireset(void);
|
||||
static int eschandle(uchar);
|
||||
@@ -1131,6 +1134,28 @@ tnewline(int first_col)
|
||||
tmoveto(first_col ? 0 : term.c.x, y);
|
||||
}
|
||||
|
||||
+void
|
||||
+readcolonargs(char **p, int cursor, int params[][CAR_PER_ARG])
|
||||
+{
|
||||
+ int i = 0;
|
||||
+ for (; i < CAR_PER_ARG; i++)
|
||||
+ params[cursor][i] = -1;
|
||||
+
|
||||
+ if (**p != ':')
|
||||
+ return;
|
||||
+
|
||||
+ char *np = NULL;
|
||||
+ i = 0;
|
||||
+
|
||||
+ while (**p == ':' && i < CAR_PER_ARG) {
|
||||
+ while (**p == ':')
|
||||
+ (*p)++;
|
||||
+ params[cursor][i] = strtol(*p, &np, 10);
|
||||
+ *p = np;
|
||||
+ i++;
|
||||
+ }
|
||||
+}
|
||||
+
|
||||
void
|
||||
csiparse(void)
|
||||
{
|
||||
@@ -1153,6 +1178,7 @@ csiparse(void)
|
||||
v = -1;
|
||||
csiescseq.arg[csiescseq.narg++] = v;
|
||||
p = np;
|
||||
+ readcolonargs(&p, csiescseq.narg-1, csiescseq.carg);
|
||||
if (*p != ';' || csiescseq.narg == ESC_ARG_SIZ)
|
||||
break;
|
||||
p++;
|
||||
@@ -1369,6 +1395,10 @@ tsetattr(int *attr, int l)
|
||||
ATTR_STRUCK );
|
||||
term.c.attr.fg = defaultfg;
|
||||
term.c.attr.bg = defaultbg;
|
||||
+ term.c.attr.ustyle = -1;
|
||||
+ term.c.attr.ucolor[0] = -1;
|
||||
+ term.c.attr.ucolor[1] = -1;
|
||||
+ term.c.attr.ucolor[2] = -1;
|
||||
break;
|
||||
case 1:
|
||||
term.c.attr.mode |= ATTR_BOLD;
|
||||
@@ -1380,7 +1410,14 @@ tsetattr(int *attr, int l)
|
||||
term.c.attr.mode |= ATTR_ITALIC;
|
||||
break;
|
||||
case 4:
|
||||
- term.c.attr.mode |= ATTR_UNDERLINE;
|
||||
+ term.c.attr.ustyle = csiescseq.carg[i][0];
|
||||
+
|
||||
+ if (term.c.attr.ustyle != 0)
|
||||
+ term.c.attr.mode |= ATTR_UNDERLINE;
|
||||
+ else
|
||||
+ term.c.attr.mode &= ~ATTR_UNDERLINE;
|
||||
+
|
||||
+ term.c.attr.mode ^= ATTR_DIRTYUNDERLINE;
|
||||
break;
|
||||
case 5: /* slow blink */
|
||||
/* FALLTHROUGH */
|
||||
@@ -1431,6 +1468,18 @@ tsetattr(int *attr, int l)
|
||||
case 49:
|
||||
term.c.attr.bg = defaultbg;
|
||||
break;
|
||||
+ case 58:
|
||||
+ term.c.attr.ucolor[0] = csiescseq.carg[i][1];
|
||||
+ term.c.attr.ucolor[1] = csiescseq.carg[i][2];
|
||||
+ term.c.attr.ucolor[2] = csiescseq.carg[i][3];
|
||||
+ term.c.attr.mode ^= ATTR_DIRTYUNDERLINE;
|
||||
+ break;
|
||||
+ case 59:
|
||||
+ term.c.attr.ucolor[0] = -1;
|
||||
+ term.c.attr.ucolor[1] = -1;
|
||||
+ term.c.attr.ucolor[2] = -1;
|
||||
+ term.c.attr.mode ^= ATTR_DIRTYUNDERLINE;
|
||||
+ break;
|
||||
default:
|
||||
if (BETWEEN(attr[i], 30, 37)) {
|
||||
term.c.attr.fg = attr[i] - 30;
|
||||
diff --git a/st.h b/st.h
|
||||
index 3d351b6..95bdcbd 100644
|
||||
--- a/st.h
|
||||
+++ b/st.h
|
||||
@@ -34,6 +34,7 @@ enum glyph_attribute {
|
||||
ATTR_WIDE = 1 << 9,
|
||||
ATTR_WDUMMY = 1 << 10,
|
||||
ATTR_BOLD_FAINT = ATTR_BOLD | ATTR_FAINT,
|
||||
+ ATTR_DIRTYUNDERLINE = 1 << 15,
|
||||
};
|
||||
|
||||
enum selection_mode {
|
||||
@@ -65,6 +66,8 @@ typedef struct {
|
||||
ushort mode; /* attribute flags */
|
||||
uint32_t fg; /* foreground */
|
||||
uint32_t bg; /* background */
|
||||
+ int ustyle; /* underline style */
|
||||
+ int ucolor[3]; /* underline color */
|
||||
} Glyph;
|
||||
|
||||
typedef Glyph *Line;
|
||||
diff --git a/st.info b/st.info
|
||||
index 8201ad6..659878c 100644
|
||||
--- a/st.info
|
||||
+++ b/st.info
|
||||
@@ -1,4 +1,5 @@
|
||||
st-mono| simpleterm monocolor,
|
||||
+ Su,
|
||||
acsc=+C\,D-A.B0E``aaffgghFiGjjkkllmmnnooppqqrrssttuuvvwwxxyyzz{{||}}~~,
|
||||
am,
|
||||
bce,
|
||||
diff --git a/x.c b/x.c
|
||||
index 210f184..3a0e79e 100644
|
||||
--- a/x.c
|
||||
+++ b/x.c
|
||||
@@ -45,6 +45,14 @@ typedef struct {
|
||||
signed char appcursor; /* application cursor */
|
||||
} Key;
|
||||
|
||||
+/* Undercurl slope types */
|
||||
+enum undercurl_slope_type {
|
||||
+ UNDERCURL_SLOPE_ASCENDING = 0,
|
||||
+ UNDERCURL_SLOPE_TOP_CAP = 1,
|
||||
+ UNDERCURL_SLOPE_DESCENDING = 2,
|
||||
+ UNDERCURL_SLOPE_BOTTOM_CAP = 3
|
||||
+};
|
||||
+
|
||||
/* X modifiers */
|
||||
#define XK_ANY_MOD UINT_MAX
|
||||
#define XK_NO_MOD 0
|
||||
@@ -1339,6 +1347,51 @@ xmakeglyphfontspecs(XftGlyphFontSpec *specs, const Glyph *glyphs, int len, int x
|
||||
return numspecs;
|
||||
}
|
||||
|
||||
+static int isSlopeRising (int x, int iPoint, int waveWidth)
|
||||
+{
|
||||
+ // . . . .
|
||||
+ // / \ / \ / \ / \
|
||||
+ // / \ / \ / \ / \
|
||||
+ // . . . . .
|
||||
+
|
||||
+ // Find absolute `x` of point
|
||||
+ x += iPoint * (waveWidth/2);
|
||||
+
|
||||
+ // Find index of absolute wave
|
||||
+ int absSlope = x / ((float)waveWidth/2);
|
||||
+
|
||||
+ return (absSlope % 2);
|
||||
+}
|
||||
+
|
||||
+static int getSlope (int x, int iPoint, int waveWidth)
|
||||
+{
|
||||
+ // Sizes: Caps are half width of slopes
|
||||
+ // 1_2 1_2 1_2 1_2
|
||||
+ // / \ / \ / \ / \
|
||||
+ // / \ / \ / \ / \
|
||||
+ // 0 3_0 3_0 3_0 3_
|
||||
+ // <2-> <1> <---6---->
|
||||
+
|
||||
+ // Find type of first point
|
||||
+ int firstType;
|
||||
+ x -= (x / waveWidth) * waveWidth;
|
||||
+ if (x < (waveWidth * (2.f/6.f)))
|
||||
+ firstType = UNDERCURL_SLOPE_ASCENDING;
|
||||
+ else if (x < (waveWidth * (3.f/6.f)))
|
||||
+ firstType = UNDERCURL_SLOPE_TOP_CAP;
|
||||
+ else if (x < (waveWidth * (5.f/6.f)))
|
||||
+ firstType = UNDERCURL_SLOPE_DESCENDING;
|
||||
+ else
|
||||
+ firstType = UNDERCURL_SLOPE_BOTTOM_CAP;
|
||||
+
|
||||
+ // Find type of given point
|
||||
+ int pointType = (iPoint % 4);
|
||||
+ pointType += firstType;
|
||||
+ pointType %= 4;
|
||||
+
|
||||
+ return pointType;
|
||||
+}
|
||||
+
|
||||
void
|
||||
xdrawglyphfontspecs(const XftGlyphFontSpec *specs, Glyph base, int len, int x, int y)
|
||||
{
|
||||
@@ -1461,8 +1514,357 @@ xdrawglyphfontspecs(const XftGlyphFontSpec *specs, Glyph base, int len, int x, i
|
||||
|
||||
/* Render underline and strikethrough. */
|
||||
if (base.mode & ATTR_UNDERLINE) {
|
||||
- XftDrawRect(xw.draw, fg, winx, winy + dc.font.ascent + 1,
|
||||
- width, 1);
|
||||
+ // Underline Color
|
||||
+ const int widthThreshold = 28; // +1 width every widthThreshold px of font
|
||||
+ int wlw = (win.ch / widthThreshold) + 1; // Wave Line Width
|
||||
+ int linecolor;
|
||||
+ if ((base.ucolor[0] >= 0) &&
|
||||
+ !(base.mode & ATTR_BLINK && win.mode & MODE_BLINK) &&
|
||||
+ !(base.mode & ATTR_INVISIBLE)
|
||||
+ ) {
|
||||
+ // Special color for underline
|
||||
+ // Index
|
||||
+ if (base.ucolor[1] < 0) {
|
||||
+ linecolor = dc.col[base.ucolor[0]].pixel;
|
||||
+ }
|
||||
+ // RGB
|
||||
+ else {
|
||||
+ XColor lcolor;
|
||||
+ lcolor.red = base.ucolor[0] * 257;
|
||||
+ lcolor.green = base.ucolor[1] * 257;
|
||||
+ lcolor.blue = base.ucolor[2] * 257;
|
||||
+ lcolor.flags = DoRed | DoGreen | DoBlue;
|
||||
+ XAllocColor(xw.dpy, xw.cmap, &lcolor);
|
||||
+ linecolor = lcolor.pixel;
|
||||
+ }
|
||||
+ } else {
|
||||
+ // Foreground color for underline
|
||||
+ linecolor = fg->pixel;
|
||||
+ }
|
||||
+
|
||||
+ XGCValues ugcv = {
|
||||
+ .foreground = linecolor,
|
||||
+ .line_width = wlw,
|
||||
+ .line_style = LineSolid,
|
||||
+ .cap_style = CapNotLast
|
||||
+ };
|
||||
+
|
||||
+ GC ugc = XCreateGC(xw.dpy, XftDrawDrawable(xw.draw),
|
||||
+ GCForeground | GCLineWidth | GCLineStyle | GCCapStyle,
|
||||
+ &ugcv);
|
||||
+
|
||||
+ // Underline Style
|
||||
+ if (base.ustyle != 3) {
|
||||
+ //XftDrawRect(xw.draw, fg, winx, winy + dc.font.ascent + 1, width, 1);
|
||||
+ XFillRectangle(xw.dpy, XftDrawDrawable(xw.draw), ugc, winx,
|
||||
+ winy + dc.font.ascent + 1, width, wlw);
|
||||
+ } else if (base.ustyle == 3) {
|
||||
+ int ww = win.cw;//width;
|
||||
+ int wh = dc.font.descent - wlw/2 - 1;//r.height/7;
|
||||
+ int wx = winx;
|
||||
+ int wy = winy + win.ch - dc.font.descent;
|
||||
+
|
||||
+#if UNDERCURL_STYLE == UNDERCURL_CURLY
|
||||
+ // Draw waves
|
||||
+ int narcs = charlen * 2 + 1;
|
||||
+ XArc *arcs = xmalloc(sizeof(XArc) * narcs);
|
||||
+
|
||||
+ int i = 0;
|
||||
+ for (i = 0; i < charlen-1; i++) {
|
||||
+ arcs[i*2] = (XArc) {
|
||||
+ .x = wx + win.cw * i + ww / 4,
|
||||
+ .y = wy,
|
||||
+ .width = win.cw / 2,
|
||||
+ .height = wh,
|
||||
+ .angle1 = 0,
|
||||
+ .angle2 = 180 * 64
|
||||
+ };
|
||||
+ arcs[i*2+1] = (XArc) {
|
||||
+ .x = wx + win.cw * i + ww * 0.75,
|
||||
+ .y = wy,
|
||||
+ .width = win.cw/2,
|
||||
+ .height = wh,
|
||||
+ .angle1 = 180 * 64,
|
||||
+ .angle2 = 180 * 64
|
||||
+ };
|
||||
+ }
|
||||
+ // Last wave
|
||||
+ arcs[i*2] = (XArc) {wx + ww * i + ww / 4, wy, ww / 2, wh,
|
||||
+ 0, 180 * 64 };
|
||||
+ // Last wave tail
|
||||
+ arcs[i*2+1] = (XArc) {wx + ww * i + ww * 0.75, wy, ceil(ww / 2.),
|
||||
+ wh, 180 * 64, 90 * 64};
|
||||
+ // First wave tail
|
||||
+ i++;
|
||||
+ arcs[i*2] = (XArc) {wx - ww/4 - 1, wy, ceil(ww / 2.), wh, 270 * 64,
|
||||
+ 90 * 64 };
|
||||
+
|
||||
+ XDrawArcs(xw.dpy, XftDrawDrawable(xw.draw), ugc, arcs, narcs);
|
||||
+
|
||||
+ free(arcs);
|
||||
+#elif UNDERCURL_STYLE == UNDERCURL_SPIKY
|
||||
+ // Make the underline corridor larger
|
||||
+ /*
|
||||
+ wy -= wh;
|
||||
+ */
|
||||
+ wh *= 2;
|
||||
+
|
||||
+ // Set the angle of the slope to 45°
|
||||
+ ww = wh;
|
||||
+
|
||||
+ // Position of wave is independent of word, it's absolute
|
||||
+ wx = (wx / (ww/2)) * (ww/2);
|
||||
+
|
||||
+ int marginStart = winx - wx;
|
||||
+
|
||||
+ // Calculate number of points with floating precision
|
||||
+ float n = width; // Width of word in pixels
|
||||
+ n = (n / ww) * 2; // Number of slopes (/ or \)
|
||||
+ n += 2; // Add two last points
|
||||
+ int npoints = n; // Convert to int
|
||||
+
|
||||
+ // Total length of underline
|
||||
+ float waveLength = 0;
|
||||
+
|
||||
+ if (npoints >= 3) {
|
||||
+ // We add an aditional slot in case we use a bonus point
|
||||
+ XPoint *points = xmalloc(sizeof(XPoint) * (npoints + 1));
|
||||
+
|
||||
+ // First point (Starts with the word bounds)
|
||||
+ points[0] = (XPoint) {
|
||||
+ .x = wx + marginStart,
|
||||
+ .y = (isSlopeRising(wx, 0, ww))
|
||||
+ ? (wy - marginStart + ww/2.f)
|
||||
+ : (wy + marginStart)
|
||||
+ };
|
||||
+
|
||||
+ // Second point (Goes back to the absolute point coordinates)
|
||||
+ points[1] = (XPoint) {
|
||||
+ .x = (ww/2.f) - marginStart,
|
||||
+ .y = (isSlopeRising(wx, 1, ww))
|
||||
+ ? (ww/2.f - marginStart)
|
||||
+ : (-ww/2.f + marginStart)
|
||||
+ };
|
||||
+ waveLength += (ww/2.f) - marginStart;
|
||||
+
|
||||
+ // The rest of the points
|
||||
+ for (int i = 2; i < npoints-1; i++) {
|
||||
+ points[i] = (XPoint) {
|
||||
+ .x = ww/2,
|
||||
+ .y = (isSlopeRising(wx, i, ww))
|
||||
+ ? wh/2
|
||||
+ : -wh/2
|
||||
+ };
|
||||
+ waveLength += ww/2;
|
||||
+ }
|
||||
+
|
||||
+ // Last point
|
||||
+ points[npoints-1] = (XPoint) {
|
||||
+ .x = ww/2,
|
||||
+ .y = (isSlopeRising(wx, npoints-1, ww))
|
||||
+ ? wh/2
|
||||
+ : -wh/2
|
||||
+ };
|
||||
+ waveLength += ww/2;
|
||||
+
|
||||
+ // End
|
||||
+ if (waveLength < width) { // Add a bonus point?
|
||||
+ int marginEnd = width - waveLength;
|
||||
+ points[npoints] = (XPoint) {
|
||||
+ .x = marginEnd,
|
||||
+ .y = (isSlopeRising(wx, npoints, ww))
|
||||
+ ? (marginEnd)
|
||||
+ : (-marginEnd)
|
||||
+ };
|
||||
+
|
||||
+ npoints++;
|
||||
+ } else if (waveLength > width) { // Is last point too far?
|
||||
+ int marginEnd = waveLength - width;
|
||||
+ points[npoints-1].x -= marginEnd;
|
||||
+ if (isSlopeRising(wx, npoints-1, ww))
|
||||
+ points[npoints-1].y -= (marginEnd);
|
||||
+ else
|
||||
+ points[npoints-1].y += (marginEnd);
|
||||
+ }
|
||||
+
|
||||
+ // Draw the lines
|
||||
+ XDrawLines(xw.dpy, XftDrawDrawable(xw.draw), ugc, points, npoints,
|
||||
+ CoordModePrevious);
|
||||
+
|
||||
+ // Draw a second underline with an offset of 1 pixel
|
||||
+ if ( ((win.ch / (widthThreshold/2)) % 2)) {
|
||||
+ points[0].x++;
|
||||
+
|
||||
+ XDrawLines(xw.dpy, XftDrawDrawable(xw.draw), ugc, points,
|
||||
+ npoints, CoordModePrevious);
|
||||
+ }
|
||||
+
|
||||
+ // Free resources
|
||||
+ free(points);
|
||||
+ }
|
||||
+#else // UNDERCURL_CAPPED
|
||||
+ // Cap is half of wave width
|
||||
+ float capRatio = 0.5f;
|
||||
+
|
||||
+ // Make the underline corridor larger
|
||||
+ wh *= 2;
|
||||
+
|
||||
+ // Set the angle of the slope to 45°
|
||||
+ ww = wh;
|
||||
+ ww *= 1 + capRatio; // Add a bit of width for the cap
|
||||
+
|
||||
+ // Position of wave is independent of word, it's absolute
|
||||
+ wx = (wx / ww) * ww;
|
||||
+
|
||||
+ float marginStart;
|
||||
+ switch(getSlope(winx, 0, ww)) {
|
||||
+ case UNDERCURL_SLOPE_ASCENDING:
|
||||
+ marginStart = winx - wx;
|
||||
+ break;
|
||||
+ case UNDERCURL_SLOPE_TOP_CAP:
|
||||
+ marginStart = winx - (wx + (ww * (2.f/6.f)));
|
||||
+ break;
|
||||
+ case UNDERCURL_SLOPE_DESCENDING:
|
||||
+ marginStart = winx - (wx + (ww * (3.f/6.f)));
|
||||
+ break;
|
||||
+ case UNDERCURL_SLOPE_BOTTOM_CAP:
|
||||
+ marginStart = winx - (wx + (ww * (5.f/6.f)));
|
||||
+ break;
|
||||
+ }
|
||||
+
|
||||
+ // Calculate number of points with floating precision
|
||||
+ float n = width; // Width of word in pixels
|
||||
+ // ._.
|
||||
+ n = (n / ww) * 4; // Number of points (./ \.)
|
||||
+ n += 2; // Add two last points
|
||||
+ int npoints = n; // Convert to int
|
||||
+
|
||||
+ // Position of the pen to draw the lines
|
||||
+ float penX = 0;
|
||||
+ float penY = 0;
|
||||
+
|
||||
+ if (npoints >= 3) {
|
||||
+ XPoint *points = xmalloc(sizeof(XPoint) * (npoints + 1));
|
||||
+
|
||||
+ // First point (Starts with the word bounds)
|
||||
+ penX = winx;
|
||||
+ switch (getSlope(winx, 0, ww)) {
|
||||
+ case UNDERCURL_SLOPE_ASCENDING:
|
||||
+ penY = wy + wh/2.f - marginStart;
|
||||
+ break;
|
||||
+ case UNDERCURL_SLOPE_TOP_CAP:
|
||||
+ penY = wy;
|
||||
+ break;
|
||||
+ case UNDERCURL_SLOPE_DESCENDING:
|
||||
+ penY = wy + marginStart;
|
||||
+ break;
|
||||
+ case UNDERCURL_SLOPE_BOTTOM_CAP:
|
||||
+ penY = wy + wh/2.f;
|
||||
+ break;
|
||||
+ }
|
||||
+ points[0].x = penX;
|
||||
+ points[0].y = penY;
|
||||
+
|
||||
+ // Second point (Goes back to the absolute point coordinates)
|
||||
+ switch (getSlope(winx, 1, ww)) {
|
||||
+ case UNDERCURL_SLOPE_ASCENDING:
|
||||
+ penX += ww * (1.f/6.f) - marginStart;
|
||||
+ penY += 0;
|
||||
+ break;
|
||||
+ case UNDERCURL_SLOPE_TOP_CAP:
|
||||
+ penX += ww * (2.f/6.f) - marginStart;
|
||||
+ penY += -wh/2.f + marginStart;
|
||||
+ break;
|
||||
+ case UNDERCURL_SLOPE_DESCENDING:
|
||||
+ penX += ww * (1.f/6.f) - marginStart;
|
||||
+ penY += 0;
|
||||
+ break;
|
||||
+ case UNDERCURL_SLOPE_BOTTOM_CAP:
|
||||
+ penX += ww * (2.f/6.f) - marginStart;
|
||||
+ penY += -marginStart + wh/2.f;
|
||||
+ break;
|
||||
+ }
|
||||
+ points[1].x = penX;
|
||||
+ points[1].y = penY;
|
||||
+
|
||||
+ // The rest of the points
|
||||
+ for (int i = 2; i < npoints; i++) {
|
||||
+ switch (getSlope(winx, i, ww)) {
|
||||
+ case UNDERCURL_SLOPE_ASCENDING:
|
||||
+ case UNDERCURL_SLOPE_DESCENDING:
|
||||
+ penX += ww * (1.f/6.f);
|
||||
+ penY += 0;
|
||||
+ break;
|
||||
+ case UNDERCURL_SLOPE_TOP_CAP:
|
||||
+ penX += ww * (2.f/6.f);
|
||||
+ penY += -wh / 2.f;
|
||||
+ break;
|
||||
+ case UNDERCURL_SLOPE_BOTTOM_CAP:
|
||||
+ penX += ww * (2.f/6.f);
|
||||
+ penY += wh / 2.f;
|
||||
+ break;
|
||||
+ }
|
||||
+ points[i].x = penX;
|
||||
+ points[i].y = penY;
|
||||
+ }
|
||||
+
|
||||
+ // End
|
||||
+ float waveLength = penX - winx;
|
||||
+ if (waveLength < width) { // Add a bonus point?
|
||||
+ int marginEnd = width - waveLength;
|
||||
+ penX += marginEnd;
|
||||
+ switch(getSlope(winx, npoints, ww)) {
|
||||
+ case UNDERCURL_SLOPE_ASCENDING:
|
||||
+ case UNDERCURL_SLOPE_DESCENDING:
|
||||
+ //penY += 0;
|
||||
+ break;
|
||||
+ case UNDERCURL_SLOPE_TOP_CAP:
|
||||
+ penY += -marginEnd;
|
||||
+ break;
|
||||
+ case UNDERCURL_SLOPE_BOTTOM_CAP:
|
||||
+ penY += marginEnd;
|
||||
+ break;
|
||||
+ }
|
||||
+
|
||||
+ points[npoints].x = penX;
|
||||
+ points[npoints].y = penY;
|
||||
+
|
||||
+ npoints++;
|
||||
+ } else if (waveLength > width) { // Is last point too far?
|
||||
+ int marginEnd = waveLength - width;
|
||||
+ points[npoints-1].x -= marginEnd;
|
||||
+ switch(getSlope(winx, npoints-1, ww)) {
|
||||
+ case UNDERCURL_SLOPE_TOP_CAP:
|
||||
+ points[npoints-1].y += marginEnd;
|
||||
+ break;
|
||||
+ case UNDERCURL_SLOPE_BOTTOM_CAP:
|
||||
+ points[npoints-1].y -= marginEnd;
|
||||
+ break;
|
||||
+ default:
|
||||
+ break;
|
||||
+ }
|
||||
+ }
|
||||
+
|
||||
+ // Draw the lines
|
||||
+ XDrawLines(xw.dpy, XftDrawDrawable(xw.draw), ugc, points, npoints,
|
||||
+ CoordModeOrigin);
|
||||
+
|
||||
+ // Draw a second underline with an offset of 1 pixel
|
||||
+ if ( ((win.ch / (widthThreshold/2)) % 2)) {
|
||||
+ for (int i = 0; i < npoints; i++)
|
||||
+ points[i].x++;
|
||||
+
|
||||
+ XDrawLines(xw.dpy, XftDrawDrawable(xw.draw), ugc, points,
|
||||
+ npoints, CoordModeOrigin);
|
||||
+ }
|
||||
+
|
||||
+ // Free resources
|
||||
+ free(points);
|
||||
+ }
|
||||
+#endif
|
||||
+ }
|
||||
+
|
||||
+ XFreeGC(xw.dpy, ugc);
|
||||
}
|
||||
|
||||
if (base.mode & ATTR_STRUCK) {
|
@ -1,126 +0,0 @@
|
||||
/* 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(const char *, char *, const 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(const 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;
|
||||
extern unsigned int defaultcs;
|
@ -1,7 +0,0 @@
|
||||
--- st.h
|
||||
+++ st.h
|
||||
@@ -123,3 +124,4 @@ extern char *termname;
|
||||
extern unsigned int tabspaces;
|
||||
extern unsigned int defaultfg;
|
||||
extern unsigned int defaultbg;
|
||||
+extern float alpha, alphaUnfocused;
|
@ -0,0 +1,12 @@
|
||||
#include "base.h"
|
||||
|
||||
/*
|
||||
* appearance
|
||||
*
|
||||
* font: see http://freedesktop.org/software/fontconfig/fontconfig-user.html
|
||||
*/
|
||||
static char *font = "Hack Nerd Font:pixelsize=14:antialias=true:autohint=true";
|
||||
static int borderpx = 1;
|
||||
|
||||
/* bg opacity */
|
||||
float alpha = 0.85, alphaUnfocused = 0.6;
|
@ -0,0 +1,12 @@
|
||||
#include "base.h"
|
||||
|
||||
/*
|
||||
* appearance
|
||||
*
|
||||
* font: see http://freedesktop.org/software/fontconfig/fontconfig-user.html
|
||||
*/
|
||||
static char *font = "Hack Nerd Font:pixelsize=16:antialias=true:autohint=true";
|
||||
static int borderpx = 2;
|
||||
|
||||
/* bg opacity */
|
||||
float alpha = 0.8, alphaUnfocused = 0.6;
|
@ -1,11 +0,0 @@
|
||||
--- x.c
|
||||
+++ x.c
|
||||
@@ -254,6 +256,8 @@ static char *opt_line = NULL;
|
||||
static char *opt_name = NULL;
|
||||
static char *opt_title = NULL;
|
||||
|
||||
+static int focused = 0;
|
||||
+
|
||||
static int oldbutton = 3; /* button event on startup: 3 = release */
|
||||
|
||||
void
|
Loading…
Reference in New Issue