From: Zac Medico Date: Wed, 11 Mar 2009 06:47:20 +0000 (-0000) Subject: Fix an issue with incomplete deepcopy of _LazyItem instances inside X-Git-Tag: v2.1.6.8~56 X-Git-Url: http://git.tremily.us/?a=commitdiff_plain;h=20f35402b633e10bd015df25ae517275f05833ed;p=portage.git Fix an issue with incomplete deepcopy of _LazyItem instances inside LazyItemsDict.__deepcopy__(). Thanks to Arfrever for reporting. (trunk r12777) svn path=/main/branches/2.1.6/; revision=13021 --- 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))