|
DataMuseum.dkPresents historical artifacts from the history of: DKUUG/EUUG Conference tapes |
This is an automatic "excavation" of a thematic subset of
See our Wiki for more about DKUUG/EUUG Conference tapes Excavated with: AutoArchaeologist - Free & Open Source Software. |
top - downloadIndex: ┃ T X ┃
Length: 12381 (0x305d) Types: TextFile Names: »XrInput.3x«
└─⟦a0efdde77⟧ Bits:30001252 EUUGD11 Tape, 1987 Spring Conference Helsinki └─ ⟦526ad3590⟧ »EUUGD11/gnu-31mar87/X.V10.R4.tar.Z« └─⟦2109abc41⟧ └─ ⟦this⟧ »./X.V10R4/Toolkit/Xr/usr/man/man3/XrInput.3x«
.TH XRINPUT 3X "Xrlib Version 10" .SH NAME XrInput - the input handling function. .SH SYNOPSIS #include <X/Xlib.h> .br #include <Xr/Xrlib.h> .br .PP .B XrInput (windowId, message, data) .br Window windowId; .br INT32 message; .br INT8 * data; .PP .SH DESCRIPTION XrInput() handles the requests for input by an application from a window or windows and the setting of window and input attributes necessary to handle editors and panel managers. .PP Most of the messages will use the xrEvent structure which is defined as follows. .nf typedef struct { UINT32 type; INT32 source; INT16 inputCode; INT8 inputType; INT8 value1; INT16 value2; INT16 value3; POINT valuePt; INT32 valuePtr; } xrEvent; .fi .PP When input occurs from a window, the .I type field of the structure will be set to one of X's input types or to the define .B XrXRAY for Xrlib input types. Refer to the X documentation for a complete description of X input. An application can only generate Xrlib input, and thus use editors, panels, and menus, if the window is registered with XrInput. The is accomplished through the MSG_ADDWINDOW message listed below. If the .I type field of the xrEvent structure is set to .B XrXRAY, the .I source field will contain the id of the window in which the input occurred, and the .I inputType field will be set to one of the defines listed in the table below. .sp 1 .TS center allbox; ll. Type Meaning _ XrEDITOR Input from an editor XrPANEL Input from a panel XrMENU Input from a menu XrMESSAGEBOX Input from a message box XrFILE Input from a file descriptor .TE .sp 1 .PP An application can also gather input from any file descriptor that has been opened. Examples of this would be input from a pty or socket. If this type of input is pending, the .I source field in the xrEvent structure will be set to the file descriptor and the .I inputType field will be set to .B XrFILE. It is then up to the application to get the input from the file descriptor. .sp .PP The messages which XrInput() provides are broken into several functional groupings. .PP .IP MSG_ADDWINDOW If an application wants to gather Xrlib type input or place editors within a window it has created, Xrlib needs to be told about the window. Issuing this message causes a window to be registered with XrInput(), which then sets up the other routines which need to know about the window. To register a window, .I windowId should be set to the id of the window to be registered and .I data needs to point to an xrWindowData structure which is defined as follows: .nf typedef struct { RECTANGLE windowRect; Pixmap foreTile; Pixmap backTile; } xrWindowData; .fi .IP MSG_REMOVEWINDOW When an application destroys a window, it should call XrInput() so that the window will be removed from XrInput()'s tables. For this message, .I windowId should be set to the id of the window to be removed and .I data is unused and can be set to .B NULL. .IP MSG_SETWINDOWDATA If an application changes the size or tiles of a window, XrInput() needs to be given the data to modify its tables. For this message, .I windowId should be set to the id of the window in which the data is to be set and .I data should be set to point to an xrWindowData structure which contains the needed information. .IP MSG_GETWINDOWDATA This messages returns the data for a window. For this call, .I windowId should be set to the id of the window in which the data is contained and .I data is a pointer to an xrWindowData structure. The members of this structure will be set to the data values for the window. .IP MSG_ADDWINDOWFUNCT Xrlib high-level manager functions have the ability to be called automatically upon a particular input or inputs. An example of this is the menu manager displaying a menu upon a menu event input. To accomplish this function, XrInput() maintains a set of information for each registered window. This message is the means by which a particular window gets the capabilities described above. For this message, .I data is a pointer to the following structure: .nf typedef struct { INT8 processFlag; xrPFI (*funct)(); INT32 instance; INT32 message; INT32 eventCount; xrWindowEvent * eventList; } xrWindowFunct; .fi The .I funct field contains a pointer to the function that is to be invoked when a particular event occurs. The function must be of the form: .nf (*funct)(instance, message, data) INT32 instance; int message; INT8 * data; .fi .I instance is the instance of the type of element .I funct is to operate upon. .I message is the message that is to be sent to the function. .I data will be a pointer to the event which occurred to invoke this function. .IP The rest of the parameters contained within the xrWindowFunct structure are defined as follows. .I processFlag is a boolean which is set to .B TRUE or .B FALSE by the application or manager adding the xrWindowFunct structure. It is used to turn on and off the processing of the event list and the automatic calling of the function attached to the window. .I eventCount contains a count of that number of events. .I eventList contains a pointer to an array of window event structures which are defined as follows: .nf typedef struct { UINT32 inputType; INT16 inputCode; } xrWindowEvent; .fi The type field of this structure can be set to any combination of X event types. The input code field is used for button or key events to further distingush the function. Each window can have as many xrWindowFunct structures attached to it as is needed. When input occurs on the window the event lists contained within the xrWindowFunct structures that are attached to the window will be searched to see if a match can be found. If the event matches one of the events listed for the window the function for the event is invoked. If no match is found, the event is returned as normal input. .IP MSG_REMOVEWINDOWFUNCT This message removes an xrWindowFunct structure that was previously added to the window .I windowId. data is a pointer to the function that matches the function supplied in the xrWindowFunct structure contained within the window. .IP MSG_SETPROCESSFLAG A manager of a window may, at times, want to turn on and off the event list checking and function calling provided through MSG_ADDWINDOWFUNCT. This message sets the .I processFlag field of the xrWindowFunct structure to .B TRUE which turns on the processing function for the window identified by the parameter .I windowId. .I data is a pointer to the function whose .I processFlag is to be set. .IP MSG_CLEARPROCESSFLAG This message is used to turn off a processing function for a window. Issuing this message causes .I processFlag to be set to .B FALSE which turns off the processing function for the window identified by the parameter .I windowId. data is a pointer to the function whose .I processFlag is to be cleared. .sp .P The following set of messages provide for the different forms of gathering input from Xrlib. .P Xrlib supports both blocked and non-blocked input. Blocked input will cause the input routine to wait for input to occur on one of the windows or the file descriptors before returning. Blocked input will also return before input occurs is the application has supplied a timeout value. Non-blocked input will return immediately with either input or an indicator that no input has occurred. .P Two modes of input are available within Xrlib. They are regular reads and hot reads. The difference between the two types of read involve the activation of the event list processing of the events attached to the window. For hot reads, when input occurs, the set of events attached to the window is scanned. If an event is found which matches the input, the cooresponding function is called. This is the means by which all of the editors and the menu system is invoked. .IP MSG_BLKREAD This message copies an input event into the XEvent structure pointed at by .I data if there is input pending. If there is no input, the call will wait until input occurs and return the input. .IP MSG_NONBLKREAD This message copies an input event into the XEvent structure pointed at by .I data if there is input pending. If there is no input, .I data is left unchanged and .B FALSE is returned. .IP MSG_BLKHOTREAD This message copies an input event into the XEvent structure pointed at by .I data if there is input pending. If there is no input, the call will wait until input occurs and return the input. If the input is select or menu input, the editors or menuing system will be invoked if appropriate. .IP MSG_NONBLKHOTREAD This message copies an input event into the XEvent structure pointed at by .I data if there is input pending. If there is no input, .I data is left unchanged and .B FALSE is returned. If the input is select or menu input, the editors or menuing system will be invoked if appropriate. .sp .P Xrlib provides a set of message for manipulating the input queue. The following list contains this set of messages. .IP MSG_PUSHEVENT This message places an event structure pointed to by .I data onto the front of the input queue. The next read will return this event. .IP MSG_PEEKEVENT This messages fills out the event structure pointed to by .I data from the event on the front of the input queue. The input queue is left unaffected by this call. If the input queue is empty, this call will fail. .IP MSG_CLEAR This message clears the input queue of all pending input. .I data is unused for this call and can be set to .B NULL. .sp .P The following list contains the set of messages to setup and change which sources XrInput() is to gather input. .IP MSG_ADDINPUT This message adds a file descriptor for which XrInput() is to gather input. .I data is a pointer to an xrFDInput structure which is defined as follows. .nf typedef struct { INT32 fd; INT8 type; } xrFDInput; .fi The .I fd field contains the file descriptor for the source of the input in which XrInput() is to gather input. The .I type field tells XrInput() which forms of input should be gathered from the file descriptor. It can be set to any combination of the defines .B XrREAD, XrWRITE, or .B XrEXCEPTION. These defines should be "Or'ed" together to define the value of this field. .IP MSG_REMOVEINPUT This message removes a previously added file descriptor from the input set. .I data must be set to point to an xrFDInput structure discussed in MSG_ADDINPUT. The structure should contain the file descriptor and the conditions which are to be removed. .IP MSG_SETTIMEOUT This message sets a timeout value, in seconds, for XrInput() to wait for input to occur from the file descriptors it is selecting upon. .I data is a pointer to the following structure. .nf struct timeval { unsigned long tv_sec; long tv_usec; }; .fi The .I tv_sec field defines the number of seconds to wait before a timeout is to occur. The .I tv_usec field defines the number of micro seconds to wait before a timeout is to occur. This structure is defined in <time.h>. .IP The timeout value will affect how blocked reads work. Normally, the blocked read will wait indefinitely for input. If an application sets a timeout value, the blocked read will wait only the number of seconds + the number of micro seconds given by the value. The value of the timeout will have no effect on non-blocked reads. .IP MSG_GETTIMEOUT This message returns the current timeout value. .I data is a pointer a timeval structure which will be filled out to the current values. .SH RETURNED VALUE For all of XrInput()'s messages, .B TRUE is returned if the function succeeds and .B FALSE is returned if it fails. .SH ERROR CONDITIONS If XrInput() fails, the .I xrErrno global will be set to one of the following values. .P .I xrErrno will be set to .B XrINVALIDID for all messages if the passed in window id is invalid. .P .I xrErrno will be set to .B XrINVALIDMSG for any messages besides the messages listed above. .P .I xrErrno will be set to .B XrINVALIDPARM whenever the data parameter contains invalid information. .P .I xrErrno will be set to .B XrOUTOFMEM if MSG_ADDWINDOW cannot allocate the needed space for a window. .P For reading messages, a return value of .B FALSE indicates that their was no input or a timeout occurred before input. There is no failure condition.