summaryrefslogtreecommitdiffstats
path: root/Lib/multiprocessing/connection.py
diff options
context:
space:
mode:
authorBenjamin Peterson <benjamin@python.org>2013-01-01 03:40:42 (GMT)
committerBenjamin Peterson <benjamin@python.org>2013-01-01 03:40:42 (GMT)
commit1f7df8f2070391f28391e3594580c07e11b6b32b (patch)
treeec03dfe4f71df3840232731145b8f6736fc6a314 /Lib/multiprocessing/connection.py
parentb25d611f8d9140e83acbfffb6b0579939c88c033 (diff)
parent10e93a6d40502e100c68090730e0b3190df97854 (diff)
downloadcpython-1f7df8f2070391f28391e3594580c07e11b6b32b.zip
cpython-1f7df8f2070391f28391e3594580c07e11b6b32b.tar.gz
cpython-1f7df8f2070391f28391e3594580c07e11b6b32b.tar.bz2
merge heads
Diffstat (limited to 'Lib/multiprocessing/connection.py')
-rw-r--r--Lib/multiprocessing/connection.py21
1 files changed, 21 insertions, 0 deletions
diff --git a/Lib/multiprocessing/connection.py b/Lib/multiprocessing/connection.py
index 4421ac5..6c398fd 100644
--- a/Lib/multiprocessing/connection.py
+++ b/Lib/multiprocessing/connection.py
@@ -200,6 +200,27 @@ if sys.platform != 'win32':
return c1, c2
else:
+ if hasattr(select, 'poll'):
+ def _poll(fds, timeout):
+ if timeout is not None:
+ timeout = int(timeout) * 1000 # timeout is in milliseconds
+ fd_map = {}
+ pollster = select.poll()
+ for fd in fds:
+ pollster.register(fd, select.POLLIN)
+ if hasattr(fd, 'fileno'):
+ fd_map[fd.fileno()] = fd
+ else:
+ fd_map[fd] = fd
+ ls = []
+ for fd, event in pollster.poll(timeout):
+ if event & select.POLLNVAL:
+ raise ValueError('invalid file descriptor %i' % fd)
+ ls.append(fd_map[fd])
+ return ls
+ else:
+ def _poll(fds, timeout):
+ return select.select(fds, [], [], timeout)[0]
from _multiprocessing import win32