1XkbAddDeviceLedInfo(3)           XKB FUNCTIONS          XkbAddDeviceLedInfo(3)
2
3
4

NAME

6       XkbAddDeviceLedInfo - Initialize an XkbDeviceLedInfoRec structure
7

SYNOPSIS

9       XkbDeviceLedInfoPtr  XkbAddDeviceLedInfo (XkbDeviceInfoPtr device_info,
10              unsigned int led_class, unsigned int led_id);
11

ARGUMENTS

13       - device_info
14              structure in which to add LED info
15
16       - led_class
17              input extension class for LED device of interest
18
19       - led_id
20              input extension ID for LED device of interest
21

DESCRIPTION

23       XkbAddDeviceLedInfo first checks  to  see  whether  an  entry  matching
24       led_class  and led_id already exists in the device_info->leds array. If
25       it finds a matching entry, it returns a pointer to that  entry.  Other‐
26       wise,  it  checks  to  be  sure  there  is  at least one empty entry in
27       device_info->leds and extends it if there is not enough room.  It  then
28       increments  device_info->num_leds and fills in the next available entry
29       in device_info->leds with led_class and led_id.
30
31       If successful, XkbAddDeviceLedInfo returns  a  pointer  to  the  XkbDe‐
32       viceLedInfoRec  structure  that  was initialized. If unable to allocate
33       sufficient storage, or if device_info points to an invalid XkbDeviceIn‐
34       foRec structure, or if led_class or led_id are inappropriate, XkbAddDe‐
35       viceLedInfo returns NULL.
36
37       To allocate additional space for button actions in an  XkbDeviceInfoRec
38       structure, use XkbResizeDeviceButtonActions.
39
40

STRUCTURES

42       Information  about  X  Input Extension devices is transferred between a
43       client program and the Xkb extension in an XkbDeviceInfoRec structure:
44
45           typedef struct {
46               char *               name;          /∗ name for device */
47               Atom                 type;          /∗ name for class of devices */
48               unsigned short       device_spec;   /∗ device of interest */
49               Bool                 has_own_state; /∗ True=>this device has its own state */
50               unsigned short       supported;     /∗ bits indicating supported capabilities */
51               unsigned short       unsupported;   /∗ bits indicating unsupported capabilities */
52               unsigned short       num_btns;      /∗ number of entries in btn_acts */
53               XkbAction *          btn_acts;      /∗ button actions */
54               unsigned short       sz_leds;       /∗ total number of entries in LEDs vector */
55               unsigned short       num_leds;      /∗ number of valid entries in LEDs vector */
56               unsigned short       dflt_kbd_fb;   /∗ input extension ID of default (core kbd) indicator */
57               unsigned short       dflt_led_fb;   /∗ input extension ID of default indicator feedback */
58               XkbDeviceLedInfoPtr  leds;          /∗ LED descriptions */
59           } XkbDeviceInfoRec, *XkbDeviceInfoPtr;
60
61
62           typedef struct {
63               unsigned short      led_class;        /∗ class for this LED device*/
64               unsigned short      led_id;           /∗ ID for this LED device */
65               unsigned int        phys_indicators;  /∗ bits for which LEDs physically present */
66               unsigned int        maps_present;     /∗ bits for which LEDs have maps in maps */
67               unsigned int        names_present;    /∗ bits for which LEDs are in names */
68               unsigned int        state;            /∗ 1 bit => corresponding LED is on */
69               Atom                names[XkbNumIndicators];   /∗ names for LEDs */
70               XkbIndicatorMapRec  maps;             /∗ indicator maps for each LED */
71           } XkbDeviceLedInfoRec, *XkbDeviceLedInfoPtr;
72
73

SEE ALSO

75       XkbResizeDeviceButtonActions(3)
76
77
78
79X Version 11                     libX11 1.6.5           XkbAddDeviceLedInfo(3)
Impressum