mirror of https://github.com/python/cpython
bpo-38178: Don't explicitly pass "loop" to EchoClientProtocol. (GH-16159)
https://bugs.python.org/issue38178
This commit is contained in:
parent
6e27a0d775
commit
c717c73fa3
|
@ -767,9 +767,8 @@ data, and waits until the connection is closed::
|
||||||
|
|
||||||
|
|
||||||
class EchoClientProtocol(asyncio.Protocol):
|
class EchoClientProtocol(asyncio.Protocol):
|
||||||
def __init__(self, message, on_con_lost, loop):
|
def __init__(self, message, on_con_lost):
|
||||||
self.message = message
|
self.message = message
|
||||||
self.loop = loop
|
|
||||||
self.on_con_lost = on_con_lost
|
self.on_con_lost = on_con_lost
|
||||||
|
|
||||||
def connection_made(self, transport):
|
def connection_made(self, transport):
|
||||||
|
@ -869,11 +868,10 @@ method, sends data and closes the transport when it receives the answer::
|
||||||
|
|
||||||
|
|
||||||
class EchoClientProtocol:
|
class EchoClientProtocol:
|
||||||
def __init__(self, message, loop):
|
def __init__(self, message, on_con_lost):
|
||||||
self.message = message
|
self.message = message
|
||||||
self.loop = loop
|
|
||||||
self.transport = None
|
self.transport = None
|
||||||
self.on_con_lost = loop.create_future()
|
self.on_con_lost = on_con_lost
|
||||||
|
|
||||||
def connection_made(self, transport):
|
def connection_made(self, transport):
|
||||||
self.transport = transport
|
self.transport = transport
|
||||||
|
@ -899,13 +897,15 @@ method, sends data and closes the transport when it receives the answer::
|
||||||
# low-level APIs.
|
# low-level APIs.
|
||||||
loop = asyncio.get_running_loop()
|
loop = asyncio.get_running_loop()
|
||||||
|
|
||||||
|
on_con_lost = loop.create_future()
|
||||||
message = "Hello World!"
|
message = "Hello World!"
|
||||||
|
|
||||||
transport, protocol = await loop.create_datagram_endpoint(
|
transport, protocol = await loop.create_datagram_endpoint(
|
||||||
lambda: EchoClientProtocol(message, loop),
|
lambda: EchoClientProtocol(message, on_con_lost),
|
||||||
remote_addr=('127.0.0.1', 9999))
|
remote_addr=('127.0.0.1', 9999))
|
||||||
|
|
||||||
try:
|
try:
|
||||||
await protocol.on_con_lost
|
await on_con_lost
|
||||||
finally:
|
finally:
|
||||||
transport.close()
|
transport.close()
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue