Add missed key definitions
This patch adds the keys for the keypad (in both modes, application mode or ansi mode) and function keys. It uses the same convention than xterm and instead of using the XK_Fxx values it generates them using F1-F12 and modifiers. For example: F1 -> ^[OP F1 + Shift = F13 -> ^[[1;2P F1 + Control = F25 -> ^[[1;5P F1 + Mod2 = F37 -> ^[[1;6P F1 + Mod1 = F49 -> ^[[1;3P F1 + Mod3 = F61 -> ^[[1;4P It is also important notice than the terminfo capability kIC (shifted insert key) only can be generated using the keypad keyboard, because the shorcut for selection paste is using the same combination. After this path the number of elements in the Key array becomes high, and maybe a sequencial search is not enough efficient now. --- TODO | 6 +--- config.def.h | 102 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++- st.info | 70 ++++++++++++++++++++++++++++++++++++++-- 3 files changed, 169 insertions(+), 9 deletions(-)
This commit is contained in:
		
							parent
							
								
									44597b359e
								
							
						
					
					
						commit
						620e3bb39e
					
				
					 3 changed files with 169 additions and 9 deletions
				
			
		
							
								
								
									
										6
									
								
								TODO
									
										
									
									
									
								
							
							
						
						
									
										6
									
								
								TODO
									
										
									
									
									
								
							| 
						 | 
				
			
			@ -5,11 +5,7 @@ vt emulation
 | 
			
		|||
* color definition in CSI
 | 
			
		||||
	* implement CSI parsing
 | 
			
		||||
* make the keypad keys really work
 | 
			
		||||
	* kf0 .. kf44
 | 
			
		||||
	* kend, kel, kent, kfnd, ked, kext
 | 
			
		||||
	* kNXT, kPRV
 | 
			
		||||
	* ka1, ka3, kb2
 | 
			
		||||
* add arrow keys handling
 | 
			
		||||
	* kel, kfnd, ked, kext
 | 
			
		||||
 | 
			
		||||
code & interface
 | 
			
		||||
----------------
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
							
								
								
									
										102
									
								
								config.def.h
									
										
									
									
									
								
							
							
						
						
									
										102
									
								
								config.def.h
									
										
									
									
									
								
							| 
						 | 
				
			
			@ -77,6 +77,49 @@ static unsigned int defaultucs = 257;
 | 
			
		|||
/* key, mask, output, keypad, cursor, crlf */
 | 
			
		||||
static Key key[] = {
 | 
			
		||||
	/* keysym             mask         string         keypad cursor crlf */
 | 
			
		||||
	{ XK_KP_Home,       XK_NO_MOD,      "\033[H",        0,    0,    0},
 | 
			
		||||
	{ XK_KP_Home,       ShiftMask,      "\033[1;2H",     0,    0,    0},
 | 
			
		||||
	{ XK_KP_Up,         XK_NO_MOD,      "\033Ox",       +1,    0,    0},
 | 
			
		||||
	{ XK_KP_Up,         XK_NO_MOD,      "\033[A",        0,   -1,    0},
 | 
			
		||||
	{ XK_KP_Up,         XK_NO_MOD,      "\033OA",        0,   +1,    0},
 | 
			
		||||
	{ XK_KP_Down,       XK_NO_MOD,      "\033Or",       +1,    0,    0},
 | 
			
		||||
	{ XK_KP_Down,       XK_NO_MOD,      "\033[B",        0,   -1,    0},
 | 
			
		||||
	{ XK_KP_Down,       XK_NO_MOD,      "\033OB",        0,   +1,    0},
 | 
			
		||||
	{ XK_KP_Left,       XK_NO_MOD,      "\033Ot",       +1,    0,    0},
 | 
			
		||||
	{ XK_KP_Left,       XK_NO_MOD,      "\033[D",        0,   -1,    0},
 | 
			
		||||
	{ XK_KP_Left,       XK_NO_MOD,      "\033OD",        0,   +1,    0},
 | 
			
		||||
	{ XK_KP_Right,      XK_NO_MOD,      "\033Ov",       +1,    0,    0},
 | 
			
		||||
	{ XK_KP_Right,      XK_NO_MOD,      "\033[C",        0,   -1,    0},
 | 
			
		||||
	{ XK_KP_Right,      XK_NO_MOD,      "\033OC",        0,   +1,    0},
 | 
			
		||||
	{ XK_KP_Prior,      XK_NO_MOD,      "\033[5~",	     0,    0,    0},
 | 
			
		||||
	{ XK_KP_Prior,      ShiftMask,      "\033[5;2~",     0,    0,    0},
 | 
			
		||||
	{ XK_KP_Begin,      XK_NO_MOD,      "\033[E",        0,    0,    0},
 | 
			
		||||
	{ XK_KP_End,        XK_NO_MOD,      "\033[4~",       0,    0,    0},
 | 
			
		||||
	{ XK_KP_End,        ShiftMask,      "\033[1;2F",     0,    0,    0},
 | 
			
		||||
	{ XK_KP_Next,       XK_NO_MOD,      "\033[6~",       0,    0,    0},
 | 
			
		||||
	{ XK_KP_Next,       ShiftMask,      "\033[6;2~",     0,    0,    0},
 | 
			
		||||
	{ XK_KP_Insert,     XK_NO_MOD,      "\033[2~",       0,    0,    0},
 | 
			
		||||
	{ XK_KP_Insert,     ShiftMask,      "\033[2;2~",     0,    0,    0},
 | 
			
		||||
	{ XK_KP_Delete,     XK_NO_MOD,      "\033[3~",       0,    0,    0},
 | 
			
		||||
	{ XK_KP_Delete,     ShiftMask,      "\033[3;2~",     0,    0,    0},
 | 
			
		||||
	{ XK_KP_Multiply,   XK_NO_MOD,      "\033Oj",       +1,    0,    0},
 | 
			
		||||
	{ XK_KP_Add,        XK_NO_MOD,      "\033Ok",       +1,    0,    0},
 | 
			
		||||
	{ XK_KP_Enter,      XK_NO_MOD,      "\033OM",       +1,    0,    0},
 | 
			
		||||
	{ XK_KP_Enter,      XK_NO_MOD,      "\n",           -1,    0,   -1},
 | 
			
		||||
	{ XK_KP_Enter,      XK_NO_MOD,      "\r\n",         -1,    0,    0},
 | 
			
		||||
	{ XK_KP_Subtract,   XK_NO_MOD,      "\033Om",       +1,    0,    0},
 | 
			
		||||
	{ XK_KP_Decimal,    XK_NO_MOD,      "\033On",       +1,    0,    0},
 | 
			
		||||
	{ XK_KP_Divide,     XK_NO_MOD,      "\033Oo",       +1,    0,    0},
 | 
			
		||||
	{ XK_KP_0,          XK_NO_MOD,      "\033Op",       +1,    0,    0},
 | 
			
		||||
	{ XK_KP_1,          XK_NO_MOD,      "\033Oq",       +1,    0,    0},
 | 
			
		||||
	{ XK_KP_2,          XK_NO_MOD,      "\033Or",       +1,    0,    0},
 | 
			
		||||
	{ XK_KP_3,          XK_NO_MOD,      "\033Os",       +1,    0,    0},
 | 
			
		||||
	{ XK_KP_4,          XK_NO_MOD,      "\033Ot",       +1,    0,    0},
 | 
			
		||||
	{ XK_KP_5,          XK_NO_MOD,      "\033Ou",       +1,    0,    0},
 | 
			
		||||
	{ XK_KP_6,          XK_NO_MOD,      "\033Ov",       +1,    0,    0},
 | 
			
		||||
	{ XK_KP_7,          XK_NO_MOD,      "\033Ow",       +1,    0,    0},
 | 
			
		||||
	{ XK_KP_8,          XK_NO_MOD,      "\033Ox",       +1,    0,    0},
 | 
			
		||||
	{ XK_KP_9,          XK_NO_MOD,      "\033Oy",       +1,    0,    0},
 | 
			
		||||
	{ XK_BackSpace,     XK_NO_MOD,      "\177",          0,    0,    0},
 | 
			
		||||
	{ XK_Up,            XK_NO_MOD,      "\033[A",        0,   -1,    0},
 | 
			
		||||
	{ XK_Up,            XK_NO_MOD,      "\033OA",        0,   +1,    0},
 | 
			
		||||
| 
						 | 
				
			
			@ -98,28 +141,85 @@ static Key key[] = {
 | 
			
		|||
	{ XK_Right,         ShiftMask,      "\033[1;2C",     0,    0,    0},
 | 
			
		||||
	{ XK_Right,         ControlMask,    "\033[1;5C",     0,    0,    0},
 | 
			
		||||
	{ XK_Right,         Mod1Mask,       "\033[1;3C",     0,    0,    0},
 | 
			
		||||
	{ XK_Tab,           ShiftMask,      "\033[Z",        0,    0,    0},
 | 
			
		||||
	{ XK_Return,        XK_NO_MOD,      "\n",            0,    0,   -1},
 | 
			
		||||
	{ XK_Return,        XK_NO_MOD,      "\r\n",          0,    0,   +1},
 | 
			
		||||
	{ XK_Return,        Mod1Mask,       "\033\n",        0,    0,   -1},
 | 
			
		||||
	{ XK_Return,        Mod1Mask,       "\033\r\n",      0,    0,   +1},
 | 
			
		||||
	{ XK_Insert,        XK_NO_MOD,      "\033[2~",       0,    0,    0},
 | 
			
		||||
	{ XK_Insert,        ShiftMask,      "\033[2;2~",     0,    0,    0},
 | 
			
		||||
	{ XK_Delete,        XK_NO_MOD,      "\033[3~",       0,    0,    0},
 | 
			
		||||
	{ XK_Home,          XK_NO_MOD,      "\033[1~",       0,    0,    0},
 | 
			
		||||
	{ XK_Delete,        ShiftMask,      "\033[3;2~",     0,    0,    0},
 | 
			
		||||
	{ XK_Home,          XK_NO_MOD,      "\033[H",        0,    0,    0},
 | 
			
		||||
	{ XK_Home,          ShiftMask,      "\033[1;2H",     0,    0,    0},
 | 
			
		||||
	{ XK_End,           XK_NO_MOD,      "\033[4~",       0,    0,    0},
 | 
			
		||||
	{ XK_End,           ShiftMask,      "\033[1;2F",     0,    0,    0},
 | 
			
		||||
	{ XK_Prior,         XK_NO_MOD,      "\033[5~",       0,    0,    0},
 | 
			
		||||
	{ XK_Next,          XK_NO_MOD,      "\033[6~",       0,    0,    0},
 | 
			
		||||
	{ XK_Next,          ShiftMask,      "\033[6;2~",     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 */  Mod2Mask,       "\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 */  Mod2Mask,       "\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 */  Mod2Mask,       "\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 */  ShiftMask,      "\033[1;5S",     0,    0,    0},
 | 
			
		||||
	{ XK_F4, /* F40 */  Mod2Mask,       "\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 */  Mod2Mask,       "\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 */  Mod2Mask,       "\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 */  Mod2Mask,       "\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 */  Mod2Mask,       "\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 */  Mod2Mask,       "\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 */ Mod2Mask,       "\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 */ Mod2Mask,       "\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 */ Mod2Mask,       "\033[24;6~",    0,    0,    0},
 | 
			
		||||
	{ XK_F12, /* F60 */ Mod1Mask,       "\033[24;3~",    0,    0,    0},
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
/* Internal shortcuts. */
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
							
								
								
									
										70
									
								
								st.info
									
										
									
									
									
								
							
							
						
						
									
										70
									
								
								st.info
									
										
									
									
									
								
							| 
						 | 
				
			
			@ -49,11 +49,24 @@ st| simpleterm,
 | 
			
		|||
	invis=\E[8m,
 | 
			
		||||
	is2=\E[4l\E>,
 | 
			
		||||
	it#8,
 | 
			
		||||
	ka1=\E[E,
 | 
			
		||||
	ka3=\E[5~,
 | 
			
		||||
	kc1=\E[4~,
 | 
			
		||||
	kc3=\E[6~,
 | 
			
		||||
	kbs=\177,
 | 
			
		||||
	kcbt=\E[Z,
 | 
			
		||||
	kb2=\EOu,
 | 
			
		||||
	kcub1=\EOD,
 | 
			
		||||
	kcud1=\EOB,
 | 
			
		||||
	kcuf1=\EOC,
 | 
			
		||||
	kcuu1=\EOA,
 | 
			
		||||
	kDC=\E[3;2~,
 | 
			
		||||
	kent=\EOM,
 | 
			
		||||
	kEND=\E[1;2F,
 | 
			
		||||
	kIC=\E[2;2~,
 | 
			
		||||
	kNXT=\E[6;2~,
 | 
			
		||||
	kPRV=\E[5;2~,
 | 
			
		||||
	kHOM=\E[1;2H,
 | 
			
		||||
	kLFT=\E[1;2D,
 | 
			
		||||
	kRIT=\E[1;2C,
 | 
			
		||||
	kind=\E[1;2B,
 | 
			
		||||
| 
						 | 
				
			
			@ -61,9 +74,6 @@ st| simpleterm,
 | 
			
		|||
	kdch1=\E[3~,
 | 
			
		||||
	kich1=\E[2~,
 | 
			
		||||
	kend=\E[4~,
 | 
			
		||||
	kf10=\E[21~,
 | 
			
		||||
	kf11=\E[23~,
 | 
			
		||||
	kf12=\E[24~,
 | 
			
		||||
	kf1=\EOP,
 | 
			
		||||
	kf2=\EOQ,
 | 
			
		||||
	kf3=\EOR,
 | 
			
		||||
| 
						 | 
				
			
			@ -73,6 +83,60 @@ st| simpleterm,
 | 
			
		|||
	kf7=\E[18~,
 | 
			
		||||
	kf8=\E[19~,
 | 
			
		||||
	kf9=\E[20~,
 | 
			
		||||
	kf10=\E[21~,
 | 
			
		||||
	kf11=\E[23~,
 | 
			
		||||
	kf12=\E[24~,
 | 
			
		||||
	kf13=\E[1;2P,
 | 
			
		||||
	kf14=\E[1;2Q,
 | 
			
		||||
	kf15=\E[1;2R,
 | 
			
		||||
	kf16=\E[1;2S,
 | 
			
		||||
	kf17=\E[15;2~,
 | 
			
		||||
	kf18=\E[17;2~,
 | 
			
		||||
	kf19=\E[18;2~,
 | 
			
		||||
	kf20=\E[19;2~,
 | 
			
		||||
	kf21=\E[20;2~,
 | 
			
		||||
	kf22=\E[21;2~,
 | 
			
		||||
	kf23=\E[23;2~,
 | 
			
		||||
	kf24=\E[24;2~,
 | 
			
		||||
	kf25=\E[1;5P,
 | 
			
		||||
	kf26=\E[1;5Q,
 | 
			
		||||
	kf27=\E[1;5R,
 | 
			
		||||
	kf28=\E[1;5S,
 | 
			
		||||
	kf29=\E[15;5~,
 | 
			
		||||
	kf30=\E[17;5~,
 | 
			
		||||
	kf31=\E[18;5~,
 | 
			
		||||
	kf32=\E[19;5~,
 | 
			
		||||
	kf33=\E[20;5~,
 | 
			
		||||
	kf34=\E[21;5~,
 | 
			
		||||
	kf35=\E[23;5~,
 | 
			
		||||
	kf36=\E[24;5~,
 | 
			
		||||
	kf37=\E[1;6P,
 | 
			
		||||
	kf38=\E[1;6Q,
 | 
			
		||||
	kf39=\E[1;6R,
 | 
			
		||||
	kf40=\E[1;6S,
 | 
			
		||||
	kf41=\E[15;6~,
 | 
			
		||||
	kf42=\E[17;6~,
 | 
			
		||||
	kf43=\E[18;6~,
 | 
			
		||||
	kf44=\E[19;6~,
 | 
			
		||||
	kf45=\E[20;6~,
 | 
			
		||||
	kf46=\E[21;6~,
 | 
			
		||||
	kf47=\E[23;6~,
 | 
			
		||||
	kf48=\E[24;6~,
 | 
			
		||||
	kf49=\E[1;3P,
 | 
			
		||||
	kf50=\E[1;3Q,
 | 
			
		||||
	kf51=\E[1;3R,
 | 
			
		||||
	kf52=\E[1;3S,
 | 
			
		||||
	kf53=\E[15;3~,
 | 
			
		||||
	kf54=\E[17;3~,
 | 
			
		||||
	kf55=\E[18;3~,
 | 
			
		||||
	kf56=\E[19;3~,
 | 
			
		||||
	kf57=\E[20;3~,
 | 
			
		||||
	kf58=\E[21;3~,
 | 
			
		||||
	kf59=\E[23;3~,
 | 
			
		||||
	kf60=\E[24;3~,
 | 
			
		||||
	kf61=\E[1;4P,
 | 
			
		||||
	kf62=\E[1;4Q,
 | 
			
		||||
	kf63=\E[1;4R,
 | 
			
		||||
	khome=\E[1~,
 | 
			
		||||
	knp=\E[6~,
 | 
			
		||||
	kmous=\E[M,
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue