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…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user