diff options
author | Zac Medico <zmedico@gentoo.org> | 2009-03-07 21:34:50 +0000 |
---|---|---|
committer | Zac Medico <zmedico@gentoo.org> | 2009-03-07 21:34:50 +0000 |
commit | 3bb82f58811fc635c24439e4addbee8412bf7d26 (patch) | |
tree | 488250dbb3cc9091a1abbfc724b2f48b547ed540 | |
parent | 8a69acd8ba05b91d111f4a22b25065fcfc42fc23 (diff) | |
download | portage-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
-rw-r--r-- | pym/portage/util.py | 11 |
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)) |