issue #156: don't decrement `waking` if we timed out rather than being woken.

This commit is contained in:
David Wilson 2018-03-20 13:01:26 +05:45
parent 07a8994ff5
commit 2c22c41819
2 changed files with 4 additions and 4 deletions

View File

@ -925,9 +925,9 @@ item.
:py:meth:`mitogen.core.Latch.put`.
**4. Wake, Non-empty**
On wake it re-acquires `lock`, removes itself from `sleeping`, decrementing
`waking`, throws :py:class:`mitogen.core.TimeoutError` if no byte was
written, otherwise pops and returns the first item in `queue` that is
On wake it re-acquires `lock`, removes itself from `sleeping`, throws
:py:class:`mitogen.core.TimeoutError` if no byte was written, decrements
`waking`, then pops and returns the first item in `queue` that is
guaranteed to exist.

View File

@ -957,11 +957,11 @@ class Latch(object):
self._lock.acquire()
try:
self._sleeping.remove(_tls.wsock)
self._waking -= 1
if self.closed:
raise LatchError()
if not rfds:
raise TimeoutError()
self._waking -= 1
if _tls.rsock.recv(2) != '\x7f':
raise LatchError('internal error: received >1 wakeups')
try: