1XGETDEVICEKEYMAPPING(3) XGETDEVICEKEYMAPPING(3)
2
3
4
6 XGetDeviceKeyMapping, XChangeDeviceKeyMapping - query or change device
7 key mappings
8
10 #include <X11/extensions/XInput.h>
11
12 KeySym *XGetDeviceKeyMapping( Display *display,
13 XDevice *device,
14 KeyCode first_keycode,
15 int keycode_count,
16 int *keysyms_per_keycode_return);
17 display
18 Specifies the connection to the X server.
19
20 device
21 Specifies the device whose key mapping is to be queried
22 or modified.
23
24 first_keycode
25 Specifies the first KeyCode to be returned.
26
27 keycode_count
28 Specifies the number of KeyCodes to be returned or
29 modified.
30
31 keysyms_per_keycode
32 Specifies the number of KeySyms per KeyCode.
33
34 keysyms_per_keycode_return
35 Specifies the address of a variable into which the
36 number of KeySyms per KeyCode will be returned.
37
38 keysyms
39 Specifies the address of an array of KeySyms.
40
42 For the specified device, the XGetDeviceKeyMapping request
43 returns the symbols for the specified number of KeyCodes
44 starting with first_keycode. The value specified in
45 first_keycode must be greater than or equal to min_keycode as
46 returned by XListInputDevices, or a BadValue error results. In
47 addition, the following expression must be less than or equal
48 to max_keycode as returned by XListInputDevices:
49
50 first_keycode + keycode_count - 1
51
52 If this is not the case, a BadValue error results. The number
53 of elements in the KeySyms list is:
54
55 keycode_count * keysyms_per_keycode_return
56
57 KeySym number N, counting from zero, for KeyCode K has the
58 following index in the list, counting from zero: (K -
59 first_code) * keysyms_per_code_return + N
60
61 The X server arbitrarily chooses the keysyms_per_keycode_return
62 value to be large enough to report all requested symbols. A
63 special KeySym value of NoSymbol is used to fill in unused
64 elements for individual KeyCodes. To free the storage returned
65 by XGetDeviceKeyMapping, use XFree.
66
67 If the specified device does not support input class keys, a
68 BadMatch error will result.
69
70 XGetDeviceKeyMapping can generate a BadDevice, BadMatch, or
71 BadValue error.
72
73 For the specified device, the XChangeDeviceKeyMapping request
74 defines the symbols for the specified number of KeyCodes
75 starting with first_keycode. The symbols for KeyCodes outside
76 this range remain unchanged. The number of elements in keysyms
77 must be:
78
79 num_codes * keysyms_per_keycode
80
81 The specified first_keycode must be greater than or equal to
82 min_keycode returned by XListInputDevices, or a BadValue error
83 results. In addition, the following expression must be less
84 than or equal to max_keycode as returned by XListInputDevices,
85 or a BadValue error results:
86
87 first_keycode + num_codes - 1
88
89 KeySym number N, counting from zero, for KeyCode K has the
90 following index in keysyms, counting from zero:
91
92 (K - first_keycode) * keysyms_per_keycode + N
93
94 The specified keysyms_per_keycode can be chosen arbitrarily by
95 the client to be large enough to hold all desired symbols. A
96 special KeySym value of NoSymbol should be used to fill in
97 unused elements for individual KeyCodes. It is legal for
98 NoSymbol to appear in nontrailing positions of the effective
99 list for a KeyCode. XChangeDeviceKeyMapping generates a
100 DeviceMappingNotify event that is sent to all clients that have
101 selected that type of event.
102
103 There is no requirement that the X server interpret this
104 mapping. It is merely stored for reading and writing by
105 clients.
106
107 If the specified device does not support input class keys, a
108 BadMatch error results.
109
110 XChangeDeviceKeyMapping can generate a BadDevice, BadMatch,
111 BadAlloc, or BadValue error.
112
114 BadDevice
115 An invalid device was specified. The specified device
116 does not exist or has not been opened by this client via
117 XOpenInputDevice. This error may also occur if the
118 specified device is the X keyboard or X pointer device.
119
120 BadMatch
121 This error may occur if an XGetDeviceKeyMapping or
122 XChangeDeviceKeyMapping request was made specifying a
123 device that has no keys.
124
125 BadValue
126 Some numeric value falls outside the range of values
127 accepted by the request. Unless a specific range is
128 specified for an argument, the full range defined by the
129 argument's type is accepted. Any argument defined as a
130 set of alternatives can generate this error.
131
132 BadAlloc
133 The server failed to allocate the requested resource or
134 server memory.
135
137 XSetDeviceButtonMapping(3), XSetDeviceModifierMapping(__3_)
138
139
140
141 05/04/2023 XGETDEVICEKEYMAPPING(3)