mirror of
				https://github.com/python/cpython.git
				synced 2025-10-25 18:54:53 +00:00 
			
		
		
		
	bpo-32193: Convert asyncio to async/await usage (#4753)
* Convert asyncio/tasks.py to async/await * Convert asyncio/queues.py to async/await * Convert asyncio/test_utils.py to async/await * Convert asyncio/base_subprocess.py to async/await * Convert asyncio/subprocess.py to async/await * Convert asyncio/streams.py to async/await * Fix comments * Convert asyncio/locks.py to async/await * Convert asyncio.sleep to async def * Add a comment * Add missing news * Convert stubs from AbstrctEventLoop to async functions * Convert subprocess_shell/subprocess_exec * Convert connect_read_pipe/connect_write_pip to async/await syntax * Convert create_datagram_endpoint * Convert create_unix_server/create_unix_connection * Get rid of old style coroutines in unix_events.py * Convert selector_events.py to async/await * Convert wait_closed and create_connection * Drop redundant line * Convert base_events.py * Code cleanup * Drop redundant comments * Fix indentation * Add explicit tests for compatibility between old and new coroutines * Convert windows event loop to use async/await * Fix double awaiting of async function * Convert asyncio/locks.py * Improve docstring * Convert tests to async/await * Convert more tests * Convert more tests * Convert more tests * Convert tests * Improve test
This commit is contained in:
		
							parent
							
								
									ede157331b
								
							
						
					
					
						commit
						5f841b5538
					
				
					 22 changed files with 647 additions and 771 deletions
				
			
		|  | @ -7,7 +7,6 @@ | |||
| 
 | ||||
| from . import events | ||||
| from . import locks | ||||
| from .coroutines import coroutine | ||||
| 
 | ||||
| 
 | ||||
| class QueueEmpty(Exception): | ||||
|  | @ -28,7 +27,7 @@ class Queue: | |||
|     """A queue, useful for coordinating producer and consumer coroutines. | ||||
| 
 | ||||
|     If maxsize is less than or equal to zero, the queue size is infinite. If it | ||||
|     is an integer greater than 0, then "yield from put()" will block when the | ||||
|     is an integer greater than 0, then "await put()" will block when the | ||||
|     queue reaches maxsize, until an item is removed by get(). | ||||
| 
 | ||||
|     Unlike the standard library Queue, you can reliably know this Queue's size | ||||
|  | @ -116,20 +115,17 @@ def full(self): | |||
|         else: | ||||
|             return self.qsize() >= self._maxsize | ||||
| 
 | ||||
|     @coroutine | ||||
|     def put(self, item): | ||||
|     async def put(self, item): | ||||
|         """Put an item into the queue. | ||||
| 
 | ||||
|         Put an item into the queue. If the queue is full, wait until a free | ||||
|         slot is available before adding item. | ||||
| 
 | ||||
|         This method is a coroutine. | ||||
|         """ | ||||
|         while self.full(): | ||||
|             putter = self._loop.create_future() | ||||
|             self._putters.append(putter) | ||||
|             try: | ||||
|                 yield from putter | ||||
|                 await putter | ||||
|             except: | ||||
|                 putter.cancel()  # Just in case putter is not done yet. | ||||
|                 if not self.full() and not putter.cancelled(): | ||||
|  | @ -151,19 +147,16 @@ def put_nowait(self, item): | |||
|         self._finished.clear() | ||||
|         self._wakeup_next(self._getters) | ||||
| 
 | ||||
|     @coroutine | ||||
|     def get(self): | ||||
|     async def get(self): | ||||
|         """Remove and return an item from the queue. | ||||
| 
 | ||||
|         If queue is empty, wait until an item is available. | ||||
| 
 | ||||
|         This method is a coroutine. | ||||
|         """ | ||||
|         while self.empty(): | ||||
|             getter = self._loop.create_future() | ||||
|             self._getters.append(getter) | ||||
|             try: | ||||
|                 yield from getter | ||||
|                 await getter | ||||
|             except: | ||||
|                 getter.cancel()  # Just in case getter is not done yet. | ||||
| 
 | ||||
|  | @ -210,8 +203,7 @@ def task_done(self): | |||
|         if self._unfinished_tasks == 0: | ||||
|             self._finished.set() | ||||
| 
 | ||||
|     @coroutine | ||||
|     def join(self): | ||||
|     async def join(self): | ||||
|         """Block until all items in the queue have been gotten and processed. | ||||
| 
 | ||||
|         The count of unfinished tasks goes up whenever an item is added to the | ||||
|  | @ -220,7 +212,7 @@ def join(self): | |||
|         When the count of unfinished tasks drops to zero, join() unblocks. | ||||
|         """ | ||||
|         if self._unfinished_tasks > 0: | ||||
|             yield from self._finished.wait() | ||||
|             await self._finished.wait() | ||||
| 
 | ||||
| 
 | ||||
| class PriorityQueue(Queue): | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Andrew Svetlov
						Andrew Svetlov