38 lines
1.0 KiB
Python
38 lines
1.0 KiB
Python
"""pure Python monitored_queue function
|
|
|
|
For use when Cython extension is unavailable (PyPy).
|
|
|
|
Authors
|
|
-------
|
|
* MinRK
|
|
"""
|
|
|
|
# Copyright (C) PyZMQ Developers
|
|
# Distributed under the terms of the Modified BSD License.
|
|
|
|
import zmq
|
|
|
|
def _relay(ins, outs, sides, prefix, swap_ids):
|
|
msg = ins.recv_multipart()
|
|
if swap_ids:
|
|
msg[:2] = msg[:2][::-1]
|
|
outs.send_multipart(msg)
|
|
sides.send_multipart([prefix] + msg)
|
|
|
|
def monitored_queue(in_socket, out_socket, mon_socket,
|
|
in_prefix=b'in', out_prefix=b'out'):
|
|
|
|
swap_ids = in_socket.type == zmq.ROUTER and out_socket.type == zmq.ROUTER
|
|
|
|
poller = zmq.Poller()
|
|
poller.register(in_socket, zmq.POLLIN)
|
|
poller.register(out_socket, zmq.POLLIN)
|
|
while True:
|
|
events = dict(poller.poll())
|
|
if in_socket in events:
|
|
_relay(in_socket, out_socket, mon_socket, in_prefix, swap_ids)
|
|
if out_socket in events:
|
|
_relay(out_socket, in_socket, mon_socket, out_prefix, swap_ids)
|
|
|
|
__all__ = ['monitored_queue']
|