fix name scope error in remove_descriptor (plus some ws/linelen fixes)
This commit is contained in:
@@ -29,7 +29,7 @@ class event_wrapper(object):
|
|||||||
if self.impl is not None:
|
if self.impl is not None:
|
||||||
self.impl.delete()
|
self.impl.delete()
|
||||||
self.impl = None
|
self.impl = None
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def pending(self):
|
def pending(self):
|
||||||
return bool(self.impl and self.impl.pending())
|
return bool(self.impl and self.impl.pending())
|
||||||
@@ -41,9 +41,11 @@ class Hub(BaseHub):
|
|||||||
def __init__(self):
|
def __init__(self):
|
||||||
super(Hub,self).__init__()
|
super(Hub,self).__init__()
|
||||||
event.init()
|
event.init()
|
||||||
|
|
||||||
self.signal_exc_info = None
|
self.signal_exc_info = None
|
||||||
self.signal(2, lambda signalnum, frame: self.greenlet.parent.throw(KeyboardInterrupt))
|
self.signal(
|
||||||
|
2,
|
||||||
|
lambda signalnum, frame: self.greenlet.parent.throw(KeyboardInterrupt))
|
||||||
self.events_to_add = []
|
self.events_to_add = []
|
||||||
|
|
||||||
def dispatch(self):
|
def dispatch(self):
|
||||||
@@ -76,7 +78,8 @@ class Hub(BaseHub):
|
|||||||
raise
|
raise
|
||||||
except:
|
except:
|
||||||
if self.signal_exc_info is not None:
|
if self.signal_exc_info is not None:
|
||||||
self.schedule_call_global(0, greenlet.getcurrent().parent.throw, *self.signal_exc_info)
|
self.schedule_call_global(
|
||||||
|
0, greenlet.getcurrent().parent.throw, *self.signal_exc_info)
|
||||||
self.signal_exc_info = None
|
self.signal_exc_info = None
|
||||||
else:
|
else:
|
||||||
self.squelch_timer_exception(None, sys.exc_info())
|
self.squelch_timer_exception(None, sys.exc_info())
|
||||||
@@ -86,25 +89,25 @@ class Hub(BaseHub):
|
|||||||
|
|
||||||
def _getrunning(self):
|
def _getrunning(self):
|
||||||
return bool(self.greenlet)
|
return bool(self.greenlet)
|
||||||
|
|
||||||
def _setrunning(self, value):
|
def _setrunning(self, value):
|
||||||
pass # exists for compatibility with BaseHub
|
pass # exists for compatibility with BaseHub
|
||||||
running = property(_getrunning, _setrunning)
|
running = property(_getrunning, _setrunning)
|
||||||
|
|
||||||
def add(self, evtype, fileno, real_cb):
|
def add(self, evtype, fileno, real_cb):
|
||||||
# this is stupid: pyevent won't call a callback unless it's a function,
|
# this is stupid: pyevent won't call a callback unless it's a function,
|
||||||
# so we have to force it to be one here
|
# so we have to force it to be one here
|
||||||
if isinstance(real_cb, types.BuiltinMethodType):
|
if isinstance(real_cb, types.BuiltinMethodType):
|
||||||
def cb(_d):
|
def cb(_d):
|
||||||
real_cb(_d)
|
real_cb(_d)
|
||||||
else:
|
else:
|
||||||
cb = real_cb
|
cb = real_cb
|
||||||
|
|
||||||
if evtype is READ:
|
if evtype is READ:
|
||||||
evt = event.read(fileno, cb, fileno)
|
evt = event.read(fileno, cb, fileno)
|
||||||
elif evtype is WRITE:
|
elif evtype is WRITE:
|
||||||
evt = event.write(fileno, cb, fileno)
|
evt = event.write(fileno, cb, fileno)
|
||||||
|
|
||||||
listener = FdListener(evtype, fileno, evt)
|
listener = FdListener(evtype, fileno, evt)
|
||||||
self.listeners[evtype].setdefault(fileno, []).append(listener)
|
self.listeners[evtype].setdefault(fileno, []).append(listener)
|
||||||
return listener
|
return listener
|
||||||
@@ -117,22 +120,22 @@ class Hub(BaseHub):
|
|||||||
self.signal_exc_info = sys.exc_info()
|
self.signal_exc_info = sys.exc_info()
|
||||||
event.abort()
|
event.abort()
|
||||||
return event_wrapper(event.signal(signalnum, wrapper))
|
return event_wrapper(event.signal(signalnum, wrapper))
|
||||||
|
|
||||||
def remove(self, listener):
|
def remove(self, listener):
|
||||||
super(Hub, self).remove(listener)
|
super(Hub, self).remove(listener)
|
||||||
listener.cb.delete()
|
listener.cb.delete()
|
||||||
|
|
||||||
def remove_descriptor(self, fileno):
|
def remove_descriptor(self, fileno):
|
||||||
for lcontainer in self.listeners.itervalues():
|
for lcontainer in self.listeners.itervalues():
|
||||||
l_list = lcontainer.pop(fileno, None)
|
l_list = lcontainer.pop(fileno, None)
|
||||||
for listener in l_list:
|
for listener in l_list:
|
||||||
try:
|
try:
|
||||||
listener.cb.delete()
|
listener.cb.delete()
|
||||||
except SYSTEM_EXCEPTIONS:
|
except self.SYSTEM_EXCEPTIONS:
|
||||||
raise
|
raise
|
||||||
except:
|
except:
|
||||||
traceback.print_exc()
|
traceback.print_exc()
|
||||||
|
|
||||||
def schedule_call_local(self, seconds, cb, *args, **kwargs):
|
def schedule_call_local(self, seconds, cb, *args, **kwargs):
|
||||||
current = greenlet.getcurrent()
|
current = greenlet.getcurrent()
|
||||||
if current is self.greenlet:
|
if current is self.greenlet:
|
||||||
@@ -149,7 +152,7 @@ class Hub(BaseHub):
|
|||||||
wrapper = event_wrapper(event_impl, seconds=seconds)
|
wrapper = event_wrapper(event_impl, seconds=seconds)
|
||||||
self.events_to_add.append(wrapper)
|
self.events_to_add.append(wrapper)
|
||||||
return wrapper
|
return wrapper
|
||||||
|
|
||||||
def _version_info(self):
|
def _version_info(self):
|
||||||
baseversion = event.__version__
|
baseversion = event.__version__
|
||||||
return baseversion
|
return baseversion
|
||||||
@@ -169,4 +172,3 @@ def _scheduled_call_local(event_impl, handle, evtype, arg):
|
|||||||
cb(*args, **kwargs)
|
cb(*args, **kwargs)
|
||||||
finally:
|
finally:
|
||||||
event_impl.delete()
|
event_impl.delete()
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user