summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorVictor Stinner <victor.stinner@gmail.com>2015-01-09 00:59:11 +0100
committerVictor Stinner <victor.stinner@gmail.com>2015-01-09 00:59:11 +0100
commit4017697430eb5ae36d275be8f6ad64107404b13c (patch)
tree02e4955d477867c60063926781b6060d4379f1f8
parentdb86ad7a5b953309a66fd78d022cd08de74fff16 (diff)
downloadtrollius-4017697430eb5ae36d275be8f6ad64107404b13c.tar.gz
Document why set_result() calls are safe
-rw-r--r--asyncio/queues.py6
1 files changed, 6 insertions, 0 deletions
diff --git a/asyncio/queues.py b/asyncio/queues.py
index 8f6c257..dce0d53 100644
--- a/asyncio/queues.py
+++ b/asyncio/queues.py
@@ -126,6 +126,8 @@ class Queue:
# Use _put and _get instead of passing item straight to getter, in
# case a subclass has logic that must run (e.g. JoinableQueue).
self._put(item)
+
+ # getter cannot be cancelled, we just removed done getters
getter.set_result(self._get())
elif self._maxsize > 0 and self._maxsize <= self.qsize():
@@ -152,6 +154,8 @@ class Queue:
# Use _put and _get instead of passing item straight to getter, in
# case a subclass has logic that must run (e.g. JoinableQueue).
self._put(item)
+
+ # getter cannot be cancelled, we just removed done getters
getter.set_result(self._get())
elif self._maxsize > 0 and self._maxsize <= self.qsize():
@@ -200,6 +204,8 @@ class Queue:
item, putter = self._putters.popleft()
self._put(item)
# Wake putter on next tick.
+
+ # getter cannot be cancelled, we just removed done putters
putter.set_result(None)
return self._get()