exevents.h revision a3f3701cea1ba388e7c877955252bb7375eedebd
/************************************************************
Copyright 1996 by Thomas E. Dickey <dickey@clark.net>
All Rights Reserved
Permission to use, copy, modify, and distribute this software and its
documentation for any purpose and without fee is hereby granted,
provided that the above copyright notice appear in all copies and that
both that copyright notice and this permission notice appear in
supporting documentation, and that the name of the above listed
copyright holder(s) not be used in advertising or publicity pertaining
to distribution of the software without specific, written prior
permission.
THE ABOVE LISTED COPYRIGHT HOLDER(S) DISCLAIM ALL WARRANTIES WITH REGARD
TO THIS SOFTWARE, INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
AND FITNESS, IN NO EVENT SHALL THE ABOVE LISTED COPYRIGHT HOLDER(S) BE
LIABLE FOR ANY SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
********************************************************/
/********************************************************************
* Interface of 'exevents.c'
*/
#ifndef EXEVENTS_H
#define EXEVENTS_H
#include "inputstr.h"
/***************************************************************
* Interface available to drivers *
***************************************************************/
/**
* Scroll flags for ::SetScrollValuator.
*/
enum ScrollFlags {
SCROLL_FLAG_NONE = 0,
/**
* Do not emulate legacy button events for valuator events on this axis.
*/
/**
* This axis is the preferred axis for valuator emulation for this axis'
* scroll type.
*/
};
int /* axnum */ ,
Atom /* label */ ,
int /* minval */ ,
int /* maxval */ ,
int /* resolution */ ,
int /* min_res */ ,
int /* max_res */ ,
int /* mode */ );
int /* axnum */ ,
enum ScrollType /* type */ ,
double /* increment */ ,
int /* flags */ );
/* Input device properties */
);
Atom /* property */ ,
Bool /* fromClient */
);
Atom /* property */ ,
Atom /* type */ ,
int /* format */ ,
int /* mode */ ,
unsigned long /* len */ ,
const void * /* value */ ,
Bool /* sendevent */
);
Atom /* property */ ,
XIPropertyValuePtr * /* value */
);
Atom /* property */ ,
Bool /* deletable */
);
int (*SetProperty) (DeviceIntPtr
dev,
prop,
int (*GetProperty) (DeviceIntPtr
dev,
property),
int (*DeleteProperty)
);
int *nelem_return, int **buf_return);
int *nelem_return, float **buf_return);
/****************************************************************************
* End of driver interface *
****************************************************************************/
/**
* Attached to the devPrivates of each client. Specifies the version number as
* supported by the client.
*/
typedef struct _XIClientRec {
int major_version;
int minor_version;
} XIClientRec, *XIClientPtr;
typedef struct _GrabParameters {
int grabtype; /* CORE, etc. */
unsigned int ownerEvents;
unsigned int this_device_mode;
unsigned int other_devices_mode;
unsigned int modifiers;
extern int
DeviceEvent * /* xE */ );
extern void
DeviceIntPtr /* other */ );
extern int
GrabParameters * /* param */ );
extern int
DeviceIntPtr /* dev */ ,
DeviceIntPtr /* modifier_device */ ,
int /* button */ ,
GrabParameters * /* param */ ,
enum InputLevel /* grabtype */ ,
GrabMask * /* eventMask */ );
extern int
DeviceIntPtr /* dev */ ,
DeviceIntPtr /* modifier_device */ ,
int /* key */ ,
GrabParameters * /* param */ ,
enum InputLevel /* grabtype */ ,
GrabMask * /* eventMask */ );
extern int
DeviceIntPtr /* dev */ ,
int /* type */ ,
GrabParameters * /* param */ ,
GrabMask * /* eventMask */ );
extern int
DeviceIntPtr /* dev */ ,
DeviceIntPtr /* mod_dev */ ,
GrabParameters * /* param */ ,
GrabMask * /* eventMask */ );
extern int
WindowPtr /* pWin */ ,
ClientPtr /* client */ ,
Mask /* mask */ ,
Mask /* exclusivemasks */ );
extern int
ClientPtr /* client */ ,
Mask /* mask */ ,
int /* mskidx */ );
extern void
extern int
XID /* id */ );
extern void
extern int
DeviceIntPtr /* d */ ,
Window /* dest */ ,
Bool /* propagate */ ,
xEvent * /* ev */ ,
Mask /* mask */ ,
int /* count */ );
extern int
DeviceIntPtr /* dev */ ,
int /* nElts */ ,
BYTE * /* map */ );
extern int
DeviceIntPtr /* dev */ ,
unsigned /* len */ ,
int /* type */ ,
KeyCode /* firstKeyCode */ ,
CARD8 /* keyCodes */ ,
CARD8 /* keySymsPerKeyCode */ ,
KeySym * /* map */ );
extern void
Bool /* freeResources */ );
extern int
Mask /* mask */ );
extern void
int /* type */ ,
deviceKeyButtonPointer * /* xE */ ,
GrabPtr /* grab */ ,
ClientPtr /* client */ ,
Mask /* deliveryMask */ );
extern void
ClientPtr /* client */ );
extern int
ClientPtr /* client */ ,
Mask /* mask */ ,
int /* maskndx */ );
extern void
Mask /* mask */ ,
xEvent * /* ev */ ,
int /* count */ );
extern void
TouchPointInfoPtr /* ti */ ,
XID /* resource */ ,
TouchOwnershipEvent * /* ev */ );
xGenericEvent * /* to */ );
/* For an event such as MappingNotify which affects client interpretation
* of input events sent by device dev, should we notify the client, or
* would it merely be irrelevant and confusing? */
extern int
extern void
extern int
extern int
#endif /* EXEVENTS_H */