Thanks to visit codestin.com
Credit goes to github.com

Skip to content

Commit 6e1ab40

Browse files
Merge heads
2 parents c959b0c + 1ea6d40 commit 6e1ab40

2 files changed

Lines changed: 41 additions & 15 deletions

File tree

Lib/asyncio/base_events.py

Lines changed: 40 additions & 9 deletions
Original file line numberDiff line numberDiff line change
@@ -179,6 +179,7 @@ def __init__(self):
179179
# In debug mode, if the execution of a callback or a step of a task
180180
# exceed this duration in seconds, the slow callback/task is logged.
181181
self.slow_callback_duration = 0.1
182+
self._current_handle = None
182183

183184
def __repr__(self):
184185
return ('<%s running=%s closed=%s debug=%s>'
@@ -723,7 +724,13 @@ def create_datagram_endpoint(self, protocol_factory,
723724
logger.debug("Datagram endpoint remote_addr=%r created: "
724725
"(%r, %r)",
725726
remote_addr, transport, protocol)
726-
yield from waiter
727+
728+
try:
729+
yield from waiter
730+
except:
731+
transport.close()
732+
raise
733+
727734
return transport, protocol
728735

729736
@coroutine
@@ -815,7 +822,13 @@ def connect_read_pipe(self, protocol_factory, pipe):
815822
protocol = protocol_factory()
816823
waiter = futures.Future(loop=self)
817824
transport = self._make_read_pipe_transport(pipe, protocol, waiter)
818-
yield from waiter
825+
826+
try:
827+
yield from waiter
828+
except:
829+
transport.close()
830+
raise
831+
819832
if self._debug:
820833
logger.debug('Read pipe %r connected: (%r, %r)',
821834
pipe.fileno(), transport, protocol)
@@ -826,7 +839,13 @@ def connect_write_pipe(self, protocol_factory, pipe):
826839
protocol = protocol_factory()
827840
waiter = futures.Future(loop=self)
828841
transport = self._make_write_pipe_transport(pipe, protocol, waiter)
829-
yield from waiter
842+
843+
try:
844+
yield from waiter
845+
except:
846+
transport.close()
847+
raise
848+
830849
if self._debug:
831850
logger.debug('Write pipe %r connected: (%r, %r)',
832851
pipe.fileno(), transport, protocol)
@@ -937,6 +956,10 @@ def default_exception_handler(self, context):
937956
else:
938957
exc_info = False
939958

959+
if (self._current_handle is not None
960+
and self._current_handle._source_traceback):
961+
context['handle_traceback'] = self._current_handle._source_traceback
962+
940963
log_lines = [message]
941964
for key in sorted(context):
942965
if key in {'message', 'exception'}:
@@ -946,6 +969,10 @@ def default_exception_handler(self, context):
946969
tb = ''.join(traceback.format_list(value))
947970
value = 'Object created at (most recent call last):\n'
948971
value += tb.rstrip()
972+
elif key == 'handle_traceback':
973+
tb = ''.join(traceback.format_list(value))
974+
value = 'Handle created at (most recent call last):\n'
975+
value += tb.rstrip()
949976
else:
950977
value = repr(value)
951978
log_lines.append('{}: {}'.format(key, value))
@@ -1103,12 +1130,16 @@ def _run_once(self):
11031130
if handle._cancelled:
11041131
continue
11051132
if self._debug:
1106-
t0 = self.time()
1107-
handle._run()
1108-
dt = self.time() - t0
1109-
if dt >= self.slow_callback_duration:
1110-
logger.warning('Executing %s took %.3f seconds',
1111-
_format_handle(handle), dt)
1133+
try:
1134+
self._current_handle = handle
1135+
t0 = self.time()
1136+
handle._run()
1137+
dt = self.time() - t0
1138+
if dt >= self.slow_callback_duration:
1139+
logger.warning('Executing %s took %.3f seconds',
1140+
_format_handle(handle), dt)
1141+
finally:
1142+
self._current_handle = None
11121143
else:
11131144
handle._run()
11141145
handle = None # Needed to break cycles when an exception occurs.

Lib/asyncio/windows_events.py

Lines changed: 1 addition & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -694,12 +694,7 @@ def _stop_serving(self, obj):
694694
def close(self):
695695
# Cancel remaining registered operations.
696696
for address, (fut, ov, obj, callback) in list(self._cache.items()):
697-
if obj is None:
698-
# The operation was started with connect_pipe() which
699-
# queues a task to Windows' thread pool. This cannot
700-
# be cancelled, so just forget it.
701-
del self._cache[address]
702-
elif fut.cancelled():
697+
if fut.cancelled():
703698
# Nothing to do with cancelled futures
704699
pass
705700
elif isinstance(fut, _WaitCancelFuture):

0 commit comments

Comments
 (0)