Compare commits
	
		
			9 Commits
		
	
	
		
			on_0.8.1
			...
			0.7_branch
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 53e4038065 | |||
|  | f93f6d7bd9 | ||
|  | 0bfde9df6d | ||
|  | b1d4782674 | ||
|  | 923cbdd9d1 | ||
|  | a2940a5559 | ||
|  | 552d828ce0 | ||
|  | b03129f569 | ||
|  | e3d2f4b5cc | 
							
								
								
									
										50
									
								
								config.def.h
									
									
									
									
									
								
							
							
						
						
									
										50
									
								
								config.def.h
									
									
									
									
									
								
							| @@ -84,31 +84,23 @@ static unsigned int tabspaces = 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 */ | 	/* solarized dark */ | ||||||
| 	"black", | 	"#03171d",  /*  0: black    */ | ||||||
| 	"red3", | 	"#dc322f",  /*  1: red      */ | ||||||
| 	"green3", | 	"#859900",  /*  2: green    */ | ||||||
| 	"yellow3", | 	"#b58900",  /*  3: yellow   */ | ||||||
| 	"blue2", | 	"#268bd2",  /*  4: blue     */ | ||||||
| 	"magenta3", | 	"#d33682",  /*  5: magenta  */ | ||||||
| 	"cyan3", | 	"#2aa198",  /*  6: cyan     */ | ||||||
| 	"gray90", | 	"#eee8d5",  /*  7: white    */ | ||||||
|  | 	"#001014",  /*  8: brblack  */ | ||||||
| 	/* 8 bright colors */ | 	"#cb4b16",  /*  9: brred    */ | ||||||
| 	"gray50", | 	"#586e75",  /* 10: brgreen  */ | ||||||
| 	"red", | 	"#657b83",  /* 11: bryellow */ | ||||||
| 	"green", | 	"#839496",  /* 12: brblue   */ | ||||||
| 	"yellow", | 	"#6c71c4",  /* 13: brmagenta*/ | ||||||
| 	"#5c5cff", | 	"#93a1a1",  /* 14: brcyan   */ | ||||||
| 	"magenta", | 	"#fdf6e3",  /* 15: brwhite  */ | ||||||
| 	"cyan", |  | ||||||
| 	"white", |  | ||||||
|  |  | ||||||
| 	[255] = 0, |  | ||||||
|  |  | ||||||
| 	/* more colors can be added after 255 to use with DefaultXX */ |  | ||||||
| 	"#cccccc", |  | ||||||
| 	"#555555", |  | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -116,10 +108,10 @@ static const char *colorname[] = { | |||||||
|  * Default colors (colorname index) |  * Default colors (colorname index) | ||||||
|  * foreground, background, cursor, reverse cursor |  * foreground, background, cursor, reverse cursor | ||||||
|  */ |  */ | ||||||
| static unsigned int defaultfg = 7; | static unsigned int defaultfg = 12; | ||||||
| static unsigned int defaultbg = 0; | static unsigned int defaultbg = 8; | ||||||
| static unsigned int defaultcs = 256; | static unsigned int defaultcs = 14; | ||||||
| static unsigned int defaultrcs = 257; | static unsigned int defaultrcs = 15; | ||||||
|  |  | ||||||
| /* | /* | ||||||
|  * Default shape of cursor |  * Default shape of cursor | ||||||
|   | |||||||
							
								
								
									
										458
									
								
								config.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										458
									
								
								config.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,458 @@ | |||||||
|  | /* See LICENSE file for copyright and license details. */ | ||||||
|  |  | ||||||
|  | /* | ||||||
|  |  * appearance | ||||||
|  |  * | ||||||
|  |  * font: see http://freedesktop.org/software/fontconfig/fontconfig-user.html | ||||||
|  |  */ | ||||||
|  | static char font[] = "Inconsolata:size=10:antialias=true:hinting=true"; | ||||||
|  | static int borderpx = 2; | ||||||
|  |  | ||||||
|  | /* | ||||||
|  |  * What program is execed by st depends of these precedence rules: | ||||||
|  |  * 1: program passed with -e | ||||||
|  |  * 2: utmp option | ||||||
|  |  * 3: SHELL environment variable | ||||||
|  |  * 4: value of shell in /etc/passwd | ||||||
|  |  * 5: value of shell in config.h | ||||||
|  |  */ | ||||||
|  | static char shell[] = "/bin/sh"; | ||||||
|  | static char *utmp = NULL; | ||||||
|  | static char stty_args[] = "stty raw pass8 nl -echo -iexten -cstopb 38400"; | ||||||
|  |  | ||||||
|  | /* identification sequence returned in DA and DECID */ | ||||||
|  | static 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: " `'\"()[]{}" | ||||||
|  |  */ | ||||||
|  | static char worddelimiters[] = " │`'\"()[]{}"; | ||||||
|  |  | ||||||
|  | /* selection timeouts (in milliseconds) */ | ||||||
|  | static unsigned int doubleclicktimeout = 300; | ||||||
|  | static unsigned int tripleclicktimeout = 600; | ||||||
|  |  | ||||||
|  | /* alt screens */ | ||||||
|  | static int allowaltscreen = 1; | ||||||
|  |  | ||||||
|  | /* frames per second st should at maximum draw to the screen */ | ||||||
|  | static unsigned int xfps = 120; | ||||||
|  | static unsigned int actionfps = 30; | ||||||
|  |  | ||||||
|  | /* | ||||||
|  |  * 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 */ | ||||||
|  | static 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 | ||||||
|  |  */ | ||||||
|  | static unsigned int tabspaces = 4; | ||||||
|  |  | ||||||
|  | /* Terminal colors (16 first used in escape sequence) */ | ||||||
|  | static const char *colorname[] = { | ||||||
|  | 	/* solarized dark */ | ||||||
|  | 	"#03171d",  /*  0: black    */ | ||||||
|  | 	"#dc322f",  /*  1: red      */ | ||||||
|  | 	"#859900",  /*  2: green    */ | ||||||
|  | 	"#b58900",  /*  3: yellow   */ | ||||||
|  | 	"#268bd2",  /*  4: blue     */ | ||||||
|  | 	"#d33682",  /*  5: magenta  */ | ||||||
|  | 	"#2aa198",  /*  6: cyan     */ | ||||||
|  | 	"#eee8d5",  /*  7: white    */ | ||||||
|  | 	"#001014",  /*  8: brblack  */ | ||||||
|  | 	"#cb4b16",  /*  9: brred    */ | ||||||
|  | 	"#586e75",  /* 10: brgreen  */ | ||||||
|  | 	"#657b83",  /* 11: bryellow */ | ||||||
|  | 	"#839496",  /* 12: brblue   */ | ||||||
|  | 	"#6c71c4",  /* 13: brmagenta*/ | ||||||
|  | 	"#93a1a1",  /* 14: brcyan   */ | ||||||
|  | 	"#fdf6e3",  /* 15: brwhite  */ | ||||||
|  | }; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /* | ||||||
|  |  * Default colors (colorname index) | ||||||
|  |  * foreground, background, cursor, reverse cursor | ||||||
|  |  */ | ||||||
|  | static unsigned int defaultfg = 12; | ||||||
|  | static unsigned int defaultbg = 8; | ||||||
|  | static unsigned int defaultcs = 14; | ||||||
|  | static unsigned int defaultrcs = 15; | ||||||
|  |  | ||||||
|  | /* | ||||||
|  |  * 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; | ||||||
|  |  | ||||||
|  | /* | ||||||
|  |  * Internal mouse shortcuts. | ||||||
|  |  * Beware that overloading Button1 will disable the selection. | ||||||
|  |  */ | ||||||
|  | static MouseShortcut mshortcuts[] = { | ||||||
|  | 	/* button               mask            string */ | ||||||
|  | 	{ Button4,              XK_ANY_MOD,     "\031" }, | ||||||
|  | 	{ Button5,              XK_ANY_MOD,     "\005" }, | ||||||
|  | }; | ||||||
|  |  | ||||||
|  | /* Internal keyboard shortcuts. */ | ||||||
|  | #define MODKEY Mod1Mask | ||||||
|  |  | ||||||
|  | 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} }, | ||||||
|  | 	{ MODKEY|ShiftMask,     XK_Prior,       xzoom,          {.f = +2} }, | ||||||
|  | 	{ MODKEY|ShiftMask,     XK_Next,        xzoom,          {.f = -2} }, | ||||||
|  | 	{ MODKEY|ShiftMask,     XK_Home,        xzoomreset,     {.f =  0} }, | ||||||
|  | 	{ ShiftMask,            XK_Insert,      selpaste,       {.i =  0} }, | ||||||
|  | 	{ MODKEY|ShiftMask,     XK_Insert,      clippaste,      {.i =  0} }, | ||||||
|  | 	{ MODKEY|ShiftMask,     XK_C,           clipcopy,       {.i =  0} }, | ||||||
|  | 	{ MODKEY|ShiftMask,     XK_V,           clippaste,      {.i =  0} }, | ||||||
|  | 	{ MODKEY,               XK_Num_Lock,    numlock,        {.i =  0} }, | ||||||
|  | 	{ MODKEY,               XK_Control_L,   iso14755,       {.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 | ||||||
|  |  * crlf value | ||||||
|  |  * * 0: no value | ||||||
|  |  * * > 0: crlf mode is enabled | ||||||
|  |  * * < 0: crlf mode is 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; | ||||||
|  |  | ||||||
|  | /* | ||||||
|  |  * Override mouse-select 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 forceselmod = ShiftMask; | ||||||
|  |  | ||||||
|  | /* | ||||||
|  |  * 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 crlf */ | ||||||
|  | 	{ XK_KP_Home,       ShiftMask,      "\033[2J",       0,   -1,    0}, | ||||||
|  | 	{ XK_KP_Home,       ShiftMask,      "\033[1;2H",     0,   +1,    0}, | ||||||
|  | 	{ XK_KP_Home,       XK_ANY_MOD,     "\033[H",        0,   -1,    0}, | ||||||
|  | 	{ XK_KP_Home,       XK_ANY_MOD,     "\033[1~",       0,   +1,    0}, | ||||||
|  | 	{ XK_KP_Up,         XK_ANY_MOD,     "\033Ox",       +1,    0,    0}, | ||||||
|  | 	{ XK_KP_Up,         XK_ANY_MOD,     "\033[A",        0,   -1,    0}, | ||||||
|  | 	{ XK_KP_Up,         XK_ANY_MOD,     "\033OA",        0,   +1,    0}, | ||||||
|  | 	{ XK_KP_Down,       XK_ANY_MOD,     "\033Or",       +1,    0,    0}, | ||||||
|  | 	{ XK_KP_Down,       XK_ANY_MOD,     "\033[B",        0,   -1,    0}, | ||||||
|  | 	{ XK_KP_Down,       XK_ANY_MOD,     "\033OB",        0,   +1,    0}, | ||||||
|  | 	{ XK_KP_Left,       XK_ANY_MOD,     "\033Ot",       +1,    0,    0}, | ||||||
|  | 	{ XK_KP_Left,       XK_ANY_MOD,     "\033[D",        0,   -1,    0}, | ||||||
|  | 	{ XK_KP_Left,       XK_ANY_MOD,     "\033OD",        0,   +1,    0}, | ||||||
|  | 	{ XK_KP_Right,      XK_ANY_MOD,     "\033Ov",       +1,    0,    0}, | ||||||
|  | 	{ XK_KP_Right,      XK_ANY_MOD,     "\033[C",        0,   -1,    0}, | ||||||
|  | 	{ XK_KP_Right,      XK_ANY_MOD,     "\033OC",        0,   +1,    0}, | ||||||
|  | 	{ XK_KP_Prior,      ShiftMask,      "\033[5;2~",     0,    0,    0}, | ||||||
|  | 	{ XK_KP_Prior,      XK_ANY_MOD,     "\033[5~",       0,    0,    0}, | ||||||
|  | 	{ XK_KP_Begin,      XK_ANY_MOD,     "\033[E",        0,    0,    0}, | ||||||
|  | 	{ XK_KP_End,        ControlMask,    "\033[J",       -1,    0,    0}, | ||||||
|  | 	{ XK_KP_End,        ControlMask,    "\033[1;5F",    +1,    0,    0}, | ||||||
|  | 	{ XK_KP_End,        ShiftMask,      "\033[K",       -1,    0,    0}, | ||||||
|  | 	{ XK_KP_End,        ShiftMask,      "\033[1;2F",    +1,    0,    0}, | ||||||
|  | 	{ XK_KP_End,        XK_ANY_MOD,     "\033[4~",       0,    0,    0}, | ||||||
|  | 	{ XK_KP_Next,       ShiftMask,      "\033[6;2~",     0,    0,    0}, | ||||||
|  | 	{ XK_KP_Next,       XK_ANY_MOD,     "\033[6~",       0,    0,    0}, | ||||||
|  | 	{ XK_KP_Insert,     ShiftMask,      "\033[2;2~",    +1,    0,    0}, | ||||||
|  | 	{ XK_KP_Insert,     ShiftMask,      "\033[4l",      -1,    0,    0}, | ||||||
|  | 	{ XK_KP_Insert,     ControlMask,    "\033[L",       -1,    0,    0}, | ||||||
|  | 	{ XK_KP_Insert,     ControlMask,    "\033[2;5~",    +1,    0,    0}, | ||||||
|  | 	{ XK_KP_Insert,     XK_ANY_MOD,     "\033[4h",      -1,    0,    0}, | ||||||
|  | 	{ XK_KP_Insert,     XK_ANY_MOD,     "\033[2~",      +1,    0,    0}, | ||||||
|  | 	{ XK_KP_Delete,     ControlMask,    "\033[M",       -1,    0,    0}, | ||||||
|  | 	{ XK_KP_Delete,     ControlMask,    "\033[3;5~",    +1,    0,    0}, | ||||||
|  | 	{ XK_KP_Delete,     ShiftMask,      "\033[2K",      -1,    0,    0}, | ||||||
|  | 	{ XK_KP_Delete,     ShiftMask,      "\033[3;2~",    +1,    0,    0}, | ||||||
|  | 	{ XK_KP_Delete,     XK_ANY_MOD,     "\033[P",       -1,    0,    0}, | ||||||
|  | 	{ XK_KP_Delete,     XK_ANY_MOD,     "\033[3~",      +1,    0,    0}, | ||||||
|  | 	{ XK_KP_Multiply,   XK_ANY_MOD,     "\033Oj",       +2,    0,    0}, | ||||||
|  | 	{ XK_KP_Add,        XK_ANY_MOD,     "\033Ok",       +2,    0,    0}, | ||||||
|  | 	{ XK_KP_Enter,      XK_ANY_MOD,     "\033OM",       +2,    0,    0}, | ||||||
|  | 	{ XK_KP_Enter,      XK_ANY_MOD,     "\r",           -1,    0,   -1}, | ||||||
|  | 	{ XK_KP_Enter,      XK_ANY_MOD,     "\r\n",         -1,    0,   +1}, | ||||||
|  | 	{ XK_KP_Subtract,   XK_ANY_MOD,     "\033Om",       +2,    0,    0}, | ||||||
|  | 	{ XK_KP_Decimal,    XK_ANY_MOD,     "\033On",       +2,    0,    0}, | ||||||
|  | 	{ XK_KP_Divide,     XK_ANY_MOD,     "\033Oo",       +2,    0,    0}, | ||||||
|  | 	{ XK_KP_0,          XK_ANY_MOD,     "\033Op",       +2,    0,    0}, | ||||||
|  | 	{ XK_KP_1,          XK_ANY_MOD,     "\033Oq",       +2,    0,    0}, | ||||||
|  | 	{ XK_KP_2,          XK_ANY_MOD,     "\033Or",       +2,    0,    0}, | ||||||
|  | 	{ XK_KP_3,          XK_ANY_MOD,     "\033Os",       +2,    0,    0}, | ||||||
|  | 	{ XK_KP_4,          XK_ANY_MOD,     "\033Ot",       +2,    0,    0}, | ||||||
|  | 	{ XK_KP_5,          XK_ANY_MOD,     "\033Ou",       +2,    0,    0}, | ||||||
|  | 	{ XK_KP_6,          XK_ANY_MOD,     "\033Ov",       +2,    0,    0}, | ||||||
|  | 	{ XK_KP_7,          XK_ANY_MOD,     "\033Ow",       +2,    0,    0}, | ||||||
|  | 	{ XK_KP_8,          XK_ANY_MOD,     "\033Ox",       +2,    0,    0}, | ||||||
|  | 	{ XK_KP_9,          XK_ANY_MOD,     "\033Oy",       +2,    0,    0}, | ||||||
|  | 	{ XK_Up,            ShiftMask,      "\033[1;2A",     0,    0,    0}, | ||||||
|  | 	{ XK_Up,            Mod1Mask,       "\033[1;3A",     0,    0,    0}, | ||||||
|  | 	{ XK_Up,         ShiftMask|Mod1Mask,"\033[1;4A",     0,    0,    0}, | ||||||
|  | 	{ XK_Up,            ControlMask,    "\033[1;5A",     0,    0,    0}, | ||||||
|  | 	{ XK_Up,      ShiftMask|ControlMask,"\033[1;6A",     0,    0,    0}, | ||||||
|  | 	{ XK_Up,       ControlMask|Mod1Mask,"\033[1;7A",     0,    0,    0}, | ||||||
|  | 	{ XK_Up,ShiftMask|ControlMask|Mod1Mask,"\033[1;8A",  0,    0,    0}, | ||||||
|  | 	{ XK_Up,            XK_ANY_MOD,     "\033[A",        0,   -1,    0}, | ||||||
|  | 	{ XK_Up,            XK_ANY_MOD,     "\033OA",        0,   +1,    0}, | ||||||
|  | 	{ XK_Down,          ShiftMask,      "\033[1;2B",     0,    0,    0}, | ||||||
|  | 	{ XK_Down,          Mod1Mask,       "\033[1;3B",     0,    0,    0}, | ||||||
|  | 	{ XK_Down,       ShiftMask|Mod1Mask,"\033[1;4B",     0,    0,    0}, | ||||||
|  | 	{ XK_Down,          ControlMask,    "\033[1;5B",     0,    0,    0}, | ||||||
|  | 	{ XK_Down,    ShiftMask|ControlMask,"\033[1;6B",     0,    0,    0}, | ||||||
|  | 	{ XK_Down,     ControlMask|Mod1Mask,"\033[1;7B",     0,    0,    0}, | ||||||
|  | 	{ XK_Down,ShiftMask|ControlMask|Mod1Mask,"\033[1;8B",0,    0,    0}, | ||||||
|  | 	{ XK_Down,          XK_ANY_MOD,     "\033[B",        0,   -1,    0}, | ||||||
|  | 	{ XK_Down,          XK_ANY_MOD,     "\033OB",        0,   +1,    0}, | ||||||
|  | 	{ XK_Left,          ShiftMask,      "\033[1;2D",     0,    0,    0}, | ||||||
|  | 	{ XK_Left,          Mod1Mask,       "\033[1;3D",     0,    0,    0}, | ||||||
|  | 	{ XK_Left,       ShiftMask|Mod1Mask,"\033[1;4D",     0,    0,    0}, | ||||||
|  | 	{ XK_Left,          ControlMask,    "\033[1;5D",     0,    0,    0}, | ||||||
|  | 	{ XK_Left,    ShiftMask|ControlMask,"\033[1;6D",     0,    0,    0}, | ||||||
|  | 	{ XK_Left,     ControlMask|Mod1Mask,"\033[1;7D",     0,    0,    0}, | ||||||
|  | 	{ XK_Left,ShiftMask|ControlMask|Mod1Mask,"\033[1;8D",0,    0,    0}, | ||||||
|  | 	{ XK_Left,          XK_ANY_MOD,     "\033[D",        0,   -1,    0}, | ||||||
|  | 	{ XK_Left,          XK_ANY_MOD,     "\033OD",        0,   +1,    0}, | ||||||
|  | 	{ XK_Right,         ShiftMask,      "\033[1;2C",     0,    0,    0}, | ||||||
|  | 	{ XK_Right,         Mod1Mask,       "\033[1;3C",     0,    0,    0}, | ||||||
|  | 	{ XK_Right,      ShiftMask|Mod1Mask,"\033[1;4C",     0,    0,    0}, | ||||||
|  | 	{ XK_Right,         ControlMask,    "\033[1;5C",     0,    0,    0}, | ||||||
|  | 	{ XK_Right,   ShiftMask|ControlMask,"\033[1;6C",     0,    0,    0}, | ||||||
|  | 	{ XK_Right,    ControlMask|Mod1Mask,"\033[1;7C",     0,    0,    0}, | ||||||
|  | 	{ XK_Right,ShiftMask|ControlMask|Mod1Mask,"\033[1;8C",0,   0,    0}, | ||||||
|  | 	{ XK_Right,         XK_ANY_MOD,     "\033[C",        0,   -1,    0}, | ||||||
|  | 	{ XK_Right,         XK_ANY_MOD,     "\033OC",        0,   +1,    0}, | ||||||
|  | 	{ XK_ISO_Left_Tab,  ShiftMask,      "\033[Z",        0,    0,    0}, | ||||||
|  | 	{ XK_Return,        Mod1Mask,       "\033\r",        0,    0,   -1}, | ||||||
|  | 	{ XK_Return,        Mod1Mask,       "\033\r\n",      0,    0,   +1}, | ||||||
|  | 	{ XK_Return,        XK_ANY_MOD,     "\r",            0,    0,   -1}, | ||||||
|  | 	{ XK_Return,        XK_ANY_MOD,     "\r\n",          0,    0,   +1}, | ||||||
|  | 	{ XK_Insert,        ShiftMask,      "\033[4l",      -1,    0,    0}, | ||||||
|  | 	{ XK_Insert,        ShiftMask,      "\033[2;2~",    +1,    0,    0}, | ||||||
|  | 	{ XK_Insert,        ControlMask,    "\033[L",       -1,    0,    0}, | ||||||
|  | 	{ XK_Insert,        ControlMask,    "\033[2;5~",    +1,    0,    0}, | ||||||
|  | 	{ XK_Insert,        XK_ANY_MOD,     "\033[4h",      -1,    0,    0}, | ||||||
|  | 	{ XK_Insert,        XK_ANY_MOD,     "\033[2~",      +1,    0,    0}, | ||||||
|  | 	{ XK_Delete,        ControlMask,    "\033[M",       -1,    0,    0}, | ||||||
|  | 	{ XK_Delete,        ControlMask,    "\033[3;5~",    +1,    0,    0}, | ||||||
|  | 	{ XK_Delete,        ShiftMask,      "\033[2K",      -1,    0,    0}, | ||||||
|  | 	{ XK_Delete,        ShiftMask,      "\033[3;2~",    +1,    0,    0}, | ||||||
|  | 	{ XK_Delete,        XK_ANY_MOD,     "\033[P",       -1,    0,    0}, | ||||||
|  | 	{ XK_Delete,        XK_ANY_MOD,     "\033[3~",      +1,    0,    0}, | ||||||
|  | 	{ XK_BackSpace,     XK_NO_MOD,      "\177",          0,    0,    0}, | ||||||
|  | 	{ XK_BackSpace,     Mod1Mask,       "\033\177",      0,    0,    0}, | ||||||
|  | 	{ XK_Home,          ShiftMask,      "\033[2J",       0,   -1,    0}, | ||||||
|  | 	{ XK_Home,          ShiftMask,      "\033[1;2H",     0,   +1,    0}, | ||||||
|  | 	{ XK_Home,          XK_ANY_MOD,     "\033[H",        0,   -1,    0}, | ||||||
|  | 	{ XK_Home,          XK_ANY_MOD,     "\033[1~",       0,   +1,    0}, | ||||||
|  | 	{ XK_End,           ControlMask,    "\033[J",       -1,    0,    0}, | ||||||
|  | 	{ XK_End,           ControlMask,    "\033[1;5F",    +1,    0,    0}, | ||||||
|  | 	{ XK_End,           ShiftMask,      "\033[K",       -1,    0,    0}, | ||||||
|  | 	{ XK_End,           ShiftMask,      "\033[1;2F",    +1,    0,    0}, | ||||||
|  | 	{ XK_End,           XK_ANY_MOD,     "\033[4~",       0,    0,    0}, | ||||||
|  | 	{ XK_Prior,         ControlMask,    "\033[5;5~",     0,    0,    0}, | ||||||
|  | 	{ XK_Prior,         ShiftMask,      "\033[5;2~",     0,    0,    0}, | ||||||
|  | 	{ XK_Prior,         XK_ANY_MOD,     "\033[5~",       0,    0,    0}, | ||||||
|  | 	{ XK_Next,          ControlMask,    "\033[6;5~",     0,    0,    0}, | ||||||
|  | 	{ XK_Next,          ShiftMask,      "\033[6;2~",     0,    0,    0}, | ||||||
|  | 	{ XK_Next,          XK_ANY_MOD,     "\033[6~",       0,    0,    0}, | ||||||
|  | 	{ XK_F1,            XK_NO_MOD,      "\033OP" ,       0,    0,    0}, | ||||||
|  | 	{ XK_F1, /* F13 */  ShiftMask,      "\033[1;2P",     0,    0,    0}, | ||||||
|  | 	{ XK_F1, /* F25 */  ControlMask,    "\033[1;5P",     0,    0,    0}, | ||||||
|  | 	{ XK_F1, /* F37 */  Mod4Mask,       "\033[1;6P",     0,    0,    0}, | ||||||
|  | 	{ XK_F1, /* F49 */  Mod1Mask,       "\033[1;3P",     0,    0,    0}, | ||||||
|  | 	{ XK_F1, /* F61 */  Mod3Mask,       "\033[1;4P",     0,    0,    0}, | ||||||
|  | 	{ XK_F2,            XK_NO_MOD,      "\033OQ" ,       0,    0,    0}, | ||||||
|  | 	{ XK_F2, /* F14 */  ShiftMask,      "\033[1;2Q",     0,    0,    0}, | ||||||
|  | 	{ XK_F2, /* F26 */  ControlMask,    "\033[1;5Q",     0,    0,    0}, | ||||||
|  | 	{ XK_F2, /* F38 */  Mod4Mask,       "\033[1;6Q",     0,    0,    0}, | ||||||
|  | 	{ XK_F2, /* F50 */  Mod1Mask,       "\033[1;3Q",     0,    0,    0}, | ||||||
|  | 	{ XK_F2, /* F62 */  Mod3Mask,       "\033[1;4Q",     0,    0,    0}, | ||||||
|  | 	{ XK_F3,            XK_NO_MOD,      "\033OR" ,       0,    0,    0}, | ||||||
|  | 	{ XK_F3, /* F15 */  ShiftMask,      "\033[1;2R",     0,    0,    0}, | ||||||
|  | 	{ XK_F3, /* F27 */  ControlMask,    "\033[1;5R",     0,    0,    0}, | ||||||
|  | 	{ XK_F3, /* F39 */  Mod4Mask,       "\033[1;6R",     0,    0,    0}, | ||||||
|  | 	{ XK_F3, /* F51 */  Mod1Mask,       "\033[1;3R",     0,    0,    0}, | ||||||
|  | 	{ XK_F3, /* F63 */  Mod3Mask,       "\033[1;4R",     0,    0,    0}, | ||||||
|  | 	{ XK_F4,            XK_NO_MOD,      "\033OS" ,       0,    0,    0}, | ||||||
|  | 	{ XK_F4, /* F16 */  ShiftMask,      "\033[1;2S",     0,    0,    0}, | ||||||
|  | 	{ XK_F4, /* F28 */  ControlMask,    "\033[1;5S",     0,    0,    0}, | ||||||
|  | 	{ XK_F4, /* F40 */  Mod4Mask,       "\033[1;6S",     0,    0,    0}, | ||||||
|  | 	{ XK_F4, /* F52 */  Mod1Mask,       "\033[1;3S",     0,    0,    0}, | ||||||
|  | 	{ XK_F5,            XK_NO_MOD,      "\033[15~",      0,    0,    0}, | ||||||
|  | 	{ XK_F5, /* F17 */  ShiftMask,      "\033[15;2~",    0,    0,    0}, | ||||||
|  | 	{ XK_F5, /* F29 */  ControlMask,    "\033[15;5~",    0,    0,    0}, | ||||||
|  | 	{ XK_F5, /* F41 */  Mod4Mask,       "\033[15;6~",    0,    0,    0}, | ||||||
|  | 	{ XK_F5, /* F53 */  Mod1Mask,       "\033[15;3~",    0,    0,    0}, | ||||||
|  | 	{ XK_F6,            XK_NO_MOD,      "\033[17~",      0,    0,    0}, | ||||||
|  | 	{ XK_F6, /* F18 */  ShiftMask,      "\033[17;2~",    0,    0,    0}, | ||||||
|  | 	{ XK_F6, /* F30 */  ControlMask,    "\033[17;5~",    0,    0,    0}, | ||||||
|  | 	{ XK_F6, /* F42 */  Mod4Mask,       "\033[17;6~",    0,    0,    0}, | ||||||
|  | 	{ XK_F6, /* F54 */  Mod1Mask,       "\033[17;3~",    0,    0,    0}, | ||||||
|  | 	{ XK_F7,            XK_NO_MOD,      "\033[18~",      0,    0,    0}, | ||||||
|  | 	{ XK_F7, /* F19 */  ShiftMask,      "\033[18;2~",    0,    0,    0}, | ||||||
|  | 	{ XK_F7, /* F31 */  ControlMask,    "\033[18;5~",    0,    0,    0}, | ||||||
|  | 	{ XK_F7, /* F43 */  Mod4Mask,       "\033[18;6~",    0,    0,    0}, | ||||||
|  | 	{ XK_F7, /* F55 */  Mod1Mask,       "\033[18;3~",    0,    0,    0}, | ||||||
|  | 	{ XK_F8,            XK_NO_MOD,      "\033[19~",      0,    0,    0}, | ||||||
|  | 	{ XK_F8, /* F20 */  ShiftMask,      "\033[19;2~",    0,    0,    0}, | ||||||
|  | 	{ XK_F8, /* F32 */  ControlMask,    "\033[19;5~",    0,    0,    0}, | ||||||
|  | 	{ XK_F8, /* F44 */  Mod4Mask,       "\033[19;6~",    0,    0,    0}, | ||||||
|  | 	{ XK_F8, /* F56 */  Mod1Mask,       "\033[19;3~",    0,    0,    0}, | ||||||
|  | 	{ XK_F9,            XK_NO_MOD,      "\033[20~",      0,    0,    0}, | ||||||
|  | 	{ XK_F9, /* F21 */  ShiftMask,      "\033[20;2~",    0,    0,    0}, | ||||||
|  | 	{ XK_F9, /* F33 */  ControlMask,    "\033[20;5~",    0,    0,    0}, | ||||||
|  | 	{ XK_F9, /* F45 */  Mod4Mask,       "\033[20;6~",    0,    0,    0}, | ||||||
|  | 	{ XK_F9, /* F57 */  Mod1Mask,       "\033[20;3~",    0,    0,    0}, | ||||||
|  | 	{ XK_F10,           XK_NO_MOD,      "\033[21~",      0,    0,    0}, | ||||||
|  | 	{ XK_F10, /* F22 */ ShiftMask,      "\033[21;2~",    0,    0,    0}, | ||||||
|  | 	{ XK_F10, /* F34 */ ControlMask,    "\033[21;5~",    0,    0,    0}, | ||||||
|  | 	{ XK_F10, /* F46 */ Mod4Mask,       "\033[21;6~",    0,    0,    0}, | ||||||
|  | 	{ XK_F10, /* F58 */ Mod1Mask,       "\033[21;3~",    0,    0,    0}, | ||||||
|  | 	{ XK_F11,           XK_NO_MOD,      "\033[23~",      0,    0,    0}, | ||||||
|  | 	{ XK_F11, /* F23 */ ShiftMask,      "\033[23;2~",    0,    0,    0}, | ||||||
|  | 	{ XK_F11, /* F35 */ ControlMask,    "\033[23;5~",    0,    0,    0}, | ||||||
|  | 	{ XK_F11, /* F47 */ Mod4Mask,       "\033[23;6~",    0,    0,    0}, | ||||||
|  | 	{ XK_F11, /* F59 */ Mod1Mask,       "\033[23;3~",    0,    0,    0}, | ||||||
|  | 	{ XK_F12,           XK_NO_MOD,      "\033[24~",      0,    0,    0}, | ||||||
|  | 	{ XK_F12, /* F24 */ ShiftMask,      "\033[24;2~",    0,    0,    0}, | ||||||
|  | 	{ XK_F12, /* F36 */ ControlMask,    "\033[24;5~",    0,    0,    0}, | ||||||
|  | 	{ XK_F12, /* F48 */ Mod4Mask,       "\033[24;6~",    0,    0,    0}, | ||||||
|  | 	{ XK_F12, /* F60 */ Mod1Mask,       "\033[24;3~",    0,    0,    0}, | ||||||
|  | 	{ XK_F13,           XK_NO_MOD,      "\033[1;2P",     0,    0,    0}, | ||||||
|  | 	{ XK_F14,           XK_NO_MOD,      "\033[1;2Q",     0,    0,    0}, | ||||||
|  | 	{ XK_F15,           XK_NO_MOD,      "\033[1;2R",     0,    0,    0}, | ||||||
|  | 	{ XK_F16,           XK_NO_MOD,      "\033[1;2S",     0,    0,    0}, | ||||||
|  | 	{ XK_F17,           XK_NO_MOD,      "\033[15;2~",    0,    0,    0}, | ||||||
|  | 	{ XK_F18,           XK_NO_MOD,      "\033[17;2~",    0,    0,    0}, | ||||||
|  | 	{ XK_F19,           XK_NO_MOD,      "\033[18;2~",    0,    0,    0}, | ||||||
|  | 	{ XK_F20,           XK_NO_MOD,      "\033[19;2~",    0,    0,    0}, | ||||||
|  | 	{ XK_F21,           XK_NO_MOD,      "\033[20;2~",    0,    0,    0}, | ||||||
|  | 	{ XK_F22,           XK_NO_MOD,      "\033[21;2~",    0,    0,    0}, | ||||||
|  | 	{ XK_F23,           XK_NO_MOD,      "\033[23;2~",    0,    0,    0}, | ||||||
|  | 	{ XK_F24,           XK_NO_MOD,      "\033[24;2~",    0,    0,    0}, | ||||||
|  | 	{ XK_F25,           XK_NO_MOD,      "\033[1;5P",     0,    0,    0}, | ||||||
|  | 	{ XK_F26,           XK_NO_MOD,      "\033[1;5Q",     0,    0,    0}, | ||||||
|  | 	{ XK_F27,           XK_NO_MOD,      "\033[1;5R",     0,    0,    0}, | ||||||
|  | 	{ XK_F28,           XK_NO_MOD,      "\033[1;5S",     0,    0,    0}, | ||||||
|  | 	{ XK_F29,           XK_NO_MOD,      "\033[15;5~",    0,    0,    0}, | ||||||
|  | 	{ XK_F30,           XK_NO_MOD,      "\033[17;5~",    0,    0,    0}, | ||||||
|  | 	{ XK_F31,           XK_NO_MOD,      "\033[18;5~",    0,    0,    0}, | ||||||
|  | 	{ XK_F32,           XK_NO_MOD,      "\033[19;5~",    0,    0,    0}, | ||||||
|  | 	{ XK_F33,           XK_NO_MOD,      "\033[20;5~",    0,    0,    0}, | ||||||
|  | 	{ XK_F34,           XK_NO_MOD,      "\033[21;5~",    0,    0,    0}, | ||||||
|  | 	{ XK_F35,           XK_NO_MOD,      "\033[23;5~",    0,    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{|}~"; | ||||||
|  |  | ||||||
							
								
								
									
										45
									
								
								st.c
									
									
									
									
									
								
							
							
						
						
									
										45
									
								
								st.c
									
									
									
									
									
								
							| @@ -267,6 +267,11 @@ typedef struct { | |||||||
| 	Draw draw; | 	Draw draw; | ||||||
| 	Visual *vis; | 	Visual *vis; | ||||||
| 	XSetWindowAttributes attrs; | 	XSetWindowAttributes attrs; | ||||||
|  | 	/* Here, we use the term *pointer* to differentiate the cursor | ||||||
|  | 	 * one sees when hovering the mouse over the terminal from, e.g., | ||||||
|  | 	 * a green rectangle where text would be entered. */ | ||||||
|  | 	Cursor vpointer, bpointer; /* visible and hidden pointers */ | ||||||
|  | 	int pointerisvisible; | ||||||
| 	int scr; | 	int scr; | ||||||
| 	int isfixed; /* is fixed geometry? */ | 	int isfixed; /* is fixed geometry? */ | ||||||
| 	int l, t; /* left and top offset */ | 	int l, t; /* left and top offset */ | ||||||
| @@ -1274,6 +1279,8 @@ xsetsel(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(0); | 		selclear(0); | ||||||
|  |  | ||||||
|  | 	clipcopy(NULL); | ||||||
| } | } | ||||||
|  |  | ||||||
| void | void | ||||||
| @@ -1302,6 +1309,13 @@ bmotion(XEvent *e) | |||||||
| { | { | ||||||
| 	int oldey, oldex, oldsby, oldsey; | 	int oldey, oldex, oldsby, oldsey; | ||||||
|  |  | ||||||
|  | 	if(!xw.pointerisvisible) { | ||||||
|  | 		XDefineCursor(xw.dpy, xw.win, xw.vpointer); | ||||||
|  | 		xw.pointerisvisible = 1; | ||||||
|  | 		if(!IS_SET(MODE_MOUSEMANY)) | ||||||
|  | 			xsetpointermotion(0); | ||||||
|  | 	} | ||||||
|  |  | ||||||
| 	if (IS_SET(MODE_MOUSE) && !(e->xbutton.state & forceselmod)) { | 	if (IS_SET(MODE_MOUSE) && !(e->xbutton.state & forceselmod)) { | ||||||
| 		mousereport(e); | 		mousereport(e); | ||||||
| 		return; | 		return; | ||||||
| @@ -2234,11 +2248,12 @@ tsetmode(int priv, int set, int *args, int narg) | |||||||
| 				MODBIT(term.mode, set, MODE_BRCKTPASTE); | 				MODBIT(term.mode, set, MODE_BRCKTPASTE); | ||||||
| 				break; | 				break; | ||||||
| 			/* Not implemented mouse modes. See comments there. */ | 			/* Not implemented mouse modes. See comments there. */ | ||||||
| 			case 1001: /* mouse highlight mode; can hang the |  | ||||||
| 				      terminal by design when implemented. */ |  | ||||||
| 			case 1005: /* UTF-8 mouse mode; will confuse | 			case 1005: /* UTF-8 mouse mode; will confuse | ||||||
| 				      applications not supporting UTF-8 | 				      applications not supporting UTF-8 | ||||||
| 				      and luit. */ | 				      and luit. */ | ||||||
|  | 				break; // so we don't print error message below | ||||||
|  | 			case 1001: /* mouse highlight mode; can hang the | ||||||
|  | 				      terminal by design when implemented. */ | ||||||
| 			case 1015: /* urxvt mangled mouse mode; incompatible | 			case 1015: /* urxvt mangled mouse mode; incompatible | ||||||
| 				      and can be mistaken for other control | 				      and can be mistaken for other control | ||||||
| 				      codes. */ | 				      codes. */ | ||||||
| @@ -3572,10 +3587,10 @@ void | |||||||
| xinit(void) | xinit(void) | ||||||
| { | { | ||||||
| 	XGCValues gcvalues; | 	XGCValues gcvalues; | ||||||
| 	Cursor cursor; |  | ||||||
| 	Window parent; | 	Window parent; | ||||||
| 	pid_t thispid = getpid(); | 	pid_t thispid = getpid(); | ||||||
| 	XColor xmousefg, xmousebg; | 	XColor xmousefg, xmousebg; | ||||||
|  | 	Pixmap blankpm; | ||||||
|  |  | ||||||
| 	if (!(xw.dpy = XOpenDisplay(NULL))) | 	if (!(xw.dpy = XOpenDisplay(NULL))) | ||||||
| 		die("Can't open display\n"); | 		die("Can't open display\n"); | ||||||
| @@ -3648,8 +3663,9 @@ xinit(void) | |||||||
| 		die("XCreateIC failed. Could not obtain input method.\n"); | 		die("XCreateIC failed. Could not obtain input method.\n"); | ||||||
|  |  | ||||||
| 	/* white cursor, black outline */ | 	/* white cursor, black outline */ | ||||||
| 	cursor = XCreateFontCursor(xw.dpy, mouseshape); | 	xw.pointerisvisible = 1; | ||||||
| 	XDefineCursor(xw.dpy, xw.win, cursor); | 	xw.vpointer = XCreateFontCursor(xw.dpy, mouseshape); | ||||||
|  | 	XDefineCursor(xw.dpy, xw.win, xw.vpointer); | ||||||
|  |  | ||||||
| 	if (XParseColor(xw.dpy, xw.cmap, colorname[mousefg], &xmousefg) == 0) { | 	if (XParseColor(xw.dpy, xw.cmap, colorname[mousefg], &xmousefg) == 0) { | ||||||
| 		xmousefg.red   = 0xffff; | 		xmousefg.red   = 0xffff; | ||||||
| @@ -3663,7 +3679,10 @@ xinit(void) | |||||||
| 		xmousebg.blue  = 0x0000; | 		xmousebg.blue  = 0x0000; | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	XRecolorCursor(xw.dpy, cursor, &xmousefg, &xmousebg); | 	XRecolorCursor(xw.dpy, xw.vpointer, &xmousefg, &xmousebg); | ||||||
|  | 	blankpm = XCreateBitmapFromData(xw.dpy, xw.win, &(char){0}, 1, 1); | ||||||
|  | 	xw.bpointer = XCreatePixmapCursor(xw.dpy, blankpm, blankpm, | ||||||
|  | 					  &xmousefg, &xmousebg, 0, 0); | ||||||
|  |  | ||||||
| 	xw.xembed = XInternAtom(xw.dpy, "_XEMBED", False); | 	xw.xembed = XInternAtom(xw.dpy, "_XEMBED", False); | ||||||
| 	xw.wmdeletewin = XInternAtom(xw.dpy, "WM_DELETE_WINDOW", False); | 	xw.wmdeletewin = XInternAtom(xw.dpy, "WM_DELETE_WINDOW", False); | ||||||
| @@ -3712,13 +3731,13 @@ xmakeglyphfontspecs(XftGlyphFontSpec *specs, const Glyph *glyphs, int len, int x | |||||||
| 			frcflags = FRC_NORMAL; | 			frcflags = FRC_NORMAL; | ||||||
| 			runewidth = xw.cw * ((mode & ATTR_WIDE) ? 2.0f : 1.0f); | 			runewidth = xw.cw * ((mode & ATTR_WIDE) ? 2.0f : 1.0f); | ||||||
| 			if ((mode & ATTR_ITALIC) && (mode & ATTR_BOLD)) { | 			if ((mode & ATTR_ITALIC) && (mode & ATTR_BOLD)) { | ||||||
| 				font = &dc.ibfont; | 				font = &dc.ifont; | ||||||
| 				frcflags = FRC_ITALICBOLD; | 				frcflags = FRC_ITALICBOLD; | ||||||
| 			} else if (mode & ATTR_ITALIC) { | 			} else if (mode & ATTR_ITALIC) { | ||||||
| 				font = &dc.ifont; | 				font = &dc.ifont; | ||||||
| 				frcflags = FRC_ITALIC; | 				frcflags = FRC_ITALIC; | ||||||
| 			} else if (mode & ATTR_BOLD) { | 			} else if (mode & ATTR_BOLD) { | ||||||
| 				font = &dc.bfont; | 				font = &dc.font; | ||||||
| 				frcflags = FRC_BOLD; | 				frcflags = FRC_BOLD; | ||||||
| 			} | 			} | ||||||
| 			yp = winy + font->ascent; | 			yp = winy + font->ascent; | ||||||
| @@ -3855,7 +3874,7 @@ xdrawglyphfontspecs(const XftGlyphFontSpec *specs, Glyph base, int len, int x, i | |||||||
|  |  | ||||||
| 	/* Change basic system colors [0-7] to bright system colors [8-15] */ | 	/* Change basic system colors [0-7] to bright system colors [8-15] */ | ||||||
| 	if ((base.mode & ATTR_BOLD_FAINT) == ATTR_BOLD && BETWEEN(base.fg, 0, 7)) | 	if ((base.mode & ATTR_BOLD_FAINT) == ATTR_BOLD && BETWEEN(base.fg, 0, 7)) | ||||||
| 		fg = &dc.col[base.fg + 8]; | 		fg = &dc.col[base.fg]; | ||||||
|  |  | ||||||
| 	if (IS_SET(MODE_REVERSE)) { | 	if (IS_SET(MODE_REVERSE)) { | ||||||
| 		if (fg == &dc.col[defaultfg]) { | 		if (fg == &dc.col[defaultfg]) { | ||||||
| @@ -4162,6 +4181,8 @@ unmap(XEvent *ev) | |||||||
| void | void | ||||||
| xsetpointermotion(int set) | xsetpointermotion(int set) | ||||||
| { | { | ||||||
|  | 	if(!set && !xw.pointerisvisible) | ||||||
|  | 		return; | ||||||
| 	MODBIT(xw.attrs.event_mask, set, PointerMotionMask); | 	MODBIT(xw.attrs.event_mask, set, PointerMotionMask); | ||||||
| 	XChangeWindowAttributes(xw.dpy, xw.win, CWEventMask, &xw.attrs); | 	XChangeWindowAttributes(xw.dpy, xw.win, CWEventMask, &xw.attrs); | ||||||
| } | } | ||||||
| @@ -4261,6 +4282,12 @@ kpress(XEvent *ev) | |||||||
| 	Status status; | 	Status status; | ||||||
| 	Shortcut *bp; | 	Shortcut *bp; | ||||||
|  |  | ||||||
|  | 	if(xw.pointerisvisible) { | ||||||
|  | 		XDefineCursor(xw.dpy, xw.win, xw.bpointer); | ||||||
|  | 		xsetpointermotion(1); | ||||||
|  | 		xw.pointerisvisible = 0; | ||||||
|  | 	} | ||||||
|  |  | ||||||
| 	if (IS_SET(MODE_KBDLOCK)) | 	if (IS_SET(MODE_KBDLOCK)) | ||||||
| 		return; | 		return; | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user