fix race condition with the concurrent decorator

This commit is contained in:
Maximilian Hils 2014-09-06 12:39:23 +02:00
parent 32e1ed212d
commit ccb6182917
1 changed files with 19 additions and 6 deletions

View File

@ -108,15 +108,28 @@ class Script:
return (False, None) return (False, None)
class ReplyProxy(object):
def __init__(self, original_reply):
self._ignore_calls = 1
self.lock = threading.Lock()
self.original_reply = original_reply
def __call__(self, *args, **kwargs):
with self.lock:
if self._ignore_calls > 0:
self._ignore_calls -= 1
return
self.original_reply(*args, **kwargs)
def __getattr__ (self, k):
return getattr(self.original_reply, k)
def _handle_concurrent_reply(fn, o, *args, **kwargs): def _handle_concurrent_reply(fn, o, *args, **kwargs):
# Make first call to o.reply a no op # Make first call to o.reply a no op
original_reply = o.reply
def restore_original_reply(): reply_proxy = ReplyProxy(o.reply)
o.reply = original_reply o.reply = reply_proxy
if hasattr(original_reply, "q"):
restore_original_reply.q = original_reply.q
o.reply = restore_original_reply
def run(): def run():
fn(*args, **kwargs) fn(*args, **kwargs)