comparison CSP2/CSP2_env/env-d9b9114564458d9d-741b3de822f2aaca6c6caa4325c4afce/lib/python3.8/multiprocessing/dummy/connection.py @ 69:33d812a61356

planemo upload commit 2e9511a184a1ca667c7be0c6321a36dc4e3d116d
author jpayne
date Tue, 18 Mar 2025 17:55:14 -0400
parents
children
comparison
equal deleted inserted replaced
67:0e9998148a16 69:33d812a61356
1 #
2 # Analogue of `multiprocessing.connection` which uses queues instead of sockets
3 #
4 # multiprocessing/dummy/connection.py
5 #
6 # Copyright (c) 2006-2008, R Oudkerk
7 # Licensed to PSF under a Contributor Agreement.
8 #
9
10 __all__ = [ 'Client', 'Listener', 'Pipe' ]
11
12 from queue import Queue
13
14
15 families = [None]
16
17
18 class Listener(object):
19
20 def __init__(self, address=None, family=None, backlog=1):
21 self._backlog_queue = Queue(backlog)
22
23 def accept(self):
24 return Connection(*self._backlog_queue.get())
25
26 def close(self):
27 self._backlog_queue = None
28
29 @property
30 def address(self):
31 return self._backlog_queue
32
33 def __enter__(self):
34 return self
35
36 def __exit__(self, exc_type, exc_value, exc_tb):
37 self.close()
38
39
40 def Client(address):
41 _in, _out = Queue(), Queue()
42 address.put((_out, _in))
43 return Connection(_in, _out)
44
45
46 def Pipe(duplex=True):
47 a, b = Queue(), Queue()
48 return Connection(a, b), Connection(b, a)
49
50
51 class Connection(object):
52
53 def __init__(self, _in, _out):
54 self._out = _out
55 self._in = _in
56 self.send = self.send_bytes = _out.put
57 self.recv = self.recv_bytes = _in.get
58
59 def poll(self, timeout=0.0):
60 if self._in.qsize() > 0:
61 return True
62 if timeout <= 0.0:
63 return False
64 with self._in.not_empty:
65 self._in.not_empty.wait(timeout)
66 return self._in.qsize() > 0
67
68 def close(self):
69 pass
70
71 def __enter__(self):
72 return self
73
74 def __exit__(self, exc_type, exc_value, exc_tb):
75 self.close()