diff options
| author | Samuel Thibault | 2010-10-19 19:48:20 +0200 |
|---|---|---|
| committer | Andrzej Zaborowski | 2010-10-21 18:31:28 +0200 |
| commit | d03703c81a202cea156811e5dbc8e88627c19986 (patch) | |
| tree | bc22fad9e369b7a770ebdf6c11ca51d5fd14d159 /ui | |
| parent | Fix pci hotplug to generate level triggered interrupt. (diff) | |
| download | qemu-d03703c81a202cea156811e5dbc8e88627c19986.tar.gz qemu-d03703c81a202cea156811e5dbc8e88627c19986.tar.xz qemu-d03703c81a202cea156811e5dbc8e88627c19986.zip | |
curses: Fix control-{@[\]^_} and ESC
control-{@[\]^_} shouldn't get the 'a' - 'A' offset for correct
translation. ESC is better simulated as escape key.
Signed-off-by: Samuel Thibault <samuel.thibault@ens-lyon.org>
Signed-off-by: Andrew Zaborowski <balrogg@gmail.com>
Diffstat (limited to 'ui')
| -rw-r--r-- | ui/curses.c | 9 | ||||
| -rw-r--r-- | ui/curses_keys.h | 1 |
2 files changed, 7 insertions, 3 deletions
diff --git a/ui/curses.c b/ui/curses.c index ed3165e45e..82bc614040 100644 --- a/ui/curses.c +++ b/ui/curses.c @@ -238,9 +238,12 @@ static void curses_refresh(DisplayState *ds) keysym = curses2keysym[chr]; if (keysym == -1) { - if (chr < ' ') - keysym = (chr + '@' - 'A' + 'a') | KEYSYM_CNTRL; - else + if (chr < ' ') { + keysym = chr + '@'; + if (keysym >= 'A' && keysym <= 'Z') + keysym += 'a' - 'A'; + keysym |= KEYSYM_CNTRL; + } else keysym = chr; } diff --git a/ui/curses_keys.h b/ui/curses_keys.h index 1decd1119d..c0d5eb452f 100644 --- a/ui/curses_keys.h +++ b/ui/curses_keys.h @@ -55,6 +55,7 @@ static const int curses2keysym[CURSES_KEYS] = { [0x7f] = KEY_BACKSPACE, ['\r'] = KEY_ENTER, ['\n'] = KEY_ENTER, + [27] = 27, [KEY_BTAB] = '\t' | KEYSYM_SHIFT, }; |
