summaryrefslogtreecommitdiffstats
path: root/ipapython/ipautil.py
diff options
context:
space:
mode:
authorPetr Viktorin <pviktori@redhat.com>2015-08-11 13:51:14 +0200
committerJan Cholasta <jcholast@redhat.com>2015-09-01 11:42:01 +0200
commit3bf91eab25c602a6fad2665456f57e8629c5a6f4 (patch)
tree52f713e898a385d57a914d539a7da9a20fc20166 /ipapython/ipautil.py
parentdd16cc98b0d67f1448bf9de25f8adce512b1431c (diff)
downloadfreeipa-3bf91eab25c602a6fad2665456f57e8629c5a6f4.tar.gz
freeipa-3bf91eab25c602a6fad2665456f57e8629c5a6f4.tar.xz
freeipa-3bf91eab25c602a6fad2665456f57e8629c5a6f4.zip
Use Python3-compatible dict method names
Python 2 has keys()/values()/items(), which return lists, iterkeys()/itervalues()/iteritems(), which return iterators, and viewkeys()/viewvalues()/viewitems() which return views. Python 3 has only keys()/values()/items(), which return views. To get iterators, one can use iter() or a for loop/comprehension; for lists there's the list() constructor. When iterating through the entire dict, without modifying the dict, the difference between Python 2's items() and iteritems() is negligible, especially on small dicts (the main overhead is extra memory, not CPU time). In the interest of simpler code, this patch changes many instances of iteritems() to items(), iterkeys() to keys() etc. In other cases, helpers like six.itervalues are used. Reviewed-By: Christian Heimes <cheimes@redhat.com> Reviewed-By: Jan Cholasta <jcholast@redhat.com>
Diffstat (limited to 'ipapython/ipautil.py')
-rw-r--r--ipapython/ipautil.py29
1 files changed, 19 insertions, 10 deletions
diff --git a/ipapython/ipautil.py b/ipapython/ipautil.py
index 80ce83506..b6cbe50e9 100644
--- a/ipapython/ipautil.py
+++ b/ipapython/ipautil.py
@@ -545,13 +545,13 @@ class CIDict(dict):
for key in keys():
self.__setitem__(key, new[key], seen)
seen = set()
- for key, value in kwargs.iteritems():
+ for key, value in kwargs.items():
self.__setitem__(key, value, seen)
def __contains__(self, key):
return super(CIDict, self).__contains__(key.lower())
- if sys.version_info < (3, 0):
+ if six.PY2:
def has_key(self, key):
return super(CIDict, self).has_key(key.lower())
@@ -562,29 +562,38 @@ class CIDict(dict):
return failobj
def __iter__(self):
- return self._keys.itervalues()
+ return six.itervalues(self._keys)
def keys(self):
- return list(self.iterkeys())
+ if six.PY2:
+ return list(self.iterkeys())
+ else:
+ return self.iterkeys()
def items(self):
- return list(self.iteritems())
+ if six.PY2:
+ return list(self.iteritems())
+ else:
+ return self.iteritems()
def values(self):
- return list(self.itervalues())
+ if six.PY2:
+ return list(self.itervalues())
+ else:
+ return self.itervalues()
def copy(self):
"""Returns a shallow copy of this CIDict"""
- return CIDict(self.items())
+ return CIDict(list(self.items()))
def iteritems(self):
- return ((k, self[k]) for k in self._keys.itervalues())
+ return ((k, self[k]) for k in six.itervalues(self._keys))
def iterkeys(self):
- return self._keys.itervalues()
+ return six.itervalues(self._keys)
def itervalues(self):
- return (v for k, v in self.iteritems())
+ return (v for k, v in six.iteritems(self))
def setdefault(self, key, value=None):
try: