more keycodes - hexa keycodes - keycode completion
git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@1907 c046a42c-6fe2-441c-8c8c-71466251a162
This commit is contained in:
parent
294e863721
commit
64866c3d5c
33
monitor.c
33
monitor.c
@ -666,6 +666,8 @@ static const KeyDef key_defs[] = {
|
|||||||
{ 0x09, "8" },
|
{ 0x09, "8" },
|
||||||
{ 0x0a, "9" },
|
{ 0x0a, "9" },
|
||||||
{ 0x0b, "0" },
|
{ 0x0b, "0" },
|
||||||
|
{ 0x0c, "minus" },
|
||||||
|
{ 0x0d, "equal" },
|
||||||
{ 0x0e, "backspace" },
|
{ 0x0e, "backspace" },
|
||||||
|
|
||||||
{ 0x0f, "tab" },
|
{ 0x0f, "tab" },
|
||||||
@ -715,6 +717,24 @@ static const KeyDef key_defs[] = {
|
|||||||
{ 0x45, "num_lock" },
|
{ 0x45, "num_lock" },
|
||||||
{ 0x46, "scroll_lock" },
|
{ 0x46, "scroll_lock" },
|
||||||
|
|
||||||
|
{ 0xb5, "kp_divide" },
|
||||||
|
{ 0x37, "kp_multiply" },
|
||||||
|
{ 0x4a, "kp_substract" },
|
||||||
|
{ 0x4e, "kp_add" },
|
||||||
|
{ 0x9c, "kp_enter" },
|
||||||
|
{ 0x53, "kp_decimal" },
|
||||||
|
|
||||||
|
{ 0x52, "kp_0" },
|
||||||
|
{ 0x4f, "kp_1" },
|
||||||
|
{ 0x50, "kp_2" },
|
||||||
|
{ 0x51, "kp_3" },
|
||||||
|
{ 0x4b, "kp_4" },
|
||||||
|
{ 0x4c, "kp_5" },
|
||||||
|
{ 0x4d, "kp_6" },
|
||||||
|
{ 0x47, "kp_7" },
|
||||||
|
{ 0x48, "kp_8" },
|
||||||
|
{ 0x49, "kp_9" },
|
||||||
|
|
||||||
{ 0x56, "<" },
|
{ 0x56, "<" },
|
||||||
|
|
||||||
{ 0x57, "f11" },
|
{ 0x57, "f11" },
|
||||||
@ -740,11 +760,18 @@ static const KeyDef key_defs[] = {
|
|||||||
static int get_keycode(const char *key)
|
static int get_keycode(const char *key)
|
||||||
{
|
{
|
||||||
const KeyDef *p;
|
const KeyDef *p;
|
||||||
|
char *endp;
|
||||||
|
int ret;
|
||||||
|
|
||||||
for(p = key_defs; p->name != NULL; p++) {
|
for(p = key_defs; p->name != NULL; p++) {
|
||||||
if (!strcmp(key, p->name))
|
if (!strcmp(key, p->name))
|
||||||
return p->keycode;
|
return p->keycode;
|
||||||
}
|
}
|
||||||
|
if (strstart(key, "0x", NULL)) {
|
||||||
|
ret = strtoul(key, &endp, 0);
|
||||||
|
if (*endp == '\0' && ret >= 0x01 && ret <= 0xff)
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2152,6 +2179,7 @@ void readline_find_completion(const char *cmdline)
|
|||||||
int nb_args, i, len;
|
int nb_args, i, len;
|
||||||
const char *ptype, *str;
|
const char *ptype, *str;
|
||||||
term_cmd_t *cmd;
|
term_cmd_t *cmd;
|
||||||
|
const KeyDef *key;
|
||||||
|
|
||||||
parse_cmdline(cmdline, &nb_args, args);
|
parse_cmdline(cmdline, &nb_args, args);
|
||||||
#ifdef DEBUG_COMPLETION
|
#ifdef DEBUG_COMPLETION
|
||||||
@ -2213,6 +2241,11 @@ void readline_find_completion(const char *cmdline)
|
|||||||
for(cmd = info_cmds; cmd->name != NULL; cmd++) {
|
for(cmd = info_cmds; cmd->name != NULL; cmd++) {
|
||||||
cmd_completion(str, cmd->name);
|
cmd_completion(str, cmd->name);
|
||||||
}
|
}
|
||||||
|
} else if (!strcmp(cmd->name, "sendkey")) {
|
||||||
|
completion_index = strlen(str);
|
||||||
|
for(key = key_defs; key->name != NULL; key++) {
|
||||||
|
cmd_completion(str, key->name);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
|
Loading…
Reference in New Issue
Block a user