Jump to content

KbdOpen: Difference between revisions

From EDM2
Created page with "==Description== This call creates a new logical keyboard. ==Syntax== <PRE> KbdOpen (KbdHandle) </PRE> ==Parameters== ; KbdHandle (PHKBD) - output : Address of the logi..."
 
Ak120 (talk | contribs)
 
(4 intermediate revisions by 2 users not shown)
Line 1: Line 1:
==Description==
This call creates a new logical keyboard.
This call creates a new logical keyboard.


==Syntax==
==Syntax==
<PRE>
  KbdOpen (KbdHandle)
  KbdOpen


    (KbdHandle)
==Parameters==
</PRE>
;KbdHandle (PHKBD) - output : Address of the logical keyboard.


==Parameters==
; KbdHandle (PHKBD) - output : Address of the logical keyboard.
==Return Code==
==Return Code==
rc (USHORT) - return
;rc (USHORT) - return:Return code descriptions are:
* 0  NO_ERROR
*440 ERROR_KBD_NO_MORE_HANDLE
*441 ERROR_KBD_CANNOT_CREATE_KCB
*464 ERROR_KBD_DETACHED
*504 ERROR_KBD_EXTENDED_SG


Return code descriptions are:
* 0    NO_ERROR
* 440        ERROR_KBD_NO_MORE_HANDLE
* 441        ERROR_KBD_CANNOT_CREATE_KCB
* 464        ERROR_KBD_DETACHED
* 504        ERROR_KBD_EXTENDED_SG
==Remarks==
==Remarks==
KbdOpen blocks while another thread has the keyboard focus (by way of KbdGetFocus) until the thread with the focus issues KbdFreeFocus. Therefore, to prevent KbdOpen from blocking, it is recommended that KbdOpen be issued only while the current thread has the focus. For example:
KbdOpen blocks while another thread has the keyboard focus (by way of [[KbdGetFocus]]) until the thread with the focus issues [[KbdFreeFocus]]. Therefore, to prevent KbdOpen from blocking, it is recommended that KbdOpen be issued only while the current thread has the focus. For example:


; KbdGetFocus : wait until focus available on handle 0  
;KbdGetFocus : wait until focus available on handle 0
;KbdOpen : get a logical keyboard handle
;KbdOpen : get another logical keyboard handle
;KbdOpen : get yet another logical keyboard handle
;KbdFreeFocus : give up the focus on handle 0.


; KbdOpen : get a logical keyboard handle
==Bindings==
 
=== C ===
; KbdOpen : get another logical keyboard handle
 
; KbdOpen : get yet another logical keyboard handle
 
; KbdFreeFocus : give up the focus on handle 0.
 
==Example Code==
=== C Binding===
<PRE>
<PRE>
#define INCL_KBD
#define INCL_KBD


USHORT  rc = KbdOpen(KbdHandle);
USHORT  rc = KbdOpen(KbdHandle);
PHKBD  KbdHandle;    /* Keyboard handle */


PHKBD            KbdHandle;    /* Keyboard handle */
USHORT rc;            /* return code */
 
USHORT           rc;            /* return code */
</PRE>
</PRE>


===MASM Binding===
===MASM===
<PRE>
<PRE>
EXTRN  KbdOpen:FAR
EXTRN  KbdOpen:FAR
Line 57: Line 46:
</PRE>
</PRE>


==Related Functions==
[[Category:Kbd]]
*
 
[[Category:The OS/2 API Project]]

Latest revision as of 16:14, 3 January 2019

This call creates a new logical keyboard.

Syntax

KbdOpen (KbdHandle)

Parameters

KbdHandle (PHKBD) - output
Address of the logical keyboard.

Return Code

rc (USHORT) - return
Return code descriptions are:
  • 0 NO_ERROR
  • 440 ERROR_KBD_NO_MORE_HANDLE
  • 441 ERROR_KBD_CANNOT_CREATE_KCB
  • 464 ERROR_KBD_DETACHED
  • 504 ERROR_KBD_EXTENDED_SG

Remarks

KbdOpen blocks while another thread has the keyboard focus (by way of KbdGetFocus) until the thread with the focus issues KbdFreeFocus. Therefore, to prevent KbdOpen from blocking, it is recommended that KbdOpen be issued only while the current thread has the focus. For example:

KbdGetFocus
wait until focus available on handle 0
KbdOpen
get a logical keyboard handle
KbdOpen
get another logical keyboard handle
KbdOpen
get yet another logical keyboard handle
KbdFreeFocus
give up the focus on handle 0.

Bindings

C

#define INCL_KBD

USHORT  rc = KbdOpen(KbdHandle);
PHKBD   KbdHandle;     /* Keyboard handle */

USHORT  rc;            /* return code */

MASM

EXTRN  KbdOpen:FAR
INCL_KBD            EQU 1

PUSH@  WORD    KbdHandle     ;Keyboard handle
CALL   KbdOpen

Returns WORD