summaryrefslogtreecommitdiffstats
path: root/pym
diff options
context:
space:
mode:
authorZac Medico <zmedico@gentoo.org>2009-03-07 21:34:50 +0000
committerZac Medico <zmedico@gentoo.org>2009-03-07 21:34:50 +0000
commit3bb82f58811fc635c24439e4addbee8412bf7d26 (patch)
tree488250dbb3cc9091a1abbfc724b2f48b547ed540 /pym
parent8a69acd8ba05b91d111f4a22b25065fcfc42fc23 (diff)
downloadportage-3bb82f58811fc635c24439e4addbee8412bf7d26.tar.gz
portage-3bb82f58811fc635c24439e4addbee8412bf7d26.tar.bz2
portage-3bb82f58811fc635c24439e4addbee8412bf7d26.zip
Fix an issue with incomplete deepcopy of _LazyItem instances inside
LazyItemsDict.__deepcopy__(). Thanks to Arfrever for reporting. svn path=/main/trunk/; revision=12777
Diffstat (limited to 'pym')
-rw-r--r--pym/portage/util.py11
1 files changed, 3 insertions, 8 deletions
diff --git a/pym/portage/util.py b/pym/portage/util.py
index c84f351be..c55da0366 100644
--- a/pym/portage/util.py
+++ b/pym/portage/util.py
@@ -1170,17 +1170,12 @@ class LazyItemsDict(dict):
memo[id(self)] = result
for k in self:
k_copy = deepcopy(k, memo)
- if k in self.lazy_items:
+ if k in list(self.lazy_items):
lazy_item = self.lazy_items[k]
- try:
- result.lazy_items[k_copy] = deepcopy(lazy_item, memo)
- except TypeError:
- # If deepcopy fails for a lazy singleton, try to
- # evaluate the singleton and deepcopy the result.
- if not lazy_item.singleton:
- raise
+ if lazy_item.singleton:
dict.__setitem__(result, k_copy, deepcopy(self[k], memo))
else:
+ result.lazy_items[k_copy] = deepcopy(lazy_item, memo)
dict.__setitem__(result, k_copy, None)
else:
dict.__setitem__(result, k_copy, deepcopy(self[k], memo))