[Overview][Constants][Types][Procedures and functions][Index] |
Wait for events on file descriptors
Source position: bunxh.inc line 96
function FPSelect( |
N: cint; |
readfds: pFDSet; |
writefds: pFDSet; |
exceptfds: pFDSet; |
TimeOut: ptimeval |
):cint; |
N: cint; |
readfds: pFDSet; |
writefds: pFDSet; |
exceptfds: pFDSet; |
TimeOut: cint |
):cint; |
var T: Text; |
TimeOut: ptimeval |
):cint; |
var T: Text; |
TimeOut: time_t |
):cint; |
FpSelect checks one of the file descriptors in the FDSets to see if the following I/O operation on the file descriptors will block.
readfds, writefds and exceptfds are pointers to arrays of 256 bits. If you want a file descriptor to be checked, you set the corresponding element in the array to 1. The other elements in the array must be set to zero. Three arrays are passed : The entries in readfds are checked to see if the following read operation will block. The entries in writefds are checked to see if the following write operation will block, while entries in exceptfds are checked to see if an exception occorred on them.
You can use the functions fpFD_ZERO, fpFD_Clr, fpFD_Set or fpFD_IsSet to manipulate the individual elements of a set.
The pointers can be Nil.
N is the value of the largest file descriptor in one of the sets, + 1. In other words, it is the position of the last bit which is set in the array of bits.
TimeOut can be used to set a time limit. If TimeOut can be two types :
When the TimeOut is reached, or one of the file descriptors has changed, the Select call returns. On return, it will have modified the entries in the array which have actually changed, and it returns the number of entries that have been changed. If the timout was reached, and no decsriptor changed, zero is returned; The arrays of indexes are undefined after that. On error, -1 is returned.
The variant with the text file will execute the FpSelect call on the file descriptor associated with the text file T
On error, the function returns -1. Extended error information can be retrieved using fpGetErrno.
|
Clear all file descriptors in set |
|
|
Clears a filedescriptor in a set |
|
|
Set a filedescriptor in a set |
|
|
Check whether a filedescriptor is set |
Program Example33; { Program to demonstrate the Select function. } Uses BaseUnix; Var FDS : Tfdset; begin fpfd_zero(FDS); fpfd_set(0,FDS); Writeln ('Press the <ENTER> to continue the program.'); { Wait until File descriptor 0 (=Input) changes } fpSelect (1,@FDS,nil,nil,nil); { Get rid of <ENTER> in buffer } readln; Writeln ('Press <ENTER> key in less than 2 seconds...'); Fpfd_zero(FDS); FpFd_set (0,FDS); if fpSelect (1,@FDS,nil,nil,2000)>0 then Writeln ('Thank you !') { FD_ISSET(0,FDS) would be true here. } else Writeln ('Too late !'); end.