diff options
author | Serhiy Storchaka <storchaka@gmail.com> | 2013-04-22 19:51:43 (GMT) |
---|---|---|
committer | Serhiy Storchaka <storchaka@gmail.com> | 2013-04-22 19:51:43 (GMT) |
commit | 81a5855a2739797a9a41e03acecf9746baa3e882 (patch) | |
tree | fc5d3e9692e9924c580501773827ef2d30f56786 /Lib | |
parent | d4cb4b74517922a4594b252edadb35222e81e47d (diff) | |
download | cpython-81a5855a2739797a9a41e03acecf9746baa3e882.zip cpython-81a5855a2739797a9a41e03acecf9746baa3e882.tar.gz cpython-81a5855a2739797a9a41e03acecf9746baa3e882.tar.bz2 |
Issue #11714: Use 'with' statements to assure a Semaphore releases a
condition variable. Original patch by Thomas Rachel.
Diffstat (limited to 'Lib')
-rw-r--r-- | Lib/threading.py | 38 |
1 files changed, 18 insertions, 20 deletions
diff --git a/Lib/threading.py b/Lib/threading.py index 46df676..ab9302c 100644 --- a/Lib/threading.py +++ b/Lib/threading.py @@ -248,31 +248,29 @@ class Semaphore: raise ValueError("can't specify timeout for non-blocking acquire") rc = False endtime = None - self._cond.acquire() - while self._value == 0: - if not blocking: - break - if timeout is not None: - if endtime is None: - endtime = _time() + timeout - else: - timeout = endtime - _time() - if timeout <= 0: - break - self._cond.wait(timeout) - else: - self._value = self._value - 1 - rc = True - self._cond.release() + with self._cond: + while self._value == 0: + if not blocking: + break + if timeout is not None: + if endtime is None: + endtime = _time() + timeout + else: + timeout = endtime - _time() + if timeout <= 0: + break + self._cond.wait(timeout) + else: + self._value = self._value - 1 + rc = True return rc __enter__ = acquire def release(self): - self._cond.acquire() - self._value = self._value + 1 - self._cond.notify() - self._cond.release() + with self._cond: + self._value = self._value + 1 + self._cond.notify() def __exit__(self, t, v, tb): self.release() |