diff options
author | Yury Selivanov <yury@magic.io> | 2016-09-15 20:01:56 (GMT) |
---|---|---|
committer | Yury Selivanov <yury@magic.io> | 2016-09-15 20:01:56 (GMT) |
commit | 2ceb5aacaabb226888029df05311b20edcc6e903 (patch) | |
tree | cab46b9a83a9dd2f5d9f15931c22b4ed32f94c07 /Lib | |
parent | 01683d86f241a591bfd18cb130a98323fc2d4055 (diff) | |
parent | 62b81c33d146d4f5b36589a93736b57d604cf260 (diff) | |
download | cpython-2ceb5aacaabb226888029df05311b20edcc6e903.zip cpython-2ceb5aacaabb226888029df05311b20edcc6e903.tar.gz cpython-2ceb5aacaabb226888029df05311b20edcc6e903.tar.bz2 |
Merge 3.6 (issue #26654)
Diffstat (limited to 'Lib')
-rw-r--r-- | Lib/asyncio/coroutines.py | 2 | ||||
-rw-r--r-- | Lib/asyncio/events.py | 27 | ||||
-rw-r--r-- | Lib/test/test_asyncio/test_events.py | 9 |
3 files changed, 23 insertions, 15 deletions
diff --git a/Lib/asyncio/coroutines.py b/Lib/asyncio/coroutines.py index 72ffb44..e013d64 100644 --- a/Lib/asyncio/coroutines.py +++ b/Lib/asyncio/coroutines.py @@ -271,7 +271,7 @@ def _format_coroutine(coro): func = coro if coro_name is None: - coro_name = events._format_callback(func, ()) + coro_name = events._format_callback(func, (), {}) try: coro_code = coro.gi_code diff --git a/Lib/asyncio/events.py b/Lib/asyncio/events.py index cc9a986..3a33646 100644 --- a/Lib/asyncio/events.py +++ b/Lib/asyncio/events.py @@ -35,23 +35,25 @@ def _get_function_source(func): return None -def _format_args(args): - """Format function arguments. +def _format_args_and_kwargs(args, kwargs): + """Format function arguments and keyword arguments. Special case for a single parameter: ('hello',) is formatted as ('hello'). """ # use reprlib to limit the length of the output - args_repr = reprlib.repr(args) - if len(args) == 1 and args_repr.endswith(',)'): - args_repr = args_repr[:-2] + ')' - return args_repr + items = [] + if args: + items.extend(reprlib.repr(arg) for arg in args) + if kwargs: + items.extend('{}={}'.format(k, reprlib.repr(v)) + for k, v in kwargs.items()) + return '(' + ', '.join(items) + ')' -def _format_callback(func, args, suffix=''): +def _format_callback(func, args, kwargs, suffix=''): if isinstance(func, functools.partial): - if args is not None: - suffix = _format_args(args) + suffix - return _format_callback(func.func, func.args, suffix) + suffix = _format_args_and_kwargs(args, kwargs) + suffix + return _format_callback(func.func, func.args, func.keywords, suffix) if hasattr(func, '__qualname__'): func_repr = getattr(func, '__qualname__') @@ -60,14 +62,13 @@ def _format_callback(func, args, suffix=''): else: func_repr = repr(func) - if args is not None: - func_repr += _format_args(args) + func_repr += _format_args_and_kwargs(args, kwargs) if suffix: func_repr += suffix return func_repr def _format_callback_source(func, args): - func_repr = _format_callback(func, args) + func_repr = _format_callback(func, args, None) source = _get_function_source(func) if source: func_repr += ' at %s:%s' % source diff --git a/Lib/test/test_asyncio/test_events.py b/Lib/test/test_asyncio/test_events.py index 7c901f2..b3f35ce 100644 --- a/Lib/test/test_asyncio/test_events.py +++ b/Lib/test/test_asyncio/test_events.py @@ -2224,7 +2224,7 @@ else: return asyncio.SelectorEventLoop(selectors.SelectSelector()) -def noop(*args): +def noop(*args, **kwargs): pass @@ -2305,6 +2305,13 @@ class HandleTests(test_utils.TestCase): % (re.escape(filename), lineno)) self.assertRegex(repr(h), regex) + # partial function with keyword args + cb = functools.partial(noop, x=1) + h = asyncio.Handle(cb, (2, 3), self.loop) + regex = (r'^<Handle noop\(x=1\)\(2, 3\) at %s:%s>$' + % (re.escape(filename), lineno)) + self.assertRegex(repr(h), regex) + # partial method if sys.version_info >= (3, 4): method = HandleTests.test_handle_repr |