diff options
author | Dan Klein <danklei@cisco.com> | 2015-08-24 09:28:43 +0300 |
---|---|---|
committer | Dan Klein <danklei@cisco.com> | 2015-08-24 09:28:43 +0300 |
commit | 20eb7d362f9bce1951bd61ad3f78cf8f4267d1d5 (patch) | |
tree | b2c3fe1c721d5f6898b4bb8e81f7c68502e313e9 /src/console/zmq/green/eventloop/ioloop.py | |
parent | 49f6b00b58c3ec734218fcd69259771a42c157bd (diff) | |
parent | 651a7d779551e193bd9dbadbe8b2a02bdab231b4 (diff) |
Merge branch 'master' into dan_stateless
Diffstat (limited to 'src/console/zmq/green/eventloop/ioloop.py')
-rwxr-xr-x | src/console/zmq/green/eventloop/ioloop.py | 33 |
1 files changed, 33 insertions, 0 deletions
diff --git a/src/console/zmq/green/eventloop/ioloop.py b/src/console/zmq/green/eventloop/ioloop.py new file mode 100755 index 00000000..e12fd5e9 --- /dev/null +++ b/src/console/zmq/green/eventloop/ioloop.py @@ -0,0 +1,33 @@ +from zmq.eventloop.ioloop import * +from zmq.green import Poller + +RealIOLoop = IOLoop +RealZMQPoller = ZMQPoller + +class IOLoop(RealIOLoop): + + def initialize(self, impl=None): + impl = _poll() if impl is None else impl + super(IOLoop, self).initialize(impl) + + @staticmethod + def instance(): + """Returns a global `IOLoop` instance. + + Most applications have a single, global `IOLoop` running on the + main thread. Use this method to get this instance from + another thread. To get the current thread's `IOLoop`, use `current()`. + """ + # install this class as the active IOLoop implementation + # when using tornado 3 + if tornado_version >= (3,): + PollIOLoop.configure(IOLoop) + return PollIOLoop.instance() + + +class ZMQPoller(RealZMQPoller): + """gevent-compatible version of ioloop.ZMQPoller""" + def __init__(self): + self._poller = Poller() + +_poll = ZMQPoller |