Articles
Forums
Downloads
Autodocs
Home
/
Autodocs
/
keymap.library
NAME
MapRawKey
Decode single raw key input event to an ANSI string. (V36)
SYNOPSIS
actual = MapRawKey(event, buffer, length, keyMap)
D0 A0 A1 D1 A2
WORD MapRawKey( struct InputEvent *, STRPTR, WORD,
struct Keymap * );
FUNCTION
This console function converts input events of type IECLASS_RAWKEY to ANSI bytes, based on the keyMap, and places the result into the buffer.
INPUTS
event
an InputEvent structure pointer. The event list is not traversed.
buffer
a byte buffer large enough to hold all anticipated characters generated by this conversion.
length
maximum anticipation, i.e. the buffer size in bytes.
keyMap
a KeyMap structure pointer, or null if the default key map is to be used.
RESULT
actual
the number of characters in the buffer, or -1 if a buffer overflow was about to occur.
EXAMPLE
...
#define BUFFERLEN 80 /* length of longest expected mapping /*
char buffer[BUFFERLEN];
struct InputEvent ie;
...
KeymapBase = OpenLibrary("keymap.library", 0);
...
ie.ie_Class = IECLASS_RAWKEY;
ie.ie_SubClass = 0;
for (;;) {
WaitPort(window->UserPort);
while (im = (struct IntuiMessage *) GetMsg(window->UserPort)) {
switch (im->Class) {
case RAWKEY:
ie.ie_Code = im->Code;
ie.ie_Qualifier = im->Qualifier;
/* recover dead key codes & qualifiers */
ie.ie_EventAddress = (APTR *) *((ULONG *)im->IAddress);
actual = MapRawKey(&ie, buffer, BUFFERLEN, 0);
for (i = 0; i < actual; i++)
ReportChar(buffer[i]);
break;
...
}
...
}
}
ERRORS
if actual is -1, a buffer overflow condition was detected.
Not all of the characters in the buffer are valid.
SEE ALSO
<devices/inputevent.h>, <devices/keymap.h>