input: don't use a function call when a literal value will do
parent
9115828e76
commit
2225d54126
78
src/winio.c
78
src/winio.c
|
@ -739,13 +739,13 @@ int convert_sequence(const int *seq, size_t seq_len)
|
||||||
* with NumLock off on xterm. */
|
* with NumLock off on xterm. */
|
||||||
return KEY_B2;
|
return KEY_B2;
|
||||||
case 'F': /* Esc O F == End on xterm/Terminal. */
|
case 'F': /* Esc O F == End on xterm/Terminal. */
|
||||||
return sc_seq_or(do_end, 0);
|
return KEY_END;
|
||||||
case 'H': /* Esc O H == Home on xterm/Terminal. */
|
case 'H': /* Esc O H == Home on xterm/Terminal. */
|
||||||
return sc_seq_or(do_home, 0);
|
return KEY_HOME;
|
||||||
case 'M': /* Esc O M == Enter on numeric keypad with
|
case 'M': /* Esc O M == Enter on numeric keypad with
|
||||||
* NumLock off on VT100/VT220/VT320/xterm/
|
* NumLock off on VT100/VT220/VT320/xterm/
|
||||||
* rxvt/Eterm. */
|
* rxvt/Eterm. */
|
||||||
return sc_seq_or(do_enter, 0);
|
return KEY_ENTER;
|
||||||
case 'P': /* Esc O P == F1 on VT100/VT220/VT320/Mach
|
case 'P': /* Esc O P == F1 on VT100/VT220/VT320/Mach
|
||||||
* console. */
|
* console. */
|
||||||
return KEY_F(1);
|
return KEY_F(1);
|
||||||
|
@ -797,7 +797,7 @@ int convert_sequence(const int *seq, size_t seq_len)
|
||||||
case 'n': /* Esc O n == Delete (.) on numeric keypad
|
case 'n': /* Esc O n == Delete (.) on numeric keypad
|
||||||
* with NumLock off on VT100/VT220/VT320/
|
* with NumLock off on VT100/VT220/VT320/
|
||||||
* xterm/rxvt/Eterm/Terminal. */
|
* xterm/rxvt/Eterm/Terminal. */
|
||||||
return sc_seq_or(do_delete, 0);
|
return KEY_DC;
|
||||||
case 'o': /* Esc O o == '/' on numeric keypad with
|
case 'o': /* Esc O o == '/' on numeric keypad with
|
||||||
* NumLock off on VT100/VT220/VT320/xterm/
|
* NumLock off on VT100/VT220/VT320/xterm/
|
||||||
* rxvt/Eterm/Terminal. */
|
* rxvt/Eterm/Terminal. */
|
||||||
|
@ -805,23 +805,23 @@ int convert_sequence(const int *seq, size_t seq_len)
|
||||||
case 'p': /* Esc O p == Insert (0) on numeric keypad
|
case 'p': /* Esc O p == Insert (0) on numeric keypad
|
||||||
* with NumLock off on VT100/VT220/VT320/
|
* with NumLock off on VT100/VT220/VT320/
|
||||||
* rxvt/Eterm/Terminal. */
|
* rxvt/Eterm/Terminal. */
|
||||||
return sc_seq_or(do_insertfile_void, 0);
|
return KEY_IC;
|
||||||
case 'q': /* Esc O q == End (1) on numeric keypad
|
case 'q': /* Esc O q == End (1) on numeric keypad
|
||||||
* with NumLock off on VT100/VT220/VT320/
|
* with NumLock off on VT100/VT220/VT320/
|
||||||
* rxvt/Eterm/Terminal. */
|
* rxvt/Eterm/Terminal. */
|
||||||
return sc_seq_or(do_end, 0);
|
return KEY_END;
|
||||||
case 'r': /* Esc O r == Down (2) on numeric keypad
|
case 'r': /* Esc O r == Down (2) on numeric keypad
|
||||||
* with NumLock off on VT100/VT220/VT320/
|
* with NumLock off on VT100/VT220/VT320/
|
||||||
* rxvt/Eterm/Terminal. */
|
* rxvt/Eterm/Terminal. */
|
||||||
return sc_seq_or(do_down_void, 0);
|
return KEY_DOWN;
|
||||||
case 's': /* Esc O s == PageDown (3) on numeric
|
case 's': /* Esc O s == PageDown (3) on numeric
|
||||||
* keypad with NumLock off on VT100/VT220/
|
* keypad with NumLock off on VT100/VT220/
|
||||||
* VT320/rxvt/Eterm/Terminal. */
|
* VT320/rxvt/Eterm/Terminal. */
|
||||||
return sc_seq_or(do_page_down, 0);
|
return KEY_NPAGE;
|
||||||
case 't': /* Esc O t == Left (4) on numeric keypad
|
case 't': /* Esc O t == Left (4) on numeric keypad
|
||||||
* with NumLock off on VT100/VT220/VT320/
|
* with NumLock off on VT100/VT220/VT320/
|
||||||
* rxvt/Eterm/Terminal. */
|
* rxvt/Eterm/Terminal. */
|
||||||
return sc_seq_or(do_left, 0);
|
return KEY_LEFT;
|
||||||
case 'u': /* Esc O u == Center (5) on numeric keypad
|
case 'u': /* Esc O u == Center (5) on numeric keypad
|
||||||
* with NumLock off on VT100/VT220/VT320/
|
* with NumLock off on VT100/VT220/VT320/
|
||||||
* rxvt/Eterm. */
|
* rxvt/Eterm. */
|
||||||
|
@ -829,19 +829,19 @@ int convert_sequence(const int *seq, size_t seq_len)
|
||||||
case 'v': /* Esc O v == Right (6) on numeric keypad
|
case 'v': /* Esc O v == Right (6) on numeric keypad
|
||||||
* with NumLock off on VT100/VT220/VT320/
|
* with NumLock off on VT100/VT220/VT320/
|
||||||
* rxvt/Eterm/Terminal. */
|
* rxvt/Eterm/Terminal. */
|
||||||
return sc_seq_or(do_right, 0);
|
return KEY_RIGHT;
|
||||||
case 'w': /* Esc O w == Home (7) on numeric keypad
|
case 'w': /* Esc O w == Home (7) on numeric keypad
|
||||||
* with NumLock off on VT100/VT220/VT320/
|
* with NumLock off on VT100/VT220/VT320/
|
||||||
* rxvt/Eterm/Terminal. */
|
* rxvt/Eterm/Terminal. */
|
||||||
return sc_seq_or(do_home, 0);
|
return KEY_HOME;
|
||||||
case 'x': /* Esc O x == Up (8) on numeric keypad
|
case 'x': /* Esc O x == Up (8) on numeric keypad
|
||||||
* with NumLock off on VT100/VT220/VT320/
|
* with NumLock off on VT100/VT220/VT320/
|
||||||
* rxvt/Eterm/Terminal. */
|
* rxvt/Eterm/Terminal. */
|
||||||
return sc_seq_or(do_up_void, 0);
|
return KEY_UP;
|
||||||
case 'y': /* Esc O y == PageUp (9) on numeric keypad
|
case 'y': /* Esc O y == PageUp (9) on numeric keypad
|
||||||
* with NumLock off on VT100/VT220/VT320/
|
* with NumLock off on VT100/VT220/VT320/
|
||||||
* rxvt/Eterm/Terminal. */
|
* rxvt/Eterm/Terminal. */
|
||||||
return sc_seq_or(do_page_up, 0);
|
return KEY_PPAGE;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 'o':
|
case 'o':
|
||||||
|
@ -917,7 +917,7 @@ int convert_sequence(const int *seq, size_t seq_len)
|
||||||
break;
|
break;
|
||||||
default: /* Esc [ 1 ~ == Home on
|
default: /* Esc [ 1 ~ == Home on
|
||||||
* VT320/Linux console. */
|
* VT320/Linux console. */
|
||||||
return sc_seq_or(do_home, 0);
|
return KEY_HOME;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
@ -950,32 +950,32 @@ int convert_sequence(const int *seq, size_t seq_len)
|
||||||
return KEY_F(16);
|
return KEY_F(16);
|
||||||
default: /* Esc [ 2 ~ == Insert on VT220/VT320/
|
default: /* Esc [ 2 ~ == Insert on VT220/VT320/
|
||||||
* Linux console/xterm/Terminal. */
|
* Linux console/xterm/Terminal. */
|
||||||
return sc_seq_or(do_insertfile_void, 0);
|
return KEY_IC;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case '3': /* Esc [ 3 ~ == Delete on VT220/VT320/
|
case '3': /* Esc [ 3 ~ == Delete on VT220/VT320/
|
||||||
* Linux console/xterm/Terminal. */
|
* Linux console/xterm/Terminal. */
|
||||||
return sc_seq_or(do_delete, 0);
|
return KEY_DC;
|
||||||
case '4': /* Esc [ 4 ~ == End on VT220/VT320/Linux
|
case '4': /* Esc [ 4 ~ == End on VT220/VT320/Linux
|
||||||
* console/xterm. */
|
* console/xterm. */
|
||||||
return sc_seq_or(do_end, 0);
|
return KEY_END;
|
||||||
case '5': /* Esc [ 5 ~ == PageUp on VT220/VT320/
|
case '5': /* Esc [ 5 ~ == PageUp on VT220/VT320/
|
||||||
* Linux console/xterm/Terminal;
|
* Linux console/xterm/Terminal;
|
||||||
* Esc [ 5 ^ == PageUp on Eterm. */
|
* Esc [ 5 ^ == PageUp on Eterm. */
|
||||||
return sc_seq_or(do_page_up, 0);
|
return KEY_PPAGE;
|
||||||
case '6': /* Esc [ 6 ~ == PageDown on VT220/VT320/
|
case '6': /* Esc [ 6 ~ == PageDown on VT220/VT320/
|
||||||
* Linux console/xterm/Terminal;
|
* Linux console/xterm/Terminal;
|
||||||
* Esc [ 6 ^ == PageDown on Eterm. */
|
* Esc [ 6 ^ == PageDown on Eterm. */
|
||||||
return sc_seq_or(do_page_down, 0);
|
return KEY_NPAGE;
|
||||||
case '7': /* Esc [ 7 ~ == Home on rxvt. */
|
case '7': /* Esc [ 7 ~ == Home on rxvt. */
|
||||||
return sc_seq_or(do_home, 0);
|
return KEY_HOME;
|
||||||
case '8': /* Esc [ 8 ~ == End on rxvt. */
|
case '8': /* Esc [ 8 ~ == End on rxvt. */
|
||||||
return sc_seq_or(do_end, 0);
|
return KEY_END;
|
||||||
case '9': /* Esc [ 9 == Delete on Mach console. */
|
case '9': /* Esc [ 9 == Delete on Mach console. */
|
||||||
return sc_seq_or(do_delete, 0);
|
return KEY_DC;
|
||||||
case '@': /* Esc [ @ == Insert on Mach console. */
|
case '@': /* Esc [ @ == Insert on Mach console. */
|
||||||
return sc_seq_or(do_insertfile_void, 0);
|
return KEY_IC;
|
||||||
case 'A': /* Esc [ A == Up on ANSI/VT220/Linux
|
case 'A': /* Esc [ A == Up on ANSI/VT220/Linux
|
||||||
* console/FreeBSD console/Mach console/
|
* console/FreeBSD console/Mach console/
|
||||||
* rxvt/Eterm/Terminal. */
|
* rxvt/Eterm/Terminal. */
|
||||||
|
@ -994,16 +994,16 @@ int convert_sequence(const int *seq, size_t seq_len)
|
||||||
* Terminal. */
|
* Terminal. */
|
||||||
return KEY_B2;
|
return KEY_B2;
|
||||||
case 'F': /* Esc [ F == End on FreeBSD console/Eterm. */
|
case 'F': /* Esc [ F == End on FreeBSD console/Eterm. */
|
||||||
return sc_seq_or(do_end, 0);
|
return KEY_END;
|
||||||
case 'G': /* Esc [ G == PageDown on FreeBSD console. */
|
case 'G': /* Esc [ G == PageDown on FreeBSD console. */
|
||||||
return sc_seq_or(do_page_down, 0);
|
return KEY_NPAGE;
|
||||||
case 'H': /* Esc [ H == Home on ANSI/VT220/FreeBSD
|
case 'H': /* Esc [ H == Home on ANSI/VT220/FreeBSD
|
||||||
* console/Mach console/Eterm. */
|
* console/Mach console/Eterm. */
|
||||||
return sc_seq_or(do_home, 0);
|
return KEY_HOME;
|
||||||
case 'I': /* Esc [ I == PageUp on FreeBSD console. */
|
case 'I': /* Esc [ I == PageUp on FreeBSD console. */
|
||||||
return sc_seq_or(do_page_up, 0);
|
return KEY_PPAGE;
|
||||||
case 'L': /* Esc [ L == Insert on ANSI/FreeBSD console. */
|
case 'L': /* Esc [ L == Insert on ANSI/FreeBSD console. */
|
||||||
return sc_seq_or(do_insertfile_void, 0);
|
return KEY_IC;
|
||||||
case 'M': /* Esc [ M == F1 on FreeBSD console. */
|
case 'M': /* Esc [ M == F1 on FreeBSD console. */
|
||||||
return KEY_F(1);
|
return KEY_F(1);
|
||||||
case 'N': /* Esc [ N == F2 on FreeBSD console. */
|
case 'N': /* Esc [ N == F2 on FreeBSD console. */
|
||||||
|
@ -1035,15 +1035,15 @@ int convert_sequence(const int *seq, size_t seq_len)
|
||||||
case 'T': /* Esc [ T == F8 on FreeBSD console. */
|
case 'T': /* Esc [ T == F8 on FreeBSD console. */
|
||||||
return KEY_F(8);
|
return KEY_F(8);
|
||||||
case 'U': /* Esc [ U == PageDown on Mach console. */
|
case 'U': /* Esc [ U == PageDown on Mach console. */
|
||||||
return sc_seq_or(do_page_down, 0);
|
return KEY_NPAGE;
|
||||||
case 'V': /* Esc [ V == PageUp on Mach console. */
|
case 'V': /* Esc [ V == PageUp on Mach console. */
|
||||||
return sc_seq_or(do_page_up, 0);
|
return KEY_PPAGE;
|
||||||
case 'W': /* Esc [ W == F11 on FreeBSD console. */
|
case 'W': /* Esc [ W == F11 on FreeBSD console. */
|
||||||
return KEY_F(11);
|
return KEY_F(11);
|
||||||
case 'X': /* Esc [ X == F12 on FreeBSD console. */
|
case 'X': /* Esc [ X == F12 on FreeBSD console. */
|
||||||
return KEY_F(12);
|
return KEY_F(12);
|
||||||
case 'Y': /* Esc [ Y == End on Mach console. */
|
case 'Y': /* Esc [ Y == End on Mach console. */
|
||||||
return sc_seq_or(do_end, 0);
|
return KEY_END;
|
||||||
case 'Z': /* Esc [ Z == F14 on FreeBSD console. */
|
case 'Z': /* Esc [ Z == F14 on FreeBSD console. */
|
||||||
return KEY_F(14);
|
return KEY_F(14);
|
||||||
case 'a': /* Esc [ a == Shift-Up on rxvt/Eterm. */
|
case 'a': /* Esc [ a == Shift-Up on rxvt/Eterm. */
|
||||||
|
@ -1080,20 +1080,19 @@ int convert_sequence(const int *seq, size_t seq_len)
|
||||||
return ERR;
|
return ERR;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Return the equivalent arrow key value for the case-insensitive
|
/* Return the equivalent arrow-key value for the first four letters
|
||||||
* letters A (up), B (down), C (right), and D (left). These are common
|
* in the alphabet, common to many escape sequences. */
|
||||||
* to many escape sequences. */
|
|
||||||
int arrow_from_abcd(int kbinput)
|
int arrow_from_abcd(int kbinput)
|
||||||
{
|
{
|
||||||
switch (tolower(kbinput)) {
|
switch (tolower(kbinput)) {
|
||||||
case 'a':
|
case 'a':
|
||||||
return sc_seq_or(do_up_void, 0);
|
return KEY_UP;
|
||||||
case 'b':
|
case 'b':
|
||||||
return sc_seq_or(do_down_void, 0);
|
return KEY_DOWN;
|
||||||
case 'c':
|
case 'c':
|
||||||
return sc_seq_or(do_right, 0);
|
return KEY_RIGHT;
|
||||||
case 'd':
|
case 'd':
|
||||||
return sc_seq_or(do_left, 0);
|
return KEY_LEFT;
|
||||||
default:
|
default:
|
||||||
return ERR;
|
return ERR;
|
||||||
}
|
}
|
||||||
|
@ -1610,8 +1609,7 @@ int get_mouseinput(int *mouse_x, int *mouse_y, bool allow_shortcuts)
|
||||||
* wheel is equivalent to moving down three lines. */
|
* wheel is equivalent to moving down three lines. */
|
||||||
for (i = 0; i < 3; i++)
|
for (i = 0; i < 3; i++)
|
||||||
unget_kbinput((mevent.bstate & BUTTON4_PRESSED) ?
|
unget_kbinput((mevent.bstate & BUTTON4_PRESSED) ?
|
||||||
sc_seq_or(do_up_void, 0) : sc_seq_or(do_down_void, 0),
|
KEY_PPAGE : KEY_NPAGE, FALSE, FALSE);
|
||||||
FALSE, FALSE);
|
|
||||||
|
|
||||||
return 1;
|
return 1;
|
||||||
} else
|
} else
|
||||||
|
|
Loading…
Reference in New Issue