mirror of
https://github.com/python/cpython.git
synced 2025-10-29 20:51:26 +00:00
SF bug [#410708] Condition.wait() and KeyboardInterrupt.
http://sourceforge.net/tracker/?func=detail&aid=410708&group_id=5470&atid=105470 Added try/finally around Condition.wait() guts, so that the lock state gets restored at the end no matter what happens.
This commit is contained in:
parent
f5bd684337
commit
c951bf9128
1 changed files with 25 additions and 23 deletions
|
|
@ -185,31 +185,33 @@ def wait(self, timeout=None):
|
||||||
waiter.acquire()
|
waiter.acquire()
|
||||||
self.__waiters.append(waiter)
|
self.__waiters.append(waiter)
|
||||||
saved_state = self._release_save()
|
saved_state = self._release_save()
|
||||||
if timeout is None:
|
try: # restore state no matter what (e.g., KeyboardInterrupt)
|
||||||
waiter.acquire()
|
if timeout is None:
|
||||||
if __debug__:
|
waiter.acquire()
|
||||||
self._note("%s.wait(): got it", self)
|
|
||||||
else:
|
|
||||||
endtime = _time() + timeout
|
|
||||||
delay = 0.000001 # 1 usec
|
|
||||||
while 1:
|
|
||||||
gotit = waiter.acquire(0)
|
|
||||||
if gotit or _time() >= endtime:
|
|
||||||
break
|
|
||||||
_sleep(delay)
|
|
||||||
if delay < 1.0:
|
|
||||||
delay = delay * 2.0
|
|
||||||
if not gotit:
|
|
||||||
if __debug__:
|
if __debug__:
|
||||||
self._note("%s.wait(%s): timed out", self, timeout)
|
self._note("%s.wait(): got it", self)
|
||||||
try:
|
|
||||||
self.__waiters.remove(waiter)
|
|
||||||
except ValueError:
|
|
||||||
pass
|
|
||||||
else:
|
else:
|
||||||
if __debug__:
|
endtime = _time() + timeout
|
||||||
self._note("%s.wait(%s): got it", self, timeout)
|
delay = 0.000001 # 1 usec
|
||||||
self._acquire_restore(saved_state)
|
while 1:
|
||||||
|
gotit = waiter.acquire(0)
|
||||||
|
if gotit or _time() >= endtime:
|
||||||
|
break
|
||||||
|
_sleep(delay)
|
||||||
|
if delay < 1.0:
|
||||||
|
delay = delay * 2.0
|
||||||
|
if not gotit:
|
||||||
|
if __debug__:
|
||||||
|
self._note("%s.wait(%s): timed out", self, timeout)
|
||||||
|
try:
|
||||||
|
self.__waiters.remove(waiter)
|
||||||
|
except ValueError:
|
||||||
|
pass
|
||||||
|
else:
|
||||||
|
if __debug__:
|
||||||
|
self._note("%s.wait(%s): got it", self, timeout)
|
||||||
|
finally:
|
||||||
|
self._acquire_restore(saved_state)
|
||||||
|
|
||||||
def notify(self, n=1):
|
def notify(self, n=1):
|
||||||
me = currentThread()
|
me = currentThread()
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue