diff options
author | Raymond Hettinger <python@rcn.com> | 2015-08-30 16:15:36 (GMT) |
---|---|---|
committer | Raymond Hettinger <python@rcn.com> | 2015-08-30 16:15:36 (GMT) |
commit | 9157545c1179045dda9d3c23961a971d838afa3a (patch) | |
tree | 5f90ae18edb1e9d1ae563e1c57fb598a26fe4f6b | |
parent | ce50802679bd4742f604c92775cd4f6b448769ea (diff) | |
parent | 7a3602e7cf1c0f54d52c563afca50c2e09e7bbf9 (diff) | |
download | cpython-9157545c1179045dda9d3c23961a971d838afa3a.zip cpython-9157545c1179045dda9d3c23961a971d838afa3a.tar.gz cpython-9157545c1179045dda9d3c23961a971d838afa3a.tar.bz2 |
merge
-rw-r--r-- | Doc/library/collections.rst | 6 | ||||
-rw-r--r-- | Lib/collections/__init__.py | 11 | ||||
-rw-r--r-- | Lib/test/test_collections.py | 12 |
3 files changed, 15 insertions, 14 deletions
diff --git a/Doc/library/collections.rst b/Doc/library/collections.rst index f2befe7..60e8fe8 100644 --- a/Doc/library/collections.rst +++ b/Doc/library/collections.rst @@ -842,10 +842,10 @@ field names, the method and attribute names start with an underscore. .. method:: somenamedtuple._asdict() Return a new :class:`OrderedDict` which maps field names to their corresponding - values. Note, this method is no longer needed now that the same effect can - be achieved by using the built-in :func:`vars` function:: + values:: - >>> vars(p) + >>> p = Point(x=11, y=22) + >>> p._asdict() OrderedDict([('x', 11), ('y', 22)]) .. versionchanged:: 3.1 diff --git a/Lib/collections/__init__.py b/Lib/collections/__init__.py index 80dc4f6..26e5d34 100644 --- a/Lib/collections/__init__.py +++ b/Lib/collections/__init__.py @@ -320,23 +320,14 @@ class {typename}(tuple): 'Return a nicely formatted representation string' return self.__class__.__name__ + '({repr_fmt})' % self - @property - def __dict__(self): - 'A new OrderedDict mapping field names to their values' - return OrderedDict(zip(self._fields, self)) - def _asdict(self): 'Return a new OrderedDict which maps field names to their values.' - return self.__dict__ + return OrderedDict(zip(self._fields, self)) def __getnewargs__(self): 'Return self as a plain tuple. Used by copy and pickle.' return tuple(self) - def __getstate__(self): - 'Exclude the OrderedDict from pickling' - return None - {field_defs} """ diff --git a/Lib/test/test_collections.py b/Lib/test/test_collections.py index c2d03ee..4124f91 100644 --- a/Lib/test/test_collections.py +++ b/Lib/test/test_collections.py @@ -257,7 +257,6 @@ class TestNamedTuple(unittest.TestCase): self.assertEqual(p._fields, ('x', 'y')) # test _fields attribute self.assertEqual(p._replace(x=1), (1, 22)) # test _replace method self.assertEqual(p._asdict(), dict(x=11, y=22)) # test _asdict method - self.assertEqual(vars(p), p._asdict()) # verify that vars() works try: p._replace(x=1, error=2) @@ -412,6 +411,17 @@ class TestNamedTuple(unittest.TestCase): globals().pop('NTColor', None) # clean-up after this test + def test_namedtuple_subclass_issue_24931(self): + class Point(namedtuple('_Point', ['x', 'y'])): + pass + + a = Point(3, 4) + self.assertEqual(a._asdict(), OrderedDict([('x', 3), ('y', 4)])) + + a.w = 5 + self.assertEqual(a.__dict__, {'w': 5}) + + ################################################################################ ### Abstract Base Classes ################################################################################ |