Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
C
cpython
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
cpython
Commits
2085bd08
Commit
2085bd08
authored
Jun 01, 2019
by
Serhiy Storchaka
Committed by
GitHub
Jun 01, 2019
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
bpo-37116: Use PEP 570 syntax for positional-only parameters. (GH-13700)
parent
4a686504
Changes
34
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
34 changed files
with
126 additions
and
261 deletions
+126
-261
Doc/library/collections.rst
Doc/library/collections.rst
+1
-1
Doc/library/contextlib.rst
Doc/library/contextlib.rst
+1
-1
Doc/library/email.headerregistry.rst
Doc/library/email.headerregistry.rst
+1
-1
Doc/library/functools.rst
Doc/library/functools.rst
+2
-2
Doc/library/inspect.rst
Doc/library/inspect.rst
+1
-1
Doc/library/operator.rst
Doc/library/operator.rst
+2
-2
Doc/library/string.rst
Doc/library/string.rst
+3
-3
Doc/library/types.rst
Doc/library/types.rst
+1
-1
Doc/library/unittest.mock-examples.rst
Doc/library/unittest.mock-examples.rst
+2
-2
Doc/library/unittest.rst
Doc/library/unittest.rst
+2
-2
Doc/library/weakref.rst
Doc/library/weakref.rst
+1
-1
Doc/whatsnew/3.8.rst
Doc/whatsnew/3.8.rst
+1
-2
Lib/_collections_abc.py
Lib/_collections_abc.py
+10
-19
Lib/_py_abc.py
Lib/_py_abc.py
+1
-1
Lib/_threading_local.py
Lib/_threading_local.py
+2
-2
Lib/collections/__init__.py
Lib/collections/__init__.py
+10
-36
Lib/contextlib.py
Lib/contextlib.py
+2
-4
Lib/dataclasses.py
Lib/dataclasses.py
+3
-6
Lib/functools.py
Lib/functools.py
+3
-13
Lib/idlelib/debugger_r.py
Lib/idlelib/debugger_r.py
+1
-1
Lib/idlelib/rpc.py
Lib/idlelib/rpc.py
+1
-1
Lib/inspect.py
Lib/inspect.py
+5
-7
Lib/multiprocessing/dummy/__init__.py
Lib/multiprocessing/dummy/__init__.py
+1
-1
Lib/multiprocessing/managers.py
Lib/multiprocessing/managers.py
+4
-7
Lib/multiprocessing/pool.py
Lib/multiprocessing/pool.py
+1
-1
Lib/operator.py
Lib/operator.py
+3
-7
Lib/random.py
Lib/random.py
+1
-1
Lib/string.py
Lib/string.py
+9
-32
Lib/test/support/script_helper.py
Lib/test/support/script_helper.py
+1
-1
Lib/typing.py
Lib/typing.py
+1
-1
Lib/unittest/case.py
Lib/unittest/case.py
+3
-27
Lib/unittest/mock.py
Lib/unittest/mock.py
+34
-48
Lib/unittest/test/test_runner.py
Lib/unittest/test/test_runner.py
+2
-3
Lib/weakref.py
Lib/weakref.py
+10
-23
No files found.
Doc/library/collections.rst
View file @
2085bd08
...
@@ -1140,7 +1140,7 @@ variants of :func:`functools.lru_cache`::
...
@@ -1140,7 +1140,7 @@ variants of :func:`functools.lru_cache`::
class LRU(OrderedDict):
class LRU(OrderedDict):
'Limit size, evicting the least recently looked-up key when full'
'Limit size, evicting the least recently looked-up key when full'
def __init__(self, maxsize=128, *args, **kwds):
def __init__(self, maxsize=128,
/,
*args, **kwds):
self.maxsize = maxsize
self.maxsize = maxsize
super().__init__(*args, **kwds)
super().__init__(*args, **kwds)
...
...
Doc/library/contextlib.rst
View file @
2085bd08
...
@@ -637,7 +637,7 @@ even further by means of a small helper class::
...
@@ -637,7 +637,7 @@ even further by means of a small helper class::
from contextlib import ExitStack
from contextlib import ExitStack
class Callback(ExitStack):
class Callback(ExitStack):
def __init__(self, callback, *args, **kwds):
def __init__(self, callback,
/,
*args, **kwds):
super(Callback, self).__init__()
super(Callback, self).__init__()
self.callback(callback, *args, **kwds)
self.callback(callback, *args, **kwds)
...
...
Doc/library/email.headerregistry.rst
View file @
2085bd08
...
@@ -107,7 +107,7 @@ headers.
...
@@ -107,7 +107,7 @@ headers.
method if it wishes to set additional attributes beyond those provided by
method if it wishes to set additional attributes beyond those provided by
``BaseHeader`` itself. Such an ``init`` method should look like this::
``BaseHeader`` itself. Such an ``init`` method should look like this::
def init(self, *args, **kw):
def init(self,
/,
*args, **kw):
self._myattr = kw.pop('myattr')
self._myattr = kw.pop('myattr')
super().init(*args, **kw)
super().init(*args, **kw)
...
...
Doc/library/functools.rst
View file @
2085bd08
...
@@ -221,7 +221,7 @@ The :mod:`functools` module defines the following functions:
...
@@ -221,7 +221,7 @@ The :mod:`functools` module defines the following functions:
Returning NotImplemented from the underlying comparison function for
Returning NotImplemented from the underlying comparison function for
unrecognised types is now supported.
unrecognised types is now supported.
.. function:: partial(func, *args, **keywords)
.. function:: partial(func,
/,
*args, **keywords)
Return a new :ref:`partial object<partial-objects>` which when called
Return a new :ref:`partial object<partial-objects>` which when called
will behave like *func* called with the positional arguments *args*
will behave like *func* called with the positional arguments *args*
...
@@ -230,7 +230,7 @@ The :mod:`functools` module defines the following functions:
...
@@ -230,7 +230,7 @@ The :mod:`functools` module defines the following functions:
supplied, they extend and override *keywords*.
supplied, they extend and override *keywords*.
Roughly equivalent to::
Roughly equivalent to::
def partial(func, *args, **keywords):
def partial(func,
/,
*args, **keywords):
def newfunc(*fargs, **fkeywords):
def newfunc(*fargs, **fkeywords):
newkeywords = {**keywords, **fkeywords}
newkeywords = {**keywords, **fkeywords}
return func(*args, *fargs, **newkeywords)
return func(*args, *fargs, **newkeywords)
...
...
Doc/library/inspect.rst
View file @
2085bd08
...
@@ -1022,7 +1022,7 @@ Classes and functions
...
@@ -1022,7 +1022,7 @@ Classes and functions
metatype is in use, cls will be the first element of the tuple.
metatype is in use, cls will be the first element of the tuple.
.. function:: getcallargs(func, *args, **kwds)
.. function:: getcallargs(func,
/,
*args, **kwds)
Bind the *args* and *kwds* to the argument names of the Python function or
Bind the *args* and *kwds* to the argument names of the Python function or
method *func*, as if it was called with them. For bound methods, bind also the
method *func*, as if it was called with them. For bound methods, bind also the
...
...
Doc/library/operator.rst
View file @
2085bd08
...
@@ -339,7 +339,7 @@ expect a function argument.
...
@@ -339,7 +339,7 @@ expect a function argument.
[('orange', 1), ('banana', 2), ('apple', 3), ('pear', 5)]
[('orange', 1), ('banana', 2), ('apple', 3), ('pear', 5)]
.. function:: methodcaller(name
[, args...]
)
.. function:: methodcaller(name
, /, *args, **kwargs
)
Return a callable object that calls the method *name* on its operand. If
Return a callable object that calls the method *name* on its operand. If
additional arguments and/or keyword arguments are given, they will be given
additional arguments and/or keyword arguments are given, they will be given
...
@@ -352,7 +352,7 @@ expect a function argument.
...
@@ -352,7 +352,7 @@ expect a function argument.
Equivalent to::
Equivalent to::
def methodcaller(name, *args, **kwargs):
def methodcaller(name,
/,
*args, **kwargs):
def caller(obj):
def caller(obj):
return getattr(obj, name)(*args, **kwargs)
return getattr(obj, name)(*args, **kwargs)
return caller
return caller
...
...
Doc/library/string.rst
View file @
2085bd08
...
@@ -88,7 +88,7 @@ implementation as the built-in :meth:`~str.format` method.
...
@@ -88,7 +88,7 @@ implementation as the built-in :meth:`~str.format` method.
The :class:`Formatter` class has the following public methods:
The :class:`Formatter` class has the following public methods:
.. method:: format(format_string, *args, **kwargs)
.. method:: format(format_string,
/,
*args, **kwargs)
The primary API method. It takes a format string and
The primary API method. It takes a format string and
an arbitrary set of positional and keyword arguments.
an arbitrary set of positional and keyword arguments.
...
@@ -720,7 +720,7 @@ these rules. The methods of :class:`Template` are:
...
@@ -720,7 +720,7 @@ these rules. The methods of :class:`Template` are:
The constructor takes a single argument which is the template string.
The constructor takes a single argument which is the template string.
.. method:: substitute(mapping, **kwds)
.. method:: substitute(mapping
={}, /
, **kwds)
Performs the template substitution, returning a new string. *mapping* is
Performs the template substitution, returning a new string. *mapping* is
any dictionary-like object with keys that match the placeholders in the
any dictionary-like object with keys that match the placeholders in the
...
@@ -729,7 +729,7 @@ these rules. The methods of :class:`Template` are:
...
@@ -729,7 +729,7 @@ these rules. The methods of :class:`Template` are:
and there are duplicates, the placeholders from *kwds* take precedence.
and there are duplicates, the placeholders from *kwds* take precedence.
.. method:: safe_substitute(mapping, **kwds)
.. method:: safe_substitute(mapping
={}, /
, **kwds)
Like :meth:`substitute`, except that if placeholders are missing from
Like :meth:`substitute`, except that if placeholders are missing from
*mapping* and *kwds*, instead of raising a :exc:`KeyError` exception, the
*mapping* and *kwds*, instead of raising a :exc:`KeyError` exception, the
...
...
Doc/library/types.rst
View file @
2085bd08
...
@@ -327,7 +327,7 @@ Additional Utility Classes and Functions
...
@@ -327,7 +327,7 @@ Additional Utility Classes and Functions
The type is roughly equivalent to the following code::
The type is roughly equivalent to the following code::
class SimpleNamespace:
class SimpleNamespace:
def __init__(self, **kwargs):
def __init__(self,
/,
**kwargs):
self.__dict__.update(kwargs)
self.__dict__.update(kwargs)
def __repr__(self):
def __repr__(self):
...
...
Doc/library/unittest.mock-examples.rst
View file @
2085bd08
...
@@ -848,7 +848,7 @@ Here's an example implementation:
...
@@ -848,7 +848,7 @@ Here's an example implementation:
>>> from copy import deepcopy
>>> from copy import deepcopy
>>> class CopyingMock(MagicMock):
>>> class CopyingMock(MagicMock):
... def __call__(self, *args, **kwargs):
... def __call__(self,
/,
*args, **kwargs):
... args = deepcopy(args)
... args = deepcopy(args)
... kwargs = deepcopy(kwargs)
... kwargs = deepcopy(kwargs)
... return super(CopyingMock, self).__call__(*args, **kwargs)
... return super(CopyingMock, self).__call__(*args, **kwargs)
...
@@ -1042,7 +1042,7 @@ that it takes arbitrary keyword arguments (``**kwargs``) which are then passed
...
@@ -1042,7 +1042,7 @@ that it takes arbitrary keyword arguments (``**kwargs``) which are then passed
onto the mock constructor:
onto the mock constructor:
>>> class Subclass(MagicMock):
>>> class Subclass(MagicMock):
... def _get_child_mock(self, **kwargs):
... def _get_child_mock(self,
/,
**kwargs):
... return MagicMock(**kwargs)
... return MagicMock(**kwargs)
...
...
>>> mymock = Subclass()
>>> mymock = Subclass()
...
...
Doc/library/unittest.rst
View file @
2085bd08
...
@@ -1456,7 +1456,7 @@ Test cases
...
@@ -1456,7 +1456,7 @@ Test cases
.. versionadded:: 3.1
.. versionadded:: 3.1
.. classmethod:: addClassCleanup(function, *args, **kwargs)
.. classmethod:: addClassCleanup(function,
/,
*args, **kwargs)
Add a function to be called after :meth:`tearDownClass` to cleanup
Add a function to be called after :meth:`tearDownClass` to cleanup
resources used during the test class. Functions will be called in reverse
resources used during the test class. Functions will be called in reverse
...
@@ -2313,7 +2313,7 @@ To add cleanup code that must be run even in the case of an exception, use
...
@@ -2313,7 +2313,7 @@ To add cleanup code that must be run even in the case of an exception, use
``addModuleCleanup``:
``addModuleCleanup``:
.. function:: addModuleCleanup(function, *args, **kwargs)
.. function:: addModuleCleanup(function,
/,
*args, **kwargs)
Add a function to be called after :func:`tearDownModule` to cleanup
Add a function to be called after :func:`tearDownModule` to cleanup
resources used during the test class. Functions will be called in reverse
resources used during the test class. Functions will be called in reverse
...
...
Doc/library/weakref.rst
View file @
2085bd08
...
@@ -396,7 +396,7 @@ the referent is accessed::
...
@@ -396,7 +396,7 @@ the referent is accessed::
import weakref
import weakref
class ExtendedRef(weakref.ref):
class ExtendedRef(weakref.ref):
def __init__(self, ob, callback=None, **annotations):
def __init__(self, ob, callback=None,
/,
**annotations):
super(ExtendedRef, self).__init__(ob, callback)
super(ExtendedRef, self).__init__(ob, callback)
self.__counter = 0
self.__counter = 0
for k, v in annotations.items():
for k, v in annotations.items():
...
...
Doc/whatsnew/3.8.rst
View file @
2085bd08
...
@@ -941,8 +941,7 @@ Deprecated
...
@@ -941,8 +941,7 @@ Deprecated
:meth:`profile.Profile.runcall`, :meth:`cProfile.Profile.runcall`,
:meth:`profile.Profile.runcall`, :meth:`cProfile.Profile.runcall`,
:meth:`bdb.Bdb.runcall`, :meth:`trace.Trace.runfunc` and
:meth:`bdb.Bdb.runcall`, :meth:`trace.Trace.runfunc` and
:func:`curses.wrapper`.
:func:`curses.wrapper`.
- *function* in :func:`unittest.addModuleCleanup` and
- *function* in :meth:`unittest.TestCase.addCleanup`.
:meth:`unittest.TestCase.addCleanup`.
- *fn* in the :meth:`~concurrent.futures.Executor.submit` method of
- *fn* in the :meth:`~concurrent.futures.Executor.submit` method of
:class:`concurrent.futures.ThreadPoolExecutor` and
:class:`concurrent.futures.ThreadPoolExecutor` and
:class:`concurrent.futures.ProcessPoolExecutor`.
:class:`concurrent.futures.ProcessPoolExecutor`.
...
...
Lib/_collections_abc.py
View file @
2085bd08
...
@@ -821,30 +821,21 @@ class MutableMapping(Mapping):
...
@@ -821,30 +821,21 @@ class MutableMapping(Mapping):
except
KeyError
:
except
KeyError
:
pass
pass
def
update
(
*
args
,
**
kwds
):
def
update
(
self
,
other
=
(),
/
,
**
kwds
):
''' D.update([E, ]**F) -> None. Update D from mapping/iterable E and F.
''' D.update([E, ]**F) -> None. Update D from mapping/iterable E and F.
If E present and has a .keys() method, does: for k in E: D[k] = E[k]
If E present and has a .keys() method, does: for k in E: D[k] = E[k]
If E present and lacks .keys() method, does: for (k, v) in E: D[k] = v
If E present and lacks .keys() method, does: for (k, v) in E: D[k] = v
In either case, this is followed by: for k, v in F.items(): D[k] = v
In either case, this is followed by: for k, v in F.items(): D[k] = v
'''
'''
if
not
args
:
if
isinstance
(
other
,
Mapping
):
raise
TypeError
(
"descriptor 'update' of 'MutableMapping' object "
for
key
in
other
:
"needs an argument"
)
self
[
key
]
=
other
[
key
]
self
,
*
args
=
args
elif
hasattr
(
other
,
"keys"
):
if
len
(
args
)
>
1
:
for
key
in
other
.
keys
():
raise
TypeError
(
'update expected at most 1 arguments, got %d'
%
self
[
key
]
=
other
[
key
]
len
(
args
))
else
:
if
args
:
for
key
,
value
in
other
:
other
=
args
[
0
]
self
[
key
]
=
value
if
isinstance
(
other
,
Mapping
):
for
key
in
other
:
self
[
key
]
=
other
[
key
]
elif
hasattr
(
other
,
"keys"
):
for
key
in
other
.
keys
():
self
[
key
]
=
other
[
key
]
else
:
for
key
,
value
in
other
:
self
[
key
]
=
value
for
key
,
value
in
kwds
.
items
():
for
key
,
value
in
kwds
.
items
():
self
[
key
]
=
value
self
[
key
]
=
value
...
...
Lib/_py_abc.py
View file @
2085bd08
...
@@ -32,7 +32,7 @@ class ABCMeta(type):
...
@@ -32,7 +32,7 @@ class ABCMeta(type):
# external code.
# external code.
_abc_invalidation_counter
=
0
_abc_invalidation_counter
=
0
def
__new__
(
mcls
,
name
,
bases
,
namespace
,
**
kwargs
):
def
__new__
(
mcls
,
name
,
bases
,
namespace
,
/
,
**
kwargs
):
cls
=
super
().
__new__
(
mcls
,
name
,
bases
,
namespace
,
**
kwargs
)
cls
=
super
().
__new__
(
mcls
,
name
,
bases
,
namespace
,
**
kwargs
)
# Compute set of abstract method names
# Compute set of abstract method names
abstracts
=
{
name
abstracts
=
{
name
...
...
Lib/_threading_local.py
View file @
2085bd08
...
@@ -56,7 +56,7 @@ You can create custom local objects by subclassing the local class:
...
@@ -56,7 +56,7 @@ You can create custom local objects by subclassing the local class:
>>> class MyLocal(local):
>>> class MyLocal(local):
... number = 2
... number = 2
... def __init__(self, **kw):
... def __init__(self,
/,
**kw):
... self.__dict__.update(kw)
... self.__dict__.update(kw)
... def squared(self):
... def squared(self):
... return self.number ** 2
... return self.number ** 2
...
@@ -204,7 +204,7 @@ def _patch(self):
...
@@ -204,7 +204,7 @@ def _patch(self):
class
local
:
class
local
:
__slots__
=
'_local__impl'
,
'__dict__'
__slots__
=
'_local__impl'
,
'__dict__'
def
__new__
(
cls
,
*
args
,
**
kw
):
def
__new__
(
cls
,
/
,
*
args
,
**
kw
):
if
(
args
or
kw
)
and
(
cls
.
__init__
is
object
.
__init__
):
if
(
args
or
kw
)
and
(
cls
.
__init__
is
object
.
__init__
):
raise
TypeError
(
"Initialization arguments are not supported"
)
raise
TypeError
(
"Initialization arguments are not supported"
)
self
=
object
.
__new__
(
cls
)
self
=
object
.
__new__
(
cls
)
...
...
Lib/collections/__init__.py
View file @
2085bd08
...
@@ -93,16 +93,10 @@ class OrderedDict(dict):
...
@@ -93,16 +93,10 @@ class OrderedDict(dict):
# Individual links are kept alive by the hard reference in self.__map.
# Individual links are kept alive by the hard reference in self.__map.
# Those hard references disappear when a key is deleted from an OrderedDict.
# Those hard references disappear when a key is deleted from an OrderedDict.
def
__init__
(
*
args
,
**
kwds
):
def
__init__
(
self
,
other
=
(),
/
,
**
kwds
):
'''Initialize an ordered dictionary. The signature is the same as
'''Initialize an ordered dictionary. The signature is the same as
regular dictionaries. Keyword argument order is preserved.
regular dictionaries. Keyword argument order is preserved.
'''
'''
if
not
args
:
raise
TypeError
(
"descriptor '__init__' of 'OrderedDict' object "
"needs an argument"
)
self
,
*
args
=
args
if
len
(
args
)
>
1
:
raise
TypeError
(
'expected at most 1 arguments, got %d'
%
len
(
args
))
try
:
try
:
self
.
__root
self
.
__root
except
AttributeError
:
except
AttributeError
:
...
@@ -110,7 +104,7 @@ class OrderedDict(dict):
...
@@ -110,7 +104,7 @@ class OrderedDict(dict):
self
.
__root
=
root
=
_proxy
(
self
.
__hardroot
)
self
.
__root
=
root
=
_proxy
(
self
.
__hardroot
)
root
.
prev
=
root
.
next
=
root
root
.
prev
=
root
.
next
=
root
self
.
__map
=
{}
self
.
__map
=
{}
self
.
__update
(
*
args
,
**
kwds
)
self
.
__update
(
other
,
**
kwds
)
def
__setitem__
(
self
,
key
,
value
,
def
__setitem__
(
self
,
key
,
value
,
dict_setitem
=
dict
.
__setitem__
,
proxy
=
_proxy
,
Link
=
_Link
):
dict_setitem
=
dict
.
__setitem__
,
proxy
=
_proxy
,
Link
=
_Link
):
...
@@ -413,8 +407,8 @@ def namedtuple(typename, field_names, *, rename=False, defaults=None, module=Non
...
@@ -413,8 +407,8 @@ def namedtuple(typename, field_names, *, rename=False, defaults=None, module=Non
_make
.
__func__
.
__doc__
=
(
f'Make a new
{
typename
}
object from a sequence '
_make
.
__func__
.
__doc__
=
(
f'Make a new
{
typename
}
object from a sequence '
'or iterable'
)
'or iterable'
)
def
_replace
(
_self
,
**
kwds
):
def
_replace
(
self
,
/
,
**
kwds
):
result
=
_self
.
_make
(
_map
(
kwds
.
pop
,
field_names
,
_
self
))
result
=
self
.
_make
(
_map
(
kwds
.
pop
,
field_names
,
self
))
if
kwds
:
if
kwds
:
raise
ValueError
(
f'Got unexpected field names:
{
list
(
kwds
)
!
r
}
'
)
raise
ValueError
(
f'Got unexpected field names:
{
list
(
kwds
)
!
r
}
'
)
return
result
return
result
...
@@ -543,7 +537,7 @@ class Counter(dict):
...
@@ -543,7 +537,7 @@ class Counter(dict):
# http://code.activestate.com/recipes/259174/
# http://code.activestate.com/recipes/259174/
# Knuth, TAOCP Vol. II section 4.6.3
# Knuth, TAOCP Vol. II section 4.6.3
def
__init__
(
*
args
,
**
kwds
):
def
__init__
(
self
,
iterable
=
None
,
/
,
**
kwds
):
'''Create a new, empty Counter object. And if given, count elements
'''Create a new, empty Counter object. And if given, count elements
from an input iterable. Or, initialize the count from another mapping
from an input iterable. Or, initialize the count from another mapping
of elements to their counts.
of elements to their counts.
...
@@ -554,14 +548,8 @@ class Counter(dict):
...
@@ -554,14 +548,8 @@ class Counter(dict):
>>> c = Counter(a=4, b=2) # a new counter from keyword args
>>> c = Counter(a=4, b=2) # a new counter from keyword args
'''
'''
if
not
args
:
raise
TypeError
(
"descriptor '__init__' of 'Counter' object "
"needs an argument"
)
self
,
*
args
=
args
if
len
(
args
)
>
1
:
raise
TypeError
(
'expected at most 1 arguments, got %d'
%
len
(
args
))
super
(
Counter
,
self
).
__init__
()
super
(
Counter
,
self
).
__init__
()
self
.
update
(
*
args
,
**
kwds
)
self
.
update
(
iterable
,
**
kwds
)
def
__missing__
(
self
,
key
):
def
__missing__
(
self
,
key
):
'The count of elements not in the Counter is zero.'
'The count of elements not in the Counter is zero.'
...
@@ -617,7 +605,7 @@ class Counter(dict):
...
@@ -617,7 +605,7 @@ class Counter(dict):
raise
NotImplementedError
(
raise
NotImplementedError
(
'Counter.fromkeys() is undefined. Use Counter(iterable) instead.'
)
'Counter.fromkeys() is undefined. Use Counter(iterable) instead.'
)
def
update
(
*
args
,
**
kwds
):
def
update
(
self
,
iterable
=
None
,
/
,
**
kwds
):
'''Like dict.update() but add counts instead of replacing them.
'''Like dict.update() but add counts instead of replacing them.
Source can be an iterable, a dictionary, or another Counter instance.
Source can be an iterable, a dictionary, or another Counter instance.
...
@@ -637,13 +625,6 @@ class Counter(dict):
...
@@ -637,13 +625,6 @@ class Counter(dict):
# contexts. Instead, we implement straight-addition. Both the inputs
# contexts. Instead, we implement straight-addition. Both the inputs
# and outputs are allowed to contain zero and negative counts.
# and outputs are allowed to contain zero and negative counts.
if
not
args
:
raise
TypeError
(
"descriptor 'update' of 'Counter' object "
"needs an argument"
)
self
,
*
args
=
args
if
len
(
args
)
>
1
:
raise
TypeError
(
'expected at most 1 arguments, got %d'
%
len
(
args
))
iterable
=
args
[
0
]
if
args
else
None
if
iterable
is
not
None
:
if
iterable
is
not
None
:
if
isinstance
(
iterable
,
_collections_abc
.
Mapping
):
if
isinstance
(
iterable
,
_collections_abc
.
Mapping
):
if
self
:
if
self
:
...
@@ -657,7 +638,7 @@ class Counter(dict):
...
@@ -657,7 +638,7 @@ class Counter(dict):
if
kwds
:
if
kwds
:
self
.
update
(
kwds
)
self
.
update
(
kwds
)
def
subtract
(
*
args
,
**
kwds
):
def
subtract
(
self
,
iterable
=
None
,
/
,
**
kwds
):
'''Like dict.update() but subtracts counts instead of replacing them.
'''Like dict.update() but subtracts counts instead of replacing them.
Counts can be reduced below zero. Both the inputs and outputs are
Counts can be reduced below zero. Both the inputs and outputs are
allowed to contain zero and negative counts.
allowed to contain zero and negative counts.
...
@@ -673,13 +654,6 @@ class Counter(dict):
...
@@ -673,13 +654,6 @@ class Counter(dict):
-1
-1
'''
'''
if
not
args
:
raise
TypeError
(
"descriptor 'subtract' of 'Counter' object "
"needs an argument"
)
self
,
*
args
=
args
if
len
(
args
)
>
1
:
raise
TypeError
(
'expected at most 1 arguments, got %d'
%
len
(
args
))
iterable
=
args
[
0
]
if
args
else
None
if
iterable
is
not
None
:
if
iterable
is
not
None
:
self_get
=
self
.
get
self_get
=
self
.
get
if
isinstance
(
iterable
,
_collections_abc
.
Mapping
):
if
isinstance
(
iterable
,
_collections_abc
.
Mapping
):
...
@@ -1141,7 +1115,7 @@ class UserList(_collections_abc.MutableSequence):
...
@@ -1141,7 +1115,7 @@ class UserList(_collections_abc.MutableSequence):
def
count
(
self
,
item
):
return
self
.
data
.
count
(
item
)
def
count
(
self
,
item
):
return
self
.
data
.
count
(
item
)
def
index
(
self
,
item
,
*
args
):
return
self
.
data
.
index
(
item
,
*
args
)
def
index
(
self
,
item
,
*
args
):
return
self
.
data
.
index
(
item
,
*
args
)
def
reverse
(
self
):
self
.
data
.
reverse
()
def
reverse
(
self
):
self
.
data
.
reverse
()
def
sort
(
self
,
*
args
,
**
kwds
):
self
.
data
.
sort
(
*
args
,
**
kwds
)
def
sort
(
self
,
/
,
*
args
,
**
kwds
):
self
.
data
.
sort
(
*
args
,
**
kwds
)
def
extend
(
self
,
other
):
def
extend
(
self
,
other
):
if
isinstance
(
other
,
UserList
):
if
isinstance
(
other
,
UserList
):
self
.
data
.
extend
(
other
.
data
)
self
.
data
.
extend
(
other
.
data
)
...
@@ -1240,7 +1214,7 @@ class UserString(_collections_abc.Sequence):
...
@@ -1240,7 +1214,7 @@ class UserString(_collections_abc.Sequence):
if
isinstance
(
sub
,
UserString
):
if
isinstance
(
sub
,
UserString
):
sub
=
sub
.
data
sub
=
sub
.
data
return
self
.
data
.
find
(
sub
,
start
,
end
)
return
self
.
data
.
find
(
sub
,
start
,
end
)
def
format
(
self
,
*
args
,
**
kwds
):
def
format
(
self
,
/
,
*
args
,
**
kwds
):
return
self
.
data
.
format
(
*
args
,
**
kwds
)
return
self
.
data
.
format
(
*
args
,
**
kwds
)
def
format_map
(
self
,
mapping
):
def
format_map
(
self
,
mapping
):
return
self
.
data
.
format_map
(
mapping
)
return
self
.
data
.
format_map
(
mapping
)
...
...
Lib/contextlib.py
View file @
2085bd08
...
@@ -377,8 +377,7 @@ class _BaseExitStack:
...
@@ -377,8 +377,7 @@ class _BaseExitStack:
return
MethodType
(
cm_exit
,
cm
)
return
MethodType
(
cm_exit
,
cm
)
@
staticmethod
@
staticmethod
def
_create_cb_wrapper
(
*
args
,
**
kwds
):
def
_create_cb_wrapper
(
callback
,
/
,
*
args
,
**
kwds
):
callback
,
*
args
=
args
def
_exit_wrapper
(
exc_type
,
exc
,
tb
):
def
_exit_wrapper
(
exc_type
,
exc
,
tb
):
callback
(
*
args
,
**
kwds
)
callback
(
*
args
,
**
kwds
)
return
_exit_wrapper
return
_exit_wrapper
...
@@ -553,8 +552,7 @@ class AsyncExitStack(_BaseExitStack, AbstractAsyncContextManager):
...
@@ -553,8 +552,7 @@ class AsyncExitStack(_BaseExitStack, AbstractAsyncContextManager):
return
MethodType
(
cm_exit
,
cm
)
return
MethodType
(
cm_exit
,
cm
)
@
staticmethod
@
staticmethod
def
_create_async_cb_wrapper
(
*
args
,
**
kwds
):
def
_create_async_cb_wrapper
(
callback
,
/
,
*
args
,
**
kwds
):
callback
,
*
args
=
args
async
def
_exit_wrapper
(
exc_type
,
exc
,
tb
):
async
def
_exit_wrapper
(
exc_type
,
exc
,
tb
):
await
callback
(
*
args
,
**
kwds
)
await
callback
(
*
args
,
**
kwds
)
return
_exit_wrapper
return
_exit_wrapper
...
...
Lib/dataclasses.py
View file @
2085bd08
...
@@ -962,10 +962,7 @@ def _process_class(cls, init, repr, eq, order, unsafe_hash, frozen):
...
@@ -962,10 +962,7 @@ def _process_class(cls, init, repr, eq, order, unsafe_hash, frozen):
return
cls
return
cls
# _cls should never be specified by keyword, so start it with an
def
dataclass
(
cls
=
None
,
/
,
*
,
init
=
True
,
repr
=
True
,
eq
=
True
,
order
=
False
,
# underscore. The presence of _cls is used to detect if this
# decorator is being called with parameters or not.
def
dataclass
(
_cls
=
None
,
*
,
init
=
True
,
repr
=
True
,
eq
=
True
,
order
=
False
,
unsafe_hash
=
False
,
frozen
=
False
):
unsafe_hash
=
False
,
frozen
=
False
):
"""Returns the same class as was passed in, with dunder methods
"""Returns the same class as was passed in, with dunder methods
added based on the fields defined in the class.
added based on the fields defined in the class.
...
@@ -983,12 +980,12 @@ def dataclass(_cls=None, *, init=True, repr=True, eq=True, order=False,
...
@@ -983,12 +980,12 @@ def dataclass(_cls=None, *, init=True, repr=True, eq=True, order=False,
return
_process_class
(
cls
,
init
,
repr
,
eq
,
order
,
unsafe_hash
,
frozen
)
return
_process_class
(
cls
,
init
,
repr
,
eq
,
order
,
unsafe_hash
,
frozen
)
# See if we're being called as @dataclass or @dataclass().
# See if we're being called as @dataclass or @dataclass().
if
_
cls
is
None
:
if
cls
is
None
:
# We're called with parens.
# We're called with parens.
return
wrap
return
wrap
# We're called as @dataclass without parens.
# We're called as @dataclass without parens.
return
wrap
(
_
cls
)
return
wrap
(
cls
)
def
fields
(
class_or_instance
):
def
fields
(
class_or_instance
):
...
...
Lib/functools.py
View file @
2085bd08
...
@@ -273,15 +273,9 @@ class partial:
...
@@ -273,15 +273,9 @@ class partial:
__slots__
=
"func"
,
"args"
,
"keywords"
,
"__dict__"
,
"__weakref__"
__slots__
=
"func"
,
"args"
,
"keywords"
,
"__dict__"
,
"__weakref__"
def
__new__
(
*
args
,
**
keywords
):
def
__new__
(
cls
,
func
,
/
,
*
args
,
**
keywords
):
if
not
args
:
raise
TypeError
(
"descriptor '__new__' of partial needs an argument"
)
if
len
(
args
)
<
2
:
raise
TypeError
(
"type 'partial' takes at least one argument"
)
cls
,
func
,
*
args
=
args
if
not
callable
(
func
):
if
not
callable
(
func
):
raise
TypeError
(
"the first argument must be callable"
)
raise
TypeError
(
"the first argument must be callable"
)
args
=
tuple
(
args
)
if
hasattr
(
func
,
"func"
):
if
hasattr
(
func
,
"func"
):
args
=
func
.
args
+
args
args
=
func
.
args
+
args
...
@@ -295,10 +289,7 @@ class partial:
...
@@ -295,10 +289,7 @@ class partial:
self
.
keywords
=
keywords
self
.
keywords
=
keywords
return
self
return
self
def
__call__
(
*
args
,
**
keywords
):
def
__call__
(
self
,
/
,
*
args
,
**
keywords
):
if
not
args
:
raise
TypeError
(
"descriptor '__call__' of partial needs an argument"
)
self
,
*
args
=
args
keywords
=
{
**
self
.
keywords
,
**
keywords
}
keywords
=
{
**
self
.
keywords
,
**
keywords
}
return
self
.
func
(
*
self
.
args
,
*
args
,
**
keywords
)
return
self
.
func
(
*
self
.
args
,
*
args
,
**
keywords
)
...
@@ -402,8 +393,7 @@ class partialmethod(object):
...
@@ -402,8 +393,7 @@ class partialmethod(object):
keywords
=
keywords
)
keywords
=
keywords
)
def
_make_unbound_method
(
self
):
def
_make_unbound_method
(
self
):
def
_method
(
*
args
,
**
keywords
):
def
_method
(
cls_or_self
,
/
,
*
args
,
**
keywords
):
cls_or_self
,
*
args
=
args
keywords
=
{
**
self
.
keywords
,
**
keywords
}
keywords
=
{
**
self
.
keywords
,
**
keywords
}
return
self
.
func
(
cls_or_self
,
*
self
.
args
,
*
args
,
**
keywords
)
return
self
.
func
(
cls_or_self
,
*
self
.
args
,
*
args
,
**
keywords
)
_method
.
__isabstractmethod__
=
self
.
__isabstractmethod__
_method
.
__isabstractmethod__
=
self
.
__isabstractmethod__
...
...
Lib/idlelib/debugger_r.py
View file @
2085bd08
...
@@ -299,7 +299,7 @@ class IdbProxy:
...
@@ -299,7 +299,7 @@ class IdbProxy:
self
.
conn
=
conn
self
.
conn
=
conn
self
.
shell
=
shell
self
.
shell
=
shell
def
call
(
self
,
methodname
,
*
args
,
**
kwargs
):
def
call
(
self
,
methodname
,
/
,
*
args
,
**
kwargs
):
##print("*** IdbProxy.call %s %s %s" % (methodname, args, kwargs))
##print("*** IdbProxy.call %s %s %s" % (methodname, args, kwargs))
value
=
self
.
conn
.
remotecall
(
self
.
oid
,
methodname
,
args
,
kwargs
)
value
=
self
.
conn
.
remotecall
(
self
.
oid
,
methodname
,
args
,
kwargs
)
##print("*** IdbProxy.call %s returns %r" % (methodname, value))
##print("*** IdbProxy.call %s returns %r" % (methodname, value))
...
...
Lib/idlelib/rpc.py
View file @
2085bd08
...
@@ -603,7 +603,7 @@ class MethodProxy(object):
...
@@ -603,7 +603,7 @@ class MethodProxy(object):
self
.
oid
=
oid
self
.
oid
=
oid
self
.
name
=
name
self
.
name
=
name
def
__call__
(
self
,
*
args
,
**
kwargs
):
def
__call__
(
self
,
/
,
*
args
,
**
kwargs
):
value
=
self
.
sockio
.
remotecall
(
self
.
oid
,
self
.
name
,
args
,
kwargs
)
value
=
self
.
sockio
.
remotecall
(
self
.
oid
,
self
.
name
,
args
,
kwargs
)
return
value
return
value
...
...
Lib/inspect.py
View file @
2085bd08
...
@@ -1329,14 +1329,12 @@ def _too_many(f_name, args, kwonly, varargs, defcount, given, values):
...
@@ -1329,14 +1329,12 @@ def _too_many(f_name, args, kwonly, varargs, defcount, given, values):
(
f_name
,
sig
,
"s"
if
plural
else
""
,
given
,
kwonly_sig
,
(
f_name
,
sig
,
"s"
if
plural
else
""
,
given
,
kwonly_sig
,
"was"
if
given
==
1
and
not
kwonly_given
else
"were"
))
"was"
if
given
==
1
and
not
kwonly_given
else
"were"
))
def
getcallargs
(
*
func_and_
positional
,
**
named
):
def
getcallargs
(
func
,
/
,
*
positional
,
**
named
):
"""Get the mapping of arguments to values.
"""Get the mapping of arguments to values.
A dict is returned, with keys the function argument names (including the
A dict is returned, with keys the function argument names (including the
names of the * and ** arguments, if any), and values the respective bound
names of the * and ** arguments, if any), and values the respective bound
values from 'positional' and 'named'."""
values from 'positional' and 'named'."""
func
=
func_and_positional
[
0
]
positional
=
func_and_positional
[
1
:]
spec
=
getfullargspec
(
func
)
spec
=
getfullargspec
(
func
)
args
,
varargs
,
varkw
,
defaults
,
kwonlyargs
,
kwonlydefaults
,
ann
=
spec
args
,
varargs
,
varkw
,
defaults
,
kwonlyargs
,
kwonlydefaults
,
ann
=
spec
f_name
=
func
.
__name__
f_name
=
func
.
__name__
...
@@ -3027,19 +3025,19 @@ class Signature:
...
@@ -3027,19 +3025,19 @@ class Signature:
return
self
.
_bound_arguments_cls
(
self
,
arguments
)
return
self
.
_bound_arguments_cls
(
self
,
arguments
)
def
bind
(
*
args
,
**
kwargs
):
def
bind
(
self
,
/
,
*
args
,
**
kwargs
):
"""Get a BoundArguments object, that maps the passed `args`
"""Get a BoundArguments object, that maps the passed `args`
and `kwargs` to the function's signature. Raises `TypeError`
and `kwargs` to the function's signature. Raises `TypeError`
if the passed arguments can not be bound.
if the passed arguments can not be bound.
"""
"""
return
args
[
0
].
_bind
(
args
[
1
:]
,
kwargs
)
return
self
.
_bind
(
args
,
kwargs
)
def
bind_partial
(
*
args
,
**
kwargs
):
def
bind_partial
(
self
,
/
,
*
args
,
**
kwargs
):
"""Get a BoundArguments object, that partially maps the
"""Get a BoundArguments object, that partially maps the
passed `args` and `kwargs` to the function's signature.
passed `args` and `kwargs` to the function's signature.
Raises `TypeError` if the passed arguments can not be bound.
Raises `TypeError` if the passed arguments can not be bound.
"""
"""
return
args
[
0
].
_bind
(
args
[
1
:]
,
kwargs
,
partial
=
True
)
return
self
.
_bind
(
args
,
kwargs
,
partial
=
True
)
def
__reduce__
(
self
):
def
__reduce__
(
self
):
return
(
type
(
self
),
return
(
type
(
self
),
...
...
Lib/multiprocessing/dummy/__init__.py
View file @
2085bd08
...
@@ -80,7 +80,7 @@ def freeze_support():
...
@@ -80,7 +80,7 @@ def freeze_support():
#
#
class
Namespace
(
object
):
class
Namespace
(
object
):
def
__init__
(
self
,
**
kwds
):
def
__init__
(
self
,
/
,
**
kwds
):
self
.
__dict__
.
update
(
kwds
)
self
.
__dict__
.
update
(
kwds
)
def
__repr__
(
self
):
def
__repr__
(
self
):
items
=
list
(
self
.
__dict__
.
items
())
items
=
list
(
self
.
__dict__
.
items
())
...
...
Lib/multiprocessing/managers.py
View file @
2085bd08
...
@@ -615,13 +615,10 @@ class BaseManager(object):
...
@@ -615,13 +615,10 @@ class BaseManager(object):
util
.
info
(
'manager serving at %r'
,
server
.
address
)
util
.
info
(
'manager serving at %r'
,
server
.
address
)
server
.
serve_forever
()
server
.
serve_forever
()
def
_create
(
*
args
,
**
kwds
):
def
_create
(
self
,
typeid
,
/
,
*
args
,
**
kwds
):
'''
'''
Create a new shared object; return the token and exposed tuple
Create a new shared object; return the token and exposed tuple
'''
'''
self
,
typeid
,
*
args
=
args
args
=
tuple
(
args
)
assert
self
.
_state
.
value
==
State
.
STARTED
,
'server not yet started'
assert
self
.
_state
.
value
==
State
.
STARTED
,
'server not yet started'
conn
=
self
.
_Client
(
self
.
_address
,
authkey
=
self
.
_authkey
)
conn
=
self
.
_Client
(
self
.
_address
,
authkey
=
self
.
_authkey
)
try
:
try
:
...
@@ -738,7 +735,7 @@ class BaseManager(object):
...
@@ -738,7 +735,7 @@ class BaseManager(object):
)
)
if
create_method
:
if
create_method
:
def
temp
(
self
,
*
args
,
**
kwds
):
def
temp
(
self
,
/
,
*
args
,
**
kwds
):
util
.
debug
(
'requesting creation of a shared %r object'
,
typeid
)
util
.
debug
(
'requesting creation of a shared %r object'
,
typeid
)
token
,
exp
=
self
.
_create
(
typeid
,
*
args
,
**
kwds
)
token
,
exp
=
self
.
_create
(
typeid
,
*
args
,
**
kwds
)
proxy
=
proxytype
(
proxy
=
proxytype
(
...
@@ -978,7 +975,7 @@ def MakeProxyType(name, exposed, _cache={}):
...
@@ -978,7 +975,7 @@ def MakeProxyType(name, exposed, _cache={}):
dic
=
{}
dic
=
{}
for
meth
in
exposed
:
for
meth
in
exposed
:
exec
(
'''def %s(self, *args, **kwds):
exec
(
'''def %s(self,
/,
*args, **kwds):
return self._callmethod(%r, args, kwds)'''
%
(
meth
,
meth
),
dic
)
return self._callmethod(%r, args, kwds)'''
%
(
meth
,
meth
),
dic
)
ProxyType
=
type
(
name
,
(
BaseProxy
,),
dic
)
ProxyType
=
type
(
name
,
(
BaseProxy
,),
dic
)
...
@@ -1017,7 +1014,7 @@ def AutoProxy(token, serializer, manager=None, authkey=None,
...
@@ -1017,7 +1014,7 @@ def AutoProxy(token, serializer, manager=None, authkey=None,
#
#
class
Namespace
(
object
):
class
Namespace
(
object
):
def
__init__
(
self
,
**
kwds
):
def
__init__
(
self
,
/
,
**
kwds
):
self
.
__dict__
.
update
(
kwds
)
self
.
__dict__
.
update
(
kwds
)
def
__repr__
(
self
):
def
__repr__
(
self
):
items
=
list
(
self
.
__dict__
.
items
())
items
=
list
(
self
.
__dict__
.
items
())
...
...
Lib/multiprocessing/pool.py
View file @
2085bd08
...
@@ -154,7 +154,7 @@ class _PoolCache(dict):
...
@@ -154,7 +154,7 @@ class _PoolCache(dict):
notification is done by the use of a queue that is provided when
notification is done by the use of a queue that is provided when
instantiating the cache.
instantiating the cache.
"""
"""
def
__init__
(
self
,
*
args
,
notifier
=
None
,
**
kwds
):
def
__init__
(
self
,
/
,
*
args
,
notifier
=
None
,
**
kwds
):
self
.
notifier
=
notifier
self
.
notifier
=
notifier
super
().
__init__
(
*
args
,
**
kwds
)
super
().
__init__
(
*
args
,
**
kwds
)
...
...
Lib/operator.py
View file @
2085bd08
...
@@ -302,15 +302,11 @@ class methodcaller:
...
@@ -302,15 +302,11 @@ class methodcaller:
"""
"""
__slots__
=
(
'_name'
,
'_args'
,
'_kwargs'
)
__slots__
=
(
'_name'
,
'_args'
,
'_kwargs'
)
def
__init__
(
*
args
,
**
kwargs
):
def
__init__
(
self
,
name
,
/
,
*
args
,
**
kwargs
):
if
len
(
args
)
<
2
:
self
.
_name
=
name
msg
=
"methodcaller needs at least one argument, the method name"
raise
TypeError
(
msg
)
self
=
args
[
0
]
self
.
_name
=
args
[
1
]
if
not
isinstance
(
self
.
_name
,
str
):
if
not
isinstance
(
self
.
_name
,
str
):
raise
TypeError
(
'method name must be a string'
)
raise
TypeError
(
'method name must be a string'
)
self
.
_args
=
args
[
2
:]
self
.
_args
=
args
self
.
_kwargs
=
kwargs
self
.
_kwargs
=
kwargs
def
__call__
(
self
,
obj
):
def
__call__
(
self
,
obj
):
...
...
Lib/random.py
View file @
2085bd08
...
@@ -100,7 +100,7 @@ class Random(_random.Random):
...
@@ -100,7 +100,7 @@ class Random(_random.Random):
self
.
seed
(
x
)
self
.
seed
(
x
)
self
.
gauss_next
=
None
self
.
gauss_next
=
None
def
__init_subclass__
(
cls
,
**
kwargs
):
def
__init_subclass__
(
cls
,
/
,
**
kwargs
):
"""Control how subclasses generate random integers.
"""Control how subclasses generate random integers.
The algorithm a subclass can use depends on the random() and/or
The algorithm a subclass can use depends on the random() and/or
...
...
Lib/string.py
View file @
2085bd08
...
@@ -52,6 +52,8 @@ def capwords(s, sep=None):
...
@@ -52,6 +52,8 @@ def capwords(s, sep=None):
import re as _re
import re as _re
from collections import ChainMap as _ChainMap
from collections import ChainMap as _ChainMap
_sentinel_dict = {}
class _TemplateMetaclass(type):
class _TemplateMetaclass(type):
pattern = r"""
pattern = r"""
%
(
delim
)
s
(
?
:
%
(
delim
)
s
(
?
:
...
@@ -104,19 +106,11 @@ class Template(metaclass=_TemplateMetaclass):
...
@@ -104,19 +106,11 @@ class Template(metaclass=_TemplateMetaclass):
raise ValueError('Invalid placeholder in string: line %d, col %d' %
raise ValueError('Invalid placeholder in string: line %d, col %d' %
(lineno, colno))
(lineno, colno))
def substitute(*args, **kws):
def substitute(self, mapping=_sentinel_dict, /, **kws):
if not args:
if mapping is _sentinel_dict:
raise TypeError("descriptor 'substitute' of 'Template' object "
"needs an argument")
self, *args = args # allow the "self" keyword be passed
if len(args) > 1:
raise TypeError('Too many positional arguments')
if not args:
mapping = kws
mapping = kws
elif kws:
elif kws:
mapping = _ChainMap(kws, args[0])
mapping = _ChainMap(kws, mapping)
else:
mapping = args[0]
# Helper function for .sub()
# Helper function for .sub()
def convert(mo):
def convert(mo):
# Check the most common path first.
# Check the most common path first.
...
@@ -131,19 +125,11 @@ class Template(metaclass=_TemplateMetaclass):
...
@@ -131,19 +125,11 @@ class Template(metaclass=_TemplateMetaclass):
self.pattern)
self.pattern)
return self.pattern.sub(convert, self.template)
return self.pattern.sub(convert, self.template)
def safe_substitute(*args, **kws):
def safe_substitute(self, mapping=_sentinel_dict, /, **kws):
if not args:
if mapping is _sentinel_dict:
raise TypeError("descriptor 'safe_substitute' of 'Template' object "
"needs an argument")
self, *args = args # allow the "self" keyword be passed
if len(args) > 1:
raise TypeError('Too many positional arguments')
if not args:
mapping = kws
mapping = kws
elif kws:
elif kws:
mapping = _ChainMap(kws, args[0])
mapping = _ChainMap(kws, mapping)
else:
mapping = args[0]
# Helper function for .sub()
# Helper function for .sub()
def convert(mo):
def convert(mo):
named = mo.group('named') or mo.group('braced')
named = mo.group('named') or mo.group('braced')
...
@@ -173,16 +159,7 @@ class Template(metaclass=_TemplateMetaclass):
...
@@ -173,16 +159,7 @@ class Template(metaclass=_TemplateMetaclass):
# The field name parser is implemented in _string.formatter_field_name_split
# The field name parser is implemented in _string.formatter_field_name_split
class Formatter:
class Formatter:
def format(*args, **kwargs):
def format(self, format_string, /, *args, **kwargs):
if not args:
raise TypeError("descriptor 'format' of 'Formatter' object "
"needs an argument")
self, *args = args # allow the "self" keyword be passed
try:
format_string, *args = args # allow the "format_string" keyword be passed
except ValueError:
raise TypeError("format() missing 1 required positional "
"argument: 'format_string'") from None
return self.vformat(format_string, args, kwargs)
return self.vformat(format_string, args, kwargs)
def vformat(self, format_string, args, kwargs):
def vformat(self, format_string, args, kwargs):
...
...
Lib/test/support/script_helper.py
View file @
2085bd08
...
@@ -137,7 +137,7 @@ def run_python_until_end(*args, **env_vars):
...
@@ -137,7 +137,7 @@ def run_python_until_end(*args, **env_vars):
err
=
strip_python_stderr
(
err
)
err
=
strip_python_stderr
(
err
)
return
_PythonRunResult
(
rc
,
out
,
err
),
cmd_line
return
_PythonRunResult
(
rc
,
out
,
err
),
cmd_line
def
_assert_python
(
expected_success
,
*
args
,
**
env_vars
):
def
_assert_python
(
expected_success
,
/
,
*
args
,
**
env_vars
):
res
,
cmd_line
=
run_python_until_end
(
*
args
,
**
env_vars
)
res
,
cmd_line
=
run_python_until_end
(
*
args
,
**
env_vars
)
if
(
res
.
rc
and
expected_success
)
or
(
not
res
.
rc
and
not
expected_success
):
if
(
res
.
rc
and
expected_success
)
or
(
not
res
.
rc
and
not
expected_success
):
res
.
fail
(
cmd_line
)
res
.
fail
(
cmd_line
)
...
...
Lib/typing.py
View file @
2085bd08
...
@@ -283,7 +283,7 @@ class _Final:
...
@@ -283,7 +283,7 @@ class _Final:
__slots__
=
(
'__weakref__'
,)
__slots__
=
(
'__weakref__'
,)
def
__init_subclass__
(
self
,
*
args
,
**
kwds
):
def
__init_subclass__
(
self
,
/
,
*
args
,
**
kwds
):
if
'_root'
not
in
kwds
:
if
'_root'
not
in
kwds
:
raise
TypeError
(
"Cannot subclass special typing classes"
)
raise
TypeError
(
"Cannot subclass special typing classes"
)
...
...
Lib/unittest/case.py
View file @
2085bd08
...
@@ -86,23 +86,10 @@ def _id(obj):
...
@@ -86,23 +86,10 @@ def _id(obj):
_module_cleanups
=
[]
_module_cleanups
=
[]
def
addModuleCleanup
(
*
args
,
**
kwargs
):
def
addModuleCleanup
(
function
,
/
,
*
args
,
**
kwargs
):
"""Same as addCleanup, except the cleanup items are called even if
"""Same as addCleanup, except the cleanup items are called even if
setUpModule fails (unlike tearDownModule)."""
setUpModule fails (unlike tearDownModule)."""
if
args
:
function
,
*
args
=
args
elif
'function'
in
kwargs
:
function
=
kwargs
.
pop
(
'function'
)
import
warnings
warnings
.
warn
(
"Passing 'function' as keyword argument is deprecated"
,
DeprecationWarning
,
stacklevel
=
2
)
else
:
raise
TypeError
(
'addModuleCleanup expected at least 1 positional '
'argument, got %d'
%
(
len
(
args
)
-
1
))
args
=
tuple
(
args
)
_module_cleanups
.
append
((
function
,
args
,
kwargs
))
_module_cleanups
.
append
((
function
,
args
,
kwargs
))
addModuleCleanup
.
__text_signature__
=
'(function, /, *args, **kwargs)'
def
doModuleCleanups
():
def
doModuleCleanups
():
...
@@ -501,22 +488,11 @@ class TestCase(object):
...
@@ -501,22 +488,11 @@ class TestCase(object):
self
.
_cleanups
.
append
((
function
,
args
,
kwargs
))
self
.
_cleanups
.
append
((
function
,
args
,
kwargs
))
addCleanup
.
__text_signature__
=
'($self, function, /, *args, **kwargs)'
addCleanup
.
__text_signature__
=
'($self, function, /, *args, **kwargs)'
def
addClassCleanup
(
*
args
,
**
kwargs
):
@
classmethod
def
addClassCleanup
(
cls
,
function
,
/
,
*
args
,
**
kwargs
):
"""Same as addCleanup, except the cleanup items are called even if
"""Same as addCleanup, except the cleanup items are called even if
setUpClass fails (unlike tearDownClass)."""
setUpClass fails (unlike tearDownClass)."""
if
len
(
args
)
>=
2
:
cls
,
function
,
*
args
=
args
elif
not
args
:
raise
TypeError
(
"descriptor 'addClassCleanup' of 'TestCase' object "
"needs an argument"
)
else
:
raise
TypeError
(
'addClassCleanup expected at least 1 positional '
'argument, got %d'
%
(
len
(
args
)
-
1
))
args
=
tuple
(
args
)
cls
.
_class_cleanups
.
append
((
function
,
args
,
kwargs
))
cls
.
_class_cleanups
.
append
((
function
,
args
,
kwargs
))
addClassCleanup
.
__text_signature__
=
'($cls, function, /, *args, **kwargs)'
addClassCleanup
=
classmethod
(
addClassCleanup
)
def
setUp
(
self
):
def
setUp
(
self
):
"Hook method for setting up the test fixture before exercising it."
"Hook method for setting up the test fixture before exercising it."
...
...
Lib/unittest/mock.py
View file @
2085bd08
This diff is collapsed.
Click to expand it.
Lib/unittest/test/test_runner.py
View file @
2085bd08
...
@@ -410,14 +410,13 @@ class TestModuleCleanUp(unittest.TestCase):
...
@@ -410,14 +410,13 @@ class TestModuleCleanUp(unittest.TestCase):
class
Module
(
object
):
class
Module
(
object
):
unittest
.
addModuleCleanup
(
cleanup
,
1
,
2
,
function
=
'hello'
)
unittest
.
addModuleCleanup
(
cleanup
,
1
,
2
,
function
=
'hello'
)
with
self
.
assert
Warns
(
DeprecationWarning
):
with
self
.
assert
Raises
(
TypeError
):
unittest
.
addModuleCleanup
(
function
=
cleanup
,
arg
=
'hello'
)
unittest
.
addModuleCleanup
(
function
=
cleanup
,
arg
=
'hello'
)
with
self
.
assertRaises
(
TypeError
):
with
self
.
assertRaises
(
TypeError
):
unittest
.
addModuleCleanup
()
unittest
.
addModuleCleanup
()
unittest
.
case
.
doModuleCleanups
()
unittest
.
case
.
doModuleCleanups
()
self
.
assertEqual
(
cleanups
,
self
.
assertEqual
(
cleanups
,
[((),
{
'arg'
:
'hello'
}),
[((
1
,
2
),
{
'function'
:
'hello'
})])
((
1
,
2
),
{
'function'
:
'hello'
})])
def
test_run_module_cleanUp
(
self
):
def
test_run_module_cleanUp
(
self
):
blowUp
=
True
blowUp
=
True
...
...
Lib/weakref.py
View file @
2085bd08
...
@@ -99,13 +99,7 @@ class WeakValueDictionary(_collections_abc.MutableMapping):
...
@@ -99,13 +99,7 @@ class WeakValueDictionary(_collections_abc.MutableMapping):
# objects are unwrapped on the way out, and we always wrap on the
# objects are unwrapped on the way out, and we always wrap on the
# way in).
# way in).
def
__init__
(
*
args
,
**
kw
):
def
__init__
(
self
,
other
=
(),
/
,
**
kw
):
if
not
args
:
raise
TypeError
(
"descriptor '__init__' of 'WeakValueDictionary' "
"object needs an argument"
)
self
,
*
args
=
args
if
len
(
args
)
>
1
:
raise
TypeError
(
'expected at most 1 arguments, got %d'
%
len
(
args
))
def
remove
(
wr
,
selfref
=
ref
(
self
),
_atomic_removal
=
_remove_dead_weakref
):
def
remove
(
wr
,
selfref
=
ref
(
self
),
_atomic_removal
=
_remove_dead_weakref
):
self
=
selfref
()
self
=
selfref
()
if
self
is
not
None
:
if
self
is
not
None
:
...
@@ -120,7 +114,7 @@ class WeakValueDictionary(_collections_abc.MutableMapping):
...
@@ -120,7 +114,7 @@ class WeakValueDictionary(_collections_abc.MutableMapping):
self
.
_pending_removals
=
[]
self
.
_pending_removals
=
[]
self
.
_iterating
=
set
()
self
.
_iterating
=
set
()
self
.
data
=
d
=
{}
self
.
data
=
d
=
{}
self
.
update
(
*
args
,
**
kw
)
self
.
update
(
other
,
**
kw
)
def
_commit_removals
(
self
):
def
_commit_removals
(
self
):
l
=
self
.
_pending_removals
l
=
self
.
_pending_removals
...
@@ -287,24 +281,17 @@ class WeakValueDictionary(_collections_abc.MutableMapping):
...
@@ -287,24 +281,17 @@ class WeakValueDictionary(_collections_abc.MutableMapping):
else
:
else
:
return
o
return
o
def
update
(
*
args
,
**
kwargs
):
def
update
(
self
,
other
=
None
,
/
,
**
kwargs
):
if
not
args
:
raise
TypeError
(
"descriptor 'update' of 'WeakValueDictionary' "
"object needs an argument"
)
self
,
*
args
=
args
if
len
(
args
)
>
1
:
raise
TypeError
(
'expected at most 1 arguments, got %d'
%
len
(
args
))
dict
=
args
[
0
]
if
args
else
None
if
self
.
_pending_removals
:
if
self
.
_pending_removals
:
self
.
_commit_removals
()
self
.
_commit_removals
()
d
=
self
.
data
d
=
self
.
data
if
dict
is
not
None
:
if
other
is
not
None
:
if
not
hasattr
(
dict
,
"items"
):
if
not
hasattr
(
other
,
"items"
):
dict
=
type
({})(
dict
)
other
=
dict
(
other
)
for
key
,
o
in
dict
.
items
():
for
key
,
o
in
other
.
items
():
d
[
key
]
=
KeyedRef
(
o
,
self
.
_remove
,
key
)
d
[
key
]
=
KeyedRef
(
o
,
self
.
_remove
,
key
)
if
len
(
kwargs
):
for
key
,
o
in
kwargs
.
items
(
):
self
.
update
(
kwargs
)
d
[
key
]
=
KeyedRef
(
o
,
self
.
_remove
,
key
)
def
valuerefs
(
self
):
def
valuerefs
(
self
):
"""Return a list of weak references to the values.
"""Return a list of weak references to the values.
...
@@ -488,7 +475,7 @@ class WeakKeyDictionary(_collections_abc.MutableMapping):
...
@@ -488,7 +475,7 @@ class WeakKeyDictionary(_collections_abc.MutableMapping):
def
setdefault
(
self
,
key
,
default
=
None
):
def
setdefault
(
self
,
key
,
default
=
None
):
return
self
.
data
.
setdefault
(
ref
(
key
,
self
.
_remove
),
default
)
return
self
.
data
.
setdefault
(
ref
(
key
,
self
.
_remove
),
default
)
def
update
(
self
,
dict
=
None
,
**
kwargs
):
def
update
(
self
,
dict
=
None
,
/
,
**
kwargs
):
d
=
self
.
data
d
=
self
.
data
if
dict
is
not
None
:
if
dict
is
not
None
:
if
not
hasattr
(
dict
,
"items"
):
if
not
hasattr
(
dict
,
"items"
):
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment