en:ibm:prcp:kbd:xlat

Differences

This shows you the differences between two versions of the page.

Link to this comparison view

en:ibm:prcp:kbd:xlat [2014/05/16 18:37] – created valeriusen:ibm:prcp:kbd:xlat [2016/09/15 03:09] (current) valerius
Line 1: Line 1:
 ==== KbdXlate ==== ==== KbdXlate ====
  
-**Bindings**:+**Bindings**: [[xlat#C bindings|C]], [[xlat#MASM bindings|MASM]] 
 + 
 +This call translates scan codes with shift states into ASCII codes.  
 + 
 +KbdXlate (XlateRecord, KbdHandle)  
 + 
 +//XlateRecord// (**PKBDTRANS**) - input  
 +Address of the translation record structure:  
 + 
 +//chardata// (**KBDKEYINFO**)  
 +Character data information structure as defined in //[[charin|KbdCharIn]]// call.  
 + 
 +//kbdflag// (**USHORT**)  
 +See the //[[KbdDDFlagWord]]// call in the "Keyboard Device Driver" section of IBM Operating System/2 Version 1.2 I/O Subsystems And Device Support Volume 1.  
 + 
 +//xlate// (**USHORT**)  
 +Translation flag:  
 + 
 +^Value ^Definition ^ 
 +|0 |Translation incomplete. | 
 +|1 |Translation complete. | 
 + 
 +//xlatestate1// (**USHORT**)  
 +Identifies the state of translation across successive calls; initially the value should be zero. It may take several calls to this function to complete a character. The value should not be changed unless a new translation is required, that is, reset value to zero.  
 + 
 +//xlatestate2// (**USHORT**)  
 +See description for //xlatestate1//.  
 + 
 +//KbdHandle// (**HKBD**) - input  
 +Default keyboard or the logical keyboard.  
 + 
 +//rc// (**USHORT**) - return  
 +Return code descriptions are:  
 + 
 +|0 |NO_ERROR | 
 +|439 |ERROR_KBD_INVALID_HANDLE | 
 +|445 |ERROR_KBD_FOCUS_REQUIRED | 
 +|447 |ERROR_KBD_KEYBOARD_BUSY | 
 +|464 |ERROR_KBD_DETACHED | 
 +|504 |ERROR_KBD_EXTENDED_SG | 
 + 
 +**Remarks** 
 + 
 +It may take several calls to complete a translation because of accent key combinations, or other complex operations.  
 + 
 +The //Xlatestate1// and //Xlatestate2// are for use by the keyboard translation routines. These fields are reserved and must only be accessed by the caller prior to starting a translation sequence and then they must be set to zero. The //KbdXlate// function is intended to be used for translating a particular scan code for a given shift state. The //KbdXlate// function is not intended to be a replacement for the OS/2 system keystroke translation function.  
 + 
 +=== C bindings ===
  
-**C**: 
 <code c> <code c>
 typedef struct _KBDTRANS {    /* kbxl */ typedef struct _KBDTRANS {    /* kbxl */
Line 28: Line 74:
 </code> </code>
  
-**MASM**:+=== MASM bindings === 
 <code asm> <code asm>
 KBDTRANS struc KBDTRANS struc
Line 52: Line 99:
 Returns WORD Returns WORD
 </code> </code>
- 
-This call translates scan codes with shift states into ASCII codes.  
- 
-KbdXlate (XlateRecord, KbdHandle)  
- 
-//XlateRecord// (**PKBDTRANS**) - input  
-Address of the translation record structure:  
- 
-//chardata// (**KBDKEYINFO**)  
-Character data information structure as defined in //[[charin|KbdCharIn]]// call.  
- 
-//kbdflag// (**USHORT**)  
-See the //[[KbdDDFlagWord]]// call in the "Keyboard Device Driver" section of IBM Operating System/2 Version 1.2 I/O Subsystems And Device Support Volume 1.  
- 
-//xlate// (**USHORT**)  
-Translation flag:  
- 
-^Value ^Definition ^ 
-|0 |Translation incomplete. | 
-|1 |Translation complete. | 
- 
-//xlatestate1// (**USHORT**)  
-Identifies the state of translation across successive calls; initially the value should be zero. It may take several calls to this function to complete a character. The value should not be changed unless a new translation is required, that is, reset value to zero.  
- 
-//xlatestate2// (**USHORT**)  
-See description for //xlatestate1// 
- 
-//KbdHandle// (**HKBD**) - input  
-Default keyboard or the logical keyboard.  
- 
-//rc// (**USHORT**) - return  
-Return code descriptions are:  
- 
-|0 |NO_ERROR | 
-|439 |ERROR_KBD_INVALID_HANDLE | 
-|445 |ERROR_KBD_FOCUS_REQUIRED | 
-|447 |ERROR_KBD_KEYBOARD_BUSY | 
-|464 |ERROR_KBD_DETACHED | 
-|504 |ERROR_KBD_EXTENDED_SG | 
- 
-**Remarks** 
- 
-It may take several calls to complete a translation because of accent key combinations, or other complex operations.  
- 
-The //Xlatestate1// and //Xlatestate2// are for use by the keyboard translation routines. These fields are reserved and must only be accessed by the caller prior to starting a translation sequence and then they must be set to zero. The //KbdXlate// function is intended to be used for translating a particular scan code for a given shift state. The //KbdXlate// function is not intended to be a replacement for the OS/2 system keystroke translation function.