blob: 44398aa580b1f6ac45444b383946d3dbdd2b1d85 [file] [log] [blame]
Fred Drake295da241998-08-10 19:42:37 +00001\section{\module{select} ---
Fred Drakebbac4321999-02-20 00:14:17 +00002 Waiting for I/O completion}
Fred Drakeb91e9341998-07-23 17:59:49 +00003
Fred Drakebbac4321999-02-20 00:14:17 +00004\declaremodule{builtin}{select}
Fred Drakeb91e9341998-07-23 17:59:49 +00005\modulesynopsis{Wait for I/O completion on multiple streams.}
6
Guido van Rossum5fdeeea1994-01-02 01:22:07 +00007
Andrew M. Kuchling99a37012000-08-25 01:21:28 +00008This module provides access to the \cfunction{select()}
9and \cfunction{poll()} functions
Guido van Rossum9814a941998-09-28 14:28:38 +000010available in most operating systems. Note that on Windows, it only
11works for sockets; on other operating systems, it also works for other
12file types (in particular, on \UNIX{}, it works on pipes). It cannot
Fred Drake38e5d272000-04-03 20:13:55 +000013be used on regular files to determine whether a file has grown since
Guido van Rossum9814a941998-09-28 14:28:38 +000014it was last read.
15
16The module defines the following:
Guido van Rossum5fdeeea1994-01-02 01:22:07 +000017
Guido van Rossum5fdeeea1994-01-02 01:22:07 +000018\begin{excdesc}{error}
19The exception raised when an error occurs. The accompanying value is
Fred Drakeb4016371998-04-02 18:44:38 +000020a pair containing the numeric error code from \cdata{errno} and the
21corresponding string, as would be printed by the \C{} function
22\cfunction{perror()}.
Guido van Rossum5fdeeea1994-01-02 01:22:07 +000023\end{excdesc}
24
Andrew M. Kuchling99a37012000-08-25 01:21:28 +000025\begin{funcdesc}{poll}{}
26(Not supported by all operating systems.) Returns a polling object,
27which supports registering and unregistering file descriptors, and
28then polling them for I/O events;
29see section~\ref{poll-objects} below for the methods supported by
30polling objects.
31\end{funcdesc}
32
Fred Drakecce10901998-03-17 06:33:25 +000033\begin{funcdesc}{select}{iwtd, owtd, ewtd\optional{, timeout}}
Fred Drakeb4016371998-04-02 18:44:38 +000034This is a straightforward interface to the \UNIX{} \cfunction{select()}
Guido van Rossum5fdeeea1994-01-02 01:22:07 +000035system call. The first three arguments are lists of `waitable
36objects': either integers representing \UNIX{} file descriptors or
Fred Drakeb4016371998-04-02 18:44:38 +000037objects with a parameterless method named \method{fileno()} returning
Guido van Rossum5fdeeea1994-01-02 01:22:07 +000038such an integer. The three lists of waitable objects are for input,
39output and `exceptional conditions', respectively. Empty lists are
Guido van Rossum02ee80d1995-04-04 12:29:37 +000040allowed. The optional \var{timeout} argument specifies a time-out as a
Guido van Rossum5fdeeea1994-01-02 01:22:07 +000041floating point number in seconds. When the \var{timeout} argument
42is omitted the function blocks until at least one file descriptor is
43ready. A time-out value of zero specifies a poll and never blocks.
44
45The return value is a triple of lists of objects that are ready:
46subsets of the first three arguments. When the time-out is reached
47without a file descriptor becoming ready, three empty lists are
48returned.
49
50Amongst the acceptable object types in the lists are Python file
Fred Drakeb4016371998-04-02 18:44:38 +000051objects (e.g. \code{sys.stdin}, or objects returned by
52\function{open()} or \function{os.popen()}), socket objects
53returned by \function{socket.socket()},%
54\withsubitem{(in module socket)}{\ttindex{socket()}}
Fred Drakeb4016371998-04-02 18:44:38 +000055\withsubitem{(in module os)}{\ttindex{popen()}}
56and the module \module{stdwin}\refbimodindex{stdwin} which happens to
Fred Drake283c5881999-04-21 17:57:15 +000057define a function
58\function{fileno()}\withsubitem{(in module stdwin)}{\ttindex{fileno()}}
Fred Drakeb4016371998-04-02 18:44:38 +000059for just this purpose. You may
Guido van Rossum5fdeeea1994-01-02 01:22:07 +000060also define a \dfn{wrapper} class yourself, as long as it has an
Fred Drakeb4016371998-04-02 18:44:38 +000061appropriate \method{fileno()} method (that really returns a \UNIX{}
62file descriptor, not just a random integer).
Guido van Rossum5fdeeea1994-01-02 01:22:07 +000063\end{funcdesc}
Andrew M. Kuchling99a37012000-08-25 01:21:28 +000064
65\subsection{Polling Objects
66 \label{poll-objects}}
67
68The \cfunction{poll()} system call, supported on most Unix systems,
69provides better scalability for network servers that service many,
70many clients at the same time.
71\cfunction{poll()} scales better because the system call only
72requires listing the file descriptors of interest, while \cfunction{select()}
73builds a bitmap, turns on bits for the fds of interest, and then
74afterward the whole bitmap has to be linearly scanned again.
75\cfunction{select()} is O(highest file descriptor), while
76\cfunction{poll()} is O(number of file descriptors).
77
78\begin{methoddesc}{register}{fd\optional{, eventmask}}
79Register a file descriptor with the polling object. Future calls to
80the \method{poll()} method will then check whether the file descriptor
81has any pending I/O events. \var{fd} can be either an integer, or an
82object with a \method{fileno()} method that returns an integer. File
83objects implement
84\method{fileno()}, so they can also be used as the argument.
85
86\var{eventmask} is an optional bitmask describing the type of events you
87want to check for, and can be a combination of the constants
88\constant{POLLIN}, \constant{POLLPRI}, and \constant{POLLOUT},
89described in the table below. If not specified, the default value
90used will check for all 3 types of events.
91
92\begin{tableii}{l|l}{code}{Constant}{Meaning}
93 \lineii{POLLIN}{There is data to read}
94 \lineii{POLLPRI}{There is urgent data to read}
95 \lineii{POLLOUT}{Ready for output: writing will not block}
96 \lineii{POLLERR}{Error condition of some sort}
97 \lineii{POLLHUP}{Hung up}
98 \lineii{POLLNVAL}{Invalid request: descriptor not open}
99\end{tableii}
100
101Registering a file descriptor that's already registered is not an
102error, and has the same effect as registering the descriptor exactly
103once.
104
105\end{methoddesc}
106
107\begin{methoddesc}{unregister}{fd}
108Remove a file descriptor being tracked by a polling object. Just like
109the \method{register()} method, \var{fd} can be an integer or an
110object with a \method{fileno()} method that returns an integer.
111
112Attempting to remove a file descriptor that was never registered
113causes a \exception{KeyError} exception to be raised.
114\end{methoddesc}
115
116\begin{methoddesc}{poll}{\optional{timeout}}
117Polls the set of registered file descriptors, and returns a
118possibly-empty list containing \code{(\var{fd}, \var{event})} 2-tuples
119for the descriptors that have events or errors to report.
120\var{fd} is the file descriptor, and \var{event} is a bitmask
121with bits set for the reported events for that descriptor
122--- \constant{POLLIN} for waiting input,
123\constant{POLLOUT} to indicate that the descriptor can be written to, and
124so forth.
125An empty list indicates that the call timed out and no file
126descriptors had any events to report.
127\end{methoddesc}
128
129