1XGETFEEDBACKCONTROL(3)                                  XGETFEEDBACKCONTROL(3)
2
3
4

NAME

6       XGetFeedbackControl, XChangeFeedbackControl - query and change input
7       device feedbacks
8

SYNOPSIS

10       #include <X11/extensions/XInput.h>
11
12       XFeedbackState *XGetFeedbackControl( Display *display,
13                                            XDevice *device,
14                                            int *num_feedbacks);
15
16       int XChangeFeedbackControl( Display *display,
17                                   XDevice *device,
18                                   Mask mask,
19                                   XFeedbackControl *control);
20
21       display
22              Specifies the connection to the X server.
23
24       device
25              Specifies the device whose feedbacks are to be queried
26              or modified.
27
28       num_feedbacks
29              Specifies an address into which the number of feedbacks
30              supported by the device is to be returned.
31
32       mask
33              Specifies a mask specific to each type of feedback that
34              describes how the feedback is to be modified.
35
36       control
37              Specifies the address of an XFeedbackControl structure
38              that contains the new values for the feedback.
39

DESCRIPTION

41           These requests are provided to manipulate those input devices
42           that support feedbacks. A BadMatch error will be generated if
43           the requested device does not support feedbacks. Whether or not
44           a given device supports feedbacks can be determined by
45           examining the information returned by the XOpenDevice request.
46           For those devices that support feedbacks, XOpenDevice will
47           return an XInputClassInfo structure with the input_class field
48           equal to the constant FeedbackClass (defined in the file XI.h).
49
50           The XGetFeedbackControl request returns a pointer to a list of
51           XFeedbackState structures. Each item in this list describes one
52           of the feedbacks supported by the device. The items are
53           variable length, so each contains its length to allow traversal
54           to the next item in the list.
55
56           The feedback classes that are currently defined are:
57           KbdFeedbackClass, PtrFeedbackClass, StringFeedbackClass,
58           IntegerFeedbackClass, LedFeedbackClass, and BellFeedbackClass.
59           These constants are defined in the file XI.h. An input device
60           may support zero or more classes of feedback, and may support
61           multiple feedbacks of the same class. Each feedback contains a
62           class identifier and an id that is unique within that class for
63           that input device. The id is used to identify the feedback when
64           making an XChangeFeedbackControl request.
65
66           XGetFeedbackControl can generate a BadDevice or BadMatch error.
67
68           The XChangeFeedbackControl request modifies the values of one
69           feedback on the specified device. The feedback is identified by
70           the id field of the XFeedbackControl structure that is passed
71           with the request. The fields of the feedback that are to be
72           modified are identified by the bits of the mask that is passed
73           with the request.
74
75           XChangeFeedbackControl can generate a BadDevice, BadMatch, or
76           BadValue error.
77
78   Structures
79           Each class of feedback is described by a structure specific to
80           that class. These structures are defined in the file XInput.h.
81           XFeedbackState and XFeedbackControl are generic structures that
82           contain three fields that are at the beginning of each class of
83           feedback:
84
85           typedef struct {
86               XID class;
87               int length;
88               XID id;
89           } XFeedbackState, XFeedbackControl;
90
91           The XKbdFeedbackState structure defines the attributes that are
92           returned for feedbacks equivalent to those on the X keyboard.
93
94           typedef struct {
95               XID class;
96               int length;
97               XID id;
98               int click;
99               int percent;
100               int pitch;
101               int duration;
102               int led_mask;
103               int global_auto_repeat;
104               char auto_repeats[32];
105           } XKbdFeedbackState;
106
107           The XPtrFeedbackState structure defines the attributes that are
108           returned for feedbacks equivalent to those on the the X
109           pointer.
110
111           typedef struct {
112               XID class;
113               int length;
114               XID id;
115               int accelNum;
116               int accelDenom;
117               int threshold;
118           } XPtrFeedbackState;
119
120           The XIntegerFeedbackState structure defines attributes that are
121           returned for integer feedbacks.
122
123           typedef struct {
124               XID class;
125               int length;
126               XID id;
127               int resolution;
128               int minVal;
129               int maxVal;
130           } XIntegerFeedbackState;
131
132           The XStringFeedbackState structure defines the attributes that
133           are returned for string feedbacks.
134
135           typedef struct {
136               XID class;
137               int length;
138               XID id;
139               int max_symbols;
140               int num_syms_supported;
141               KeySym *syms_supported;
142           } XStringFeedbackState;
143
144           The XBellFeedbackState structure defines the attributes that
145           are returned for bell feedbacks.
146
147           typedef struct {
148               XID class;
149               int length;
150               XID id;
151               int percent;
152               int pitch;
153               int duration;
154           } XBellFeedbackState;
155
156           The XLedFeedbackState structure defines the attributes that are
157           returned for LED feedbacks.
158
159           typedef struct {
160               XID class;
161               int length;
162               XID id;
163               int led_values;
164           } XLedFeedbackState;
165
166           The XPrtFeedbackControl structure defines the attributes that
167           can be controlled for pointer feedbacks.
168
169           typedef struct {
170               XID class;
171               int length;
172               XID id;
173               int accelNum;
174               int accelDenom;
175               int threshold;
176           } XPtrFeedbackControl;
177
178           The XKbdFeedbackControl structure defines the attributes that
179           can be controlled for keyboard feedbacks.
180
181           typedef struct {
182               XID class;
183               int length;
184               XID id;
185               int click;
186               int percent;
187               int pitch;
188               int duration;
189               int led_mask;
190               int led_value;
191               int key;
192               int auto_repeat_mode;
193           } XKbdFeedbackControl;
194
195           The XStringFeedbackControl structure defines the attributes
196           that can be controlled for string feedbacks.
197
198           typedef struct {
199               XID class;
200               int length;
201               XID id;
202               int num_keysyms;
203               KeySym  *syms_to_display;
204           } XStringFeedbackControl;
205
206           The XIntegerFeedbackControl structure defines the attributes
207           that can be controlled for integer feedbacks.
208
209           typedef struct {
210               XID class;
211               int length;
212               XID id;
213               int int_to_display;
214           } XIntegerFeedbackControl;
215
216           The XBellFeedbackControl structure defines the attributes that
217           can be controlled for bell feedbacks.
218
219           typedef struct {
220               XID     class;
221               int     length;
222               XID     id;
223               int     percent;
224               int     pitch;
225               int     duration;
226           } XBellFeedbackControl;
227
228           The XLedFeedbackControl structure defines the attributes that
229           can be controlled for LED feedbacks.
230
231           typedef struct {
232               XID     class;
233               int     length;
234               XID     id;
235               int     led_mask;
236               int     led_values;
237           } XLedFeedbackControl;
238

DIAGNOSTICS

240           BadDevice
241                  An invalid device was specified. The specified device
242                  does not exist or has not been opened by this client via
243                  XOpenInputDevice. This error may also occur if some
244                  other client has caused the specified device to become
245                  the X keyboard or X pointer device via the
246                  XChangeKeyboardDevice or XChangePointerDevice requests.
247
248           BadMatch
249                  This error may occur if an XGetFeedbackControl request
250                  was made specifying a device that has no feedbacks, or
251                  an XChangeFeedbackControl request was made with an
252                  XFeedbackControl structure that contains an invalid
253                  feedback type. It may also occur if an invalid
254                  combination of mask bits is specified ( DvKey but no
255                  DvAutoRepeatMode for keyboard feedbacks), or if an
256                  invalid KeySym is specified for a string feedback.
257
258           BadValue
259                  Some numeric value falls outside the range of values
260                  accepted by the XChangeFeedbackControl request. Unless a
261                  specific range is specified for an argument, the full
262                  range defined by the argument's type is accepted. Any
263                  argument defined as a set of alternatives can generate
264                  this error.
265
266
267
268                                  05/04/2023            XGETFEEDBACKCONTROL(3)
Impressum