From: Zac Medico Date: Tue, 22 Sep 2009 20:43:34 +0000 (-0000) Subject: Replace dict.keys() usage with __iter__(), since it behaves identically in X-Git-Tag: v2.2_rc42~42 X-Git-Url: http://git.tremily.us/?a=commitdiff_plain;h=151192525a264e4bfdf92aee215045a5aaecab33;p=portage.git Replace dict.keys() usage with __iter__(), since it behaves identically in both python 2.x and 3.x. svn path=/main/trunk/; revision=14382 --- diff --git a/pym/portage/cache/mappings.py b/pym/portage/cache/mappings.py index b777ed1d0..a6c111897 100644 --- a/pym/portage/cache/mappings.py +++ b/pym/portage/cache/mappings.py @@ -226,9 +226,9 @@ class ProtectedDict(MutableMapping): def __iter__(self): - for k in self.new.keys(): + for k in self.new: yield k - for k in self.orig.keys(): + for k in self.orig: if k not in self.blacklist and k not in self.new: yield k diff --git a/pym/portage/cache/template.py b/pym/portage/cache/template.py index 9e779520b..3b003b1f6 100644 --- a/pym/portage/cache/template.py +++ b/pym/portage/cache/template.py @@ -68,8 +68,8 @@ class database(object): raise cache_errors.ReadOnlyRestriction() if self.cleanse_keys: d=ProtectedDict(values) - for k in list(d.keys()): - if d[k] == '': + for k, v in list(d.items()): + if not v: del d[k] if self.serialize_eclasses and "_eclasses_" in values: d["_eclasses_"] = serialize_eclasses(d["_eclasses_"]) @@ -110,13 +110,13 @@ class database(object): return cpv in self def keys(self): - return tuple(self.keys()) + return list(self) def iterkeys(self): return iter(self) def iteritems(self): - for x in self.keys(): + for x in self: yield (x, self[x]) def items(self): @@ -182,7 +182,7 @@ class database(object): if key not in self.__known_keys: raise InvalidRestriction(key, match, "Key isn't valid") - for cpv in self.keys(): + for cpv in self: cont = True vals = self[cpv] for key, match in restricts.items():