Commit 2c7a85f3 authored by Jeremy Hylton's avatar Jeremy Hylton

Add pending() method to Connection.

parent fdd1d394
...@@ -12,6 +12,7 @@ ...@@ -12,6 +12,7 @@
# #
############################################################################## ##############################################################################
import asyncore import asyncore
import errno
import select import select
import sys import sys
import threading import threading
...@@ -331,6 +332,7 @@ class Connection(smac.SizedMessageAsyncConnection): ...@@ -331,6 +332,7 @@ class Connection(smac.SizedMessageAsyncConnection):
self.thr_async = 1 self.thr_async = 1
def is_async(self): def is_async(self):
# overridden for ManagedConnection
if self.thr_async: if self.thr_async:
return 1 return 1
else: else:
...@@ -367,6 +369,36 @@ class Connection(smac.SizedMessageAsyncConnection): ...@@ -367,6 +369,36 @@ class Connection(smac.SizedMessageAsyncConnection):
else: else:
asyncore.poll(0.0, self._map) asyncore.poll(0.0, self._map)
def pending(self):
"""Invoke mainloop until any pending messages are handled."""
if __debug__:
log("pending(), async=%d" % self.is_async(), level=zLOG.TRACE)
if self.is_async():
return
# Inline the asyncore poll3 function to know whether any input
# was actually read. Repeat until know input is ready.
# XXX This only does reads.
poll = select.poll()
poll.register(self._fileno, select.POLLIN)
# put dummy value in r so we enter the while loop the first time
r = [(self._fileno, None)]
while r:
try:
r = poll.poll()
except select.error, err:
if err[0] == errno.EINTR:
continue
else:
raise
if r:
try:
self.handle_read_event()
except asyncore.ExitNow:
raise
else:
self.handle_error()
class ServerConnection(Connection): class ServerConnection(Connection):
"""Connection on the server side""" """Connection on the server side"""
...@@ -423,6 +455,7 @@ class ManagedConnection(Connection): ...@@ -423,6 +455,7 @@ class ManagedConnection(Connection):
return 0 return 0
def is_async(self): def is_async(self):
# XXX could the check_mgr_async() be avoided on each test?
if self.thr_async: if self.thr_async:
return 1 return 1
return self.check_mgr_async() return self.check_mgr_async()
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment