Optimizing the key lookup to the X11 function key. It is still possible to
remap other keys.
This commit is contained in:
		@@ -88,6 +88,12 @@ static Shortcut shortcuts[] = {
 | 
			
		||||
 * position for a key.
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/*
 | 
			
		||||
 * If you want something else but the function keys of X11 (0xFF00 - 0xFFFF)
 | 
			
		||||
 * mapped below, add them to this array.
 | 
			
		||||
 */
 | 
			
		||||
static KeySym mappedkeys[] = { -1 };
 | 
			
		||||
 | 
			
		||||
/* key, mask, output, keypad, cursor, crlf */
 | 
			
		||||
static Key key[] = {
 | 
			
		||||
	/* keysym             mask         string         keypad cursor crlf */
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										14
									
								
								st.c
									
									
									
									
									
								
							
							
						
						
									
										14
									
								
								st.c
									
									
									
									
									
								
							@@ -2711,6 +2711,20 @@ char*
 | 
			
		||||
kmap(KeySym k, uint state) {
 | 
			
		||||
	uint mask;
 | 
			
		||||
	Key *kp;
 | 
			
		||||
	int i;
 | 
			
		||||
 | 
			
		||||
	/* Check for mapped keys out of X11 function keys. */
 | 
			
		||||
	for(i = 0; i < LEN(mappedkeys); i++) {
 | 
			
		||||
		if(mappedkeys[i] == k) {
 | 
			
		||||
			fprintf(stderr, "mapped function key.\n");
 | 
			
		||||
			break;
 | 
			
		||||
		}
 | 
			
		||||
	}
 | 
			
		||||
	if(i == LEN(mappedkeys)) {
 | 
			
		||||
		if((k & 0xFFFF) < 0xFF00)
 | 
			
		||||
			return NULL;
 | 
			
		||||
	}
 | 
			
		||||
	fprintf(stderr, "Function key.\n");
 | 
			
		||||
 | 
			
		||||
	for(kp = key; kp < key + LEN(key); kp++) {
 | 
			
		||||
		mask = kp->mask;
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user