Ensure strpkey can parse numbered function keys
This commit is contained in:
parent
59800c356b
commit
a3b8804018
@ -8,7 +8,7 @@ int main(int argc, char *argv[])
|
||||
char buffer[16];
|
||||
size_t len;
|
||||
|
||||
plan_tests(24);
|
||||
plan_tests(28);
|
||||
|
||||
tk = termkey_new(0, TERMKEY_FLAG_NOTERMIOS);
|
||||
|
||||
@ -79,6 +79,18 @@ int main(int argc, char *argv[])
|
||||
is_int(len, 4, "length for sym/Up/0 wrapbracket");
|
||||
is_str(buffer, "<Up>", "buffer for sym/Up/0 wrapbracket");
|
||||
|
||||
key.type = TERMKEY_TYPE_FUNCTION;
|
||||
key.code.number = 5;
|
||||
key.modifiers = 0;
|
||||
|
||||
len = termkey_strfkey(tk, buffer, sizeof buffer, &key, 0);
|
||||
is_int(len, 2, "length for func/5/0");
|
||||
is_str(buffer, "F5", "buffer for func/5/0");
|
||||
|
||||
len = termkey_strfkey(tk, buffer, sizeof buffer, &key, TERMKEY_FORMAT_WRAPBRACKET);
|
||||
is_int(len, 4, "length for func/5/0 wrapbracket");
|
||||
is_str(buffer, "<F5>", "buffer for func/5/0 wrapbracket");
|
||||
|
||||
termkey_destroy(tk);
|
||||
|
||||
return exit_status();
|
||||
|
@ -9,7 +9,7 @@ int main(int argc, char *argv[])
|
||||
|
||||
#define CLEAR_KEY do { key.type = -1; key.code.codepoint = -1; key.modifiers = -1; key.utf8[0] = 0; } while(0)
|
||||
|
||||
plan_tests(44);
|
||||
plan_tests(48);
|
||||
|
||||
tk = termkey_new(0, TERMKEY_FLAG_NOTERMIOS);
|
||||
|
||||
@ -84,6 +84,13 @@ int main(int argc, char *argv[])
|
||||
is_int(key.code.sym, TERMKEY_SYM_UP, "key.code.codepoint for sym/Up/0");
|
||||
is_int(key.modifiers, 0, "key.modifiers for sym/Up/0");
|
||||
|
||||
CLEAR_KEY;
|
||||
res = termkey_strpkey(tk, "F5", &key, 0);
|
||||
is_int(res, TERMKEY_RES_KEY, "result for func/5/0");
|
||||
is_int(key.type, TERMKEY_TYPE_FUNCTION, "key.type for func/5/0");
|
||||
is_int(key.code.number, 5, "key.code.number for func/5/0");
|
||||
is_int(key.modifiers, 0, "key.modifiers for func/5/0");
|
||||
|
||||
termkey_destroy(tk);
|
||||
|
||||
return exit_status();
|
||||
|
@ -1122,7 +1122,10 @@ TermKeyResult termkey_strpkey(TermKey *tk, const char *str, TermKeyKey *key, Ter
|
||||
else if((key->code.sym = termkey_keyname2sym(tk, str)) != TERMKEY_SYM_UNKNOWN) {
|
||||
key->type = TERMKEY_TYPE_KEYSYM;
|
||||
}
|
||||
// TODO: Consider function keys
|
||||
else if(sscanf(str, "F%d", &key->code.number) == 1) {
|
||||
key->type = TERMKEY_TYPE_FUNCTION;
|
||||
}
|
||||
// TODO: Consider mouse events?
|
||||
else {
|
||||
return TERMKEY_RES_NONE;
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user