cpython/Doc/lib/libselect.tex

56 lines
2.5 KiB
TeX
Raw Normal View History

\section{\module{select} ---
1999-02-19 20:14:17 -04:00
Waiting for I/O completion}
1999-02-19 20:14:17 -04:00
\declaremodule{builtin}{select}
\modulesynopsis{Wait for I/O completion on multiple streams.}
1994-01-01 21:22:07 -04:00
1998-04-02 14:44:38 -04:00
This module provides access to the function \cfunction{select()}
available in most operating systems. Note that on Windows, it only
works for sockets; on other operating systems, it also works for other
file types (in particular, on \UNIX{}, it works on pipes). It cannot
be used or regular files to determine whether a file has grown since
it was last read.
The module defines the following:
1994-01-01 21:22:07 -04:00
\begin{excdesc}{error}
The exception raised when an error occurs. The accompanying value is
1998-04-02 14:44:38 -04:00
a pair containing the numeric error code from \cdata{errno} and the
corresponding string, as would be printed by the \C{} function
\cfunction{perror()}.
1994-01-01 21:22:07 -04:00
\end{excdesc}
\begin{funcdesc}{select}{iwtd, owtd, ewtd\optional{, timeout}}
1998-04-02 14:44:38 -04:00
This is a straightforward interface to the \UNIX{} \cfunction{select()}
1994-01-01 21:22:07 -04:00
system call. The first three arguments are lists of `waitable
objects': either integers representing \UNIX{} file descriptors or
1998-04-02 14:44:38 -04:00
objects with a parameterless method named \method{fileno()} returning
1994-01-01 21:22:07 -04:00
such an integer. The three lists of waitable objects are for input,
output and `exceptional conditions', respectively. Empty lists are
1995-04-04 09:29:37 -03:00
allowed. The optional \var{timeout} argument specifies a time-out as a
1994-01-01 21:22:07 -04:00
floating point number in seconds. When the \var{timeout} argument
is omitted the function blocks until at least one file descriptor is
ready. A time-out value of zero specifies a poll and never blocks.
The return value is a triple of lists of objects that are ready:
subsets of the first three arguments. When the time-out is reached
without a file descriptor becoming ready, three empty lists are
returned.
Amongst the acceptable object types in the lists are Python file
1998-04-02 14:44:38 -04:00
objects (e.g. \code{sys.stdin}, or objects returned by
\function{open()} or \function{os.popen()}), socket objects
returned by \function{socket.socket()},%
\withsubitem{(in module socket)}{\ttindex{socket()}}
\withsubitem{(in module posix)}{\ttindex{popen()}}
\withsubitem{(in module os)}{\ttindex{popen()}}
and the module \module{stdwin}\refbimodindex{stdwin} which happens to
define a function \function{fileno()}%
\withsubitem{(in module stdwin)}{\ttindex{fileno()}}
for just this purpose. You may
1994-01-01 21:22:07 -04:00
also define a \dfn{wrapper} class yourself, as long as it has an
1998-04-02 14:44:38 -04:00
appropriate \method{fileno()} method (that really returns a \UNIX{}
file descriptor, not just a random integer).
1994-01-01 21:22:07 -04:00
\end{funcdesc}