diff options
author | Bar Harel <bzvi7919@gmail.com> | 2019-05-19 16:57:13 +0300 |
---|---|---|
committer | Serhiy Storchaka <storchaka@gmail.com> | 2019-05-19 16:57:13 +0300 |
commit | f4e1babf44792bdeb0c01da96821ba0800a51fd8 (patch) | |
tree | bc551ef155b52026cee8408766e7259f06024b45 /Lib/collections | |
parent | bpo-36948: Fix NameError in urllib.request.URLopener.retrieve (GH-13389) (diff) | |
download | cpython-f4e1babf44792bdeb0c01da96821ba0800a51fd8.tar.gz cpython-f4e1babf44792bdeb0c01da96821ba0800a51fd8.tar.bz2 cpython-f4e1babf44792bdeb0c01da96821ba0800a51fd8.zip |
bpo-27141: Fix collections.UserList and UserDict shallow copy. (GH-4094)
Diffstat (limited to 'Lib/collections')
-rw-r--r-- | Lib/collections/__init__.py | 14 |
1 files changed, 14 insertions, 0 deletions
diff --git a/Lib/collections/__init__.py b/Lib/collections/__init__.py index 706907ad4a2..960d82a5dcf 100644 --- a/Lib/collections/__init__.py +++ b/Lib/collections/__init__.py @@ -1038,6 +1038,13 @@ class UserDict(_collections_abc.MutableMapping): # Now, add the methods in dicts but not in MutableMapping def __repr__(self): return repr(self.data) + def __copy__(self): + inst = self.__class__.__new__(self.__class__) + inst.__dict__.update(self.__dict__) + # Create a copy and avoid triggering descriptors + inst.__dict__["data"] = self.__dict__["data"].copy() + return inst + def copy(self): if self.__class__ is UserDict: return UserDict(self.data.copy()) @@ -1050,6 +1057,7 @@ class UserDict(_collections_abc.MutableMapping): self.data = data c.update(self) return c + @classmethod def fromkeys(cls, iterable, value=None): d = cls() @@ -1118,6 +1126,12 @@ class UserList(_collections_abc.MutableSequence): def __imul__(self, n): self.data *= n return self + def __copy__(self): + inst = self.__class__.__new__(self.__class__) + inst.__dict__.update(self.__dict__) + # Create a copy and avoid triggering descriptors + inst.__dict__["data"] = self.__dict__["data"][:] + return inst def append(self, item): self.data.append(item) def insert(self, i, item): self.data.insert(i, item) def pop(self, i=-1): return self.data.pop(i) |