xref: /OK3568_Linux_fs/external/xserver/Xi/stubs.c (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1*4882a593Smuzhiyun /************************************************************
2*4882a593Smuzhiyun 
3*4882a593Smuzhiyun Copyright 1989, 1998  The Open Group
4*4882a593Smuzhiyun 
5*4882a593Smuzhiyun Permission to use, copy, modify, distribute, and sell this software and its
6*4882a593Smuzhiyun documentation for any purpose is hereby granted without fee, provided that
7*4882a593Smuzhiyun the above copyright notice appear in all copies and that both that
8*4882a593Smuzhiyun copyright notice and this permission notice appear in supporting
9*4882a593Smuzhiyun documentation.
10*4882a593Smuzhiyun 
11*4882a593Smuzhiyun The above copyright notice and this permission notice shall be included in
12*4882a593Smuzhiyun all copies or substantial portions of the Software.
13*4882a593Smuzhiyun 
14*4882a593Smuzhiyun THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
15*4882a593Smuzhiyun IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
16*4882a593Smuzhiyun FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL THE
17*4882a593Smuzhiyun OPEN GROUP BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN
18*4882a593Smuzhiyun AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
19*4882a593Smuzhiyun CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
20*4882a593Smuzhiyun 
21*4882a593Smuzhiyun Except as contained in this notice, the name of The Open Group shall not be
22*4882a593Smuzhiyun used in advertising or otherwise to promote the sale, use or other dealings
23*4882a593Smuzhiyun in this Software without prior written authorization from The Open Group.
24*4882a593Smuzhiyun 
25*4882a593Smuzhiyun Copyright 1989 by Hewlett-Packard Company, Palo Alto, California.
26*4882a593Smuzhiyun 
27*4882a593Smuzhiyun 			All Rights Reserved
28*4882a593Smuzhiyun 
29*4882a593Smuzhiyun Permission to use, copy, modify, and distribute this software and its
30*4882a593Smuzhiyun documentation for any purpose and without fee is hereby granted,
31*4882a593Smuzhiyun provided that the above copyright notice appear in all copies and that
32*4882a593Smuzhiyun both that copyright notice and this permission notice appear in
33*4882a593Smuzhiyun supporting documentation, and that the name of Hewlett-Packard not be
34*4882a593Smuzhiyun used in advertising or publicity pertaining to distribution of the
35*4882a593Smuzhiyun software without specific, written prior permission.
36*4882a593Smuzhiyun 
37*4882a593Smuzhiyun HEWLETT-PACKARD DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE, INCLUDING
38*4882a593Smuzhiyun ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO EVENT SHALL
39*4882a593Smuzhiyun HEWLETT-PACKARD BE LIABLE FOR ANY SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR
40*4882a593Smuzhiyun ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS,
41*4882a593Smuzhiyun WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION,
42*4882a593Smuzhiyun ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS
43*4882a593Smuzhiyun SOFTWARE.
44*4882a593Smuzhiyun 
45*4882a593Smuzhiyun ********************************************************/
46*4882a593Smuzhiyun 
47*4882a593Smuzhiyun /*
48*4882a593Smuzhiyun  * stubs.c -- stub routines for the X server side of the XINPUT
49*4882a593Smuzhiyun  * extension.  This file is mainly to be used only as documentation.
50*4882a593Smuzhiyun  * There is not much code here, and you can't get a working XINPUT
51*4882a593Smuzhiyun  * server just using this.
52*4882a593Smuzhiyun  * The Xvfb server uses this file so it will compile with the same
53*4882a593Smuzhiyun  * object files as the real X server for a platform that has XINPUT.
54*4882a593Smuzhiyun  * Xnest could do the same thing.
55*4882a593Smuzhiyun  */
56*4882a593Smuzhiyun 
57*4882a593Smuzhiyun #ifdef HAVE_DIX_CONFIG_H
58*4882a593Smuzhiyun #include <dix-config.h>
59*4882a593Smuzhiyun #endif
60*4882a593Smuzhiyun 
61*4882a593Smuzhiyun #include <X11/X.h>
62*4882a593Smuzhiyun #include <X11/Xproto.h>
63*4882a593Smuzhiyun #include "inputstr.h"
64*4882a593Smuzhiyun #include <X11/extensions/XI.h>
65*4882a593Smuzhiyun #include <X11/extensions/XIproto.h>
66*4882a593Smuzhiyun #include "XIstubs.h"
67*4882a593Smuzhiyun #include "xace.h"
68*4882a593Smuzhiyun 
69*4882a593Smuzhiyun /****************************************************************************
70*4882a593Smuzhiyun  *
71*4882a593Smuzhiyun  * Caller:	ProcXSetDeviceMode
72*4882a593Smuzhiyun  *
73*4882a593Smuzhiyun  * Change the mode of an extension device.
74*4882a593Smuzhiyun  * This function is used to change the mode of a device from reporting
75*4882a593Smuzhiyun  * relative motion to reporting absolute positional information, and
76*4882a593Smuzhiyun  * vice versa.
77*4882a593Smuzhiyun  * The default implementation below is that no such devices are supported.
78*4882a593Smuzhiyun  *
79*4882a593Smuzhiyun  */
80*4882a593Smuzhiyun 
81*4882a593Smuzhiyun int
SetDeviceMode(ClientPtr client,DeviceIntPtr dev,int mode)82*4882a593Smuzhiyun SetDeviceMode(ClientPtr client, DeviceIntPtr dev, int mode)
83*4882a593Smuzhiyun {
84*4882a593Smuzhiyun     return BadMatch;
85*4882a593Smuzhiyun }
86*4882a593Smuzhiyun 
87*4882a593Smuzhiyun /****************************************************************************
88*4882a593Smuzhiyun  *
89*4882a593Smuzhiyun  * Caller:	ProcXSetDeviceValuators
90*4882a593Smuzhiyun  *
91*4882a593Smuzhiyun  * Set the value of valuators on an extension input device.
92*4882a593Smuzhiyun  * This function is used to set the initial value of valuators on
93*4882a593Smuzhiyun  * those input devices that are capable of reporting either relative
94*4882a593Smuzhiyun  * motion or an absolute position, and allow an initial position to be set.
95*4882a593Smuzhiyun  * The default implementation below is that no such devices are supported.
96*4882a593Smuzhiyun  *
97*4882a593Smuzhiyun  */
98*4882a593Smuzhiyun 
99*4882a593Smuzhiyun int
SetDeviceValuators(ClientPtr client,DeviceIntPtr dev,int * valuators,int first_valuator,int num_valuators)100*4882a593Smuzhiyun SetDeviceValuators(ClientPtr client, DeviceIntPtr dev,
101*4882a593Smuzhiyun                    int *valuators, int first_valuator, int num_valuators)
102*4882a593Smuzhiyun {
103*4882a593Smuzhiyun     return BadMatch;
104*4882a593Smuzhiyun }
105*4882a593Smuzhiyun 
106*4882a593Smuzhiyun /****************************************************************************
107*4882a593Smuzhiyun  *
108*4882a593Smuzhiyun  * Caller:	ProcXChangeDeviceControl
109*4882a593Smuzhiyun  *
110*4882a593Smuzhiyun  * Change the specified device controls on an extension input device.
111*4882a593Smuzhiyun  *
112*4882a593Smuzhiyun  */
113*4882a593Smuzhiyun 
114*4882a593Smuzhiyun int
ChangeDeviceControl(ClientPtr client,DeviceIntPtr dev,xDeviceCtl * control)115*4882a593Smuzhiyun ChangeDeviceControl(ClientPtr client, DeviceIntPtr dev, xDeviceCtl * control)
116*4882a593Smuzhiyun {
117*4882a593Smuzhiyun     return BadMatch;
118*4882a593Smuzhiyun }
119*4882a593Smuzhiyun 
120*4882a593Smuzhiyun /****************************************************************************
121*4882a593Smuzhiyun  *
122*4882a593Smuzhiyun  * Caller: configAddDevice (and others)
123*4882a593Smuzhiyun  *
124*4882a593Smuzhiyun  * Add a new device with the specified options.
125*4882a593Smuzhiyun  *
126*4882a593Smuzhiyun  */
127*4882a593Smuzhiyun int
NewInputDeviceRequest(InputOption * options,InputAttributes * attrs,DeviceIntPtr * pdev)128*4882a593Smuzhiyun NewInputDeviceRequest(InputOption *options, InputAttributes * attrs,
129*4882a593Smuzhiyun                       DeviceIntPtr *pdev)
130*4882a593Smuzhiyun {
131*4882a593Smuzhiyun     return BadValue;
132*4882a593Smuzhiyun }
133*4882a593Smuzhiyun 
134*4882a593Smuzhiyun /****************************************************************************
135*4882a593Smuzhiyun  *
136*4882a593Smuzhiyun  * Caller: configRemoveDevice (and others)
137*4882a593Smuzhiyun  *
138*4882a593Smuzhiyun  * Remove the specified device previously added.
139*4882a593Smuzhiyun  *
140*4882a593Smuzhiyun  */
141*4882a593Smuzhiyun void
DeleteInputDeviceRequest(DeviceIntPtr dev)142*4882a593Smuzhiyun DeleteInputDeviceRequest(DeviceIntPtr dev)
143*4882a593Smuzhiyun {
144*4882a593Smuzhiyun     RemoveDevice(dev, TRUE);
145*4882a593Smuzhiyun }
146*4882a593Smuzhiyun 
147*4882a593Smuzhiyun /****************************************************************************
148*4882a593Smuzhiyun  *
149*4882a593Smuzhiyun  * Caller: configRemoveDevice (and others)
150*4882a593Smuzhiyun  *
151*4882a593Smuzhiyun  * Remove any traces of the input device specified in config_info.
152*4882a593Smuzhiyun  * This is only necessary if the ddx keeps information around beyond
153*4882a593Smuzhiyun  * the NewInputDeviceRequest/DeleteInputDeviceRequest
154*4882a593Smuzhiyun  *
155*4882a593Smuzhiyun  */
156*4882a593Smuzhiyun void
RemoveInputDeviceTraces(const char * config_info)157*4882a593Smuzhiyun RemoveInputDeviceTraces(const char *config_info)
158*4882a593Smuzhiyun {
159*4882a593Smuzhiyun }
160