Differences
This shows you the differences between two versions of the page.
Both sides previous revisionPrevious revisionNext revision | Previous revision | ||
en:docs:fapi:vioscrlock [2021/08/20 08:38] – prokushev | en:docs:fapi:vioscrlock [2021/09/19 04:46] (current) – prokushev | ||
---|---|---|---|
Line 1: | Line 1: | ||
{{page> | {{page> | ||
+ | ====== VioScrLock ====== | ||
+ | |||
This call requests ownership of (locks) the physical display buffer. | This call requests ownership of (locks) the physical display buffer. | ||
- | ==Syntax== | + | ===== Syntax ===== |
- | | + | <code c> |
+ | VioScrLock (WaitFlag, Status, VioHandle) | ||
+ | </ | ||
+ | ===== Parameters ===== | ||
+ | |||
+ | * WaitFlag ([[USHORT]]) - input : Indicates whether the process should block until the screen I/O can take place. | ||
+ | |||
+ | ^ Value ^ Definition ^ | ||
+ | | 0 | Return if screen I/O not available | | ||
+ | | 1 | Wait until screen I/O is available | | ||
+ | |||
+ | * Status ([[PUCHAR]]) - output : Address of the Indicator of whether the lock is successful, described below. | ||
+ | |||
+ | ^ Value ^ Definition ^ | ||
+ | | 0 | Lock successful | | ||
+ | | 1 | Lock unsuccessful (in the case of no wait) | | ||
- | ==Parameters== | ||
- | ;WaitFlag (USHORT) - input : Indicates whether the process should block until the screen I/O can take place. | ||
- | ''' | ||
- | | ||
- | | ||
- | ; Status (PUCHAR) - output : Address of the Indicator of whether the lock is successful, described below. | ||
- | ''' | ||
- | | ||
- | | ||
Status is returned only when AX = 0. | Status is returned only when AX = 0. | ||
Status = 1 may be returned only when WaitFlag = 0. | Status = 1 may be returned only when WaitFlag = 0. | ||
- | ; VioHandle (HVIO) - input : Reserved word of 0s. | ||
- | ==Return Code== | + | * VioHandle ([[HVIO]]) - input : Reserved word of 0s. |
- | rc (USHORT) - return | + | |
+ | ===== Return Code ===== | ||
+ | |||
+ | rc ([[USHORT]]) - return | ||
Return code descriptions are: | Return code descriptions are: | ||
- | * 0 NO_ERROR | ||
- | * 366 ERROR_VIO_WAIT_FLAG | ||
- | * 430 ERROR_VIO_ILLEGAL_DURING_POPUP | ||
- | * 434 ERROR_VIO_LOCK | ||
- | * 436 ERROR_VIO_INVALID_HANDLE | ||
- | * 465 ERROR_VIO_DETACHED | ||
- | * 494 ERROR_VIO_EXTENDED_SG | ||
- | ==Remarks== | + | * 0 NO_ERROR |
+ | * 366 ERROR_VIO_WAIT_FLAG | ||
+ | * 430 ERROR_VIO_ILLEGAL_DURING_POPUP | ||
+ | * 434 ERROR_VIO_LOCK | ||
+ | * 436 ERROR_VIO_INVALID_HANDLE | ||
+ | * 465 ERROR_VIO_DETACHED | ||
+ | * 494 ERROR_VIO_EXTENDED_SG | ||
+ | |||
+ | ===== Remarks ===== | ||
This function call permits a process to determine if I/O to the physical screen buffer can take place. This prevents the process from writing to the physical buffer when the process is in the background. Processes must cooperate with the system in coordinating screen accesses. | This function call permits a process to determine if I/O to the physical screen buffer can take place. This prevents the process from writing to the physical buffer when the process is in the background. Processes must cooperate with the system in coordinating screen accesses. | ||
Line 38: | Line 50: | ||
When the screen lock is in effect and another thread in the same or different process (in the same session) issues VioScrLock, the second thread receives an error code. VioScrUnLock must be issued by a thread within the same process that issued VioScrLock. | When the screen lock is in effect and another thread in the same or different process (in the same session) issues VioScrLock, the second thread receives an error code. VioScrUnLock must be issued by a thread within the same process that issued VioScrLock. | ||
- | ===Family API Considerations=== | + | ==== Family API Considerations ==== |
Some options operate differently in the DOS mode than in the OS/2 mode. Therefore, the following restriction applies to VioScrLock when coding in the DOS mode: | Some options operate differently in the DOS mode than in the OS/2 mode. Therefore, the following restriction applies to VioScrLock when coding in the DOS mode: | ||
The status always indicates the lock is successful (Return code = 0). | The status always indicates the lock is successful (Return code = 0). | ||
- | ==Example Code== | + | ===== Bindings ===== |
- | === C Binding=== | + | |
- | <PRE> | + | ==== C Binding==== |
+ | <code c> | ||
#define INCL_VIO | #define INCL_VIO | ||
Line 55: | Line 69: | ||
USHORT | USHORT | ||
- | </PRE> | + | </code> |
- | ===MASM Binding=== | + | ====MASM Binding==== |
- | <PRE> | + | <code asm> |
EXTRN VioScrLock: | EXTRN VioScrLock: | ||
INCL_VIO | INCL_VIO | ||
Line 68: | Line 82: | ||
Returns WORD | Returns WORD | ||
+ | </ | ||
- | + | ===== Note ===== | |
- | ====== Note ====== | + | |
Text based on [[http:// | Text based on [[http:// |