Fixed #20989 -- Removed explicit list comprehension inside dict() and tuple()

Thanks jeroen.pulles at redslider.net for the suggestion and
helper script.
This commit is contained in:
Tim Graham 2013-08-29 12:09:35 -04:00
parent f19a3669b8
commit c7d0ff0cad
23 changed files with 38 additions and 38 deletions

View File

@ -95,7 +95,7 @@ def load_hashers(password_hashers=None):
raise ImproperlyConfigured("hasher doesn't specify an " raise ImproperlyConfigured("hasher doesn't specify an "
"algorithm name: %s" % backend) "algorithm name: %s" % backend)
hashers.append(hasher) hashers.append(hasher)
HASHERS = dict([(hasher.algorithm, hasher) for hasher in hashers]) HASHERS = dict((hasher.algorithm, hasher) for hasher in hashers)
PREFERRED_HASHER = hashers[0] PREFERRED_HASHER = hashers[0]

View File

@ -191,4 +191,4 @@ OGRFieldTypes = { 0 : OFTInteger,
10 : OFTTime, 10 : OFTTime,
11 : OFTDateTime, 11 : OFTDateTime,
} }
ROGRFieldTypes = dict([(cls, num) for num, cls in OGRFieldTypes.items()]) ROGRFieldTypes = dict((cls, num) for num, cls in OGRFieldTypes.items())

View File

@ -28,7 +28,7 @@ class OGRGeomType(object):
7 + wkb25bit : 'GeometryCollection25D', 7 + wkb25bit : 'GeometryCollection25D',
} }
# Reverse type dictionary, keyed by lower-case of the name. # Reverse type dictionary, keyed by lower-case of the name.
_str_types = dict([(v.lower(), k) for k, v in _types.items()]) _str_types = dict((v.lower(), k) for k, v in _types.items())
def __init__(self, type_input): def __init__(self, type_input):
"Figures out the correct OGR Type based upon the input." "Figures out the correct OGR Type based upon the input."

View File

@ -84,7 +84,7 @@ def gdal_version_info():
ver = gdal_version().decode() ver = gdal_version().decode()
m = version_regex.match(ver) m = version_regex.match(ver)
if not m: raise OGRException('Could not parse GDAL version string "%s"' % ver) if not m: raise OGRException('Could not parse GDAL version string "%s"' % ver)
return dict([(key, m.group(key)) for key in ('major', 'minor', 'subminor')]) return dict((key, m.group(key)) for key in ('major', 'minor', 'subminor'))
_verinfo = gdal_version_info() _verinfo = gdal_version_info()
GDAL_MAJOR_VERSION = int(_verinfo['major']) GDAL_MAJOR_VERSION = int(_verinfo['major'])

View File

@ -20,13 +20,13 @@ TEST_DATA = os.path.join(os.path.dirname(upath(gis.__file__)), 'tests', 'data')
def tuplize(seq): def tuplize(seq):
"Turn all nested sequences to tuples in given sequence." "Turn all nested sequences to tuples in given sequence."
if isinstance(seq, (list, tuple)): if isinstance(seq, (list, tuple)):
return tuple([tuplize(i) for i in seq]) return tuple(tuplize(i) for i in seq)
return seq return seq
def strconvert(d): def strconvert(d):
"Converts all keys in dictionary to str type." "Converts all keys in dictionary to str type."
return dict([(str(k), v) for k, v in six.iteritems(d)]) return dict((str(k), v) for k, v in six.iteritems(d))
def get_ds_file(name, ext): def get_ds_file(name, ext):

View File

@ -87,7 +87,7 @@ class GeometryCollection(GEOSGeometry):
@property @property
def tuple(self): def tuple(self):
"Returns a tuple of all the coordinates in this Geometry Collection" "Returns a tuple of all the coordinates in this Geometry Collection"
return tuple([g.tuple for g in self]) return tuple(g.tuple for g in self)
coords = tuple coords = tuple
# MultiPoint, MultiLineString, and MultiPolygon class definitions. # MultiPoint, MultiLineString, and MultiPolygon class definitions.

View File

@ -81,7 +81,7 @@ class Command(LabelCommand):
raise CommandError('GDAL is required to inspect geospatial data sources.') raise CommandError('GDAL is required to inspect geospatial data sources.')
# Removing options with `None` values. # Removing options with `None` values.
options = dict([(k, v) for k, v in options.items() if not v is None]) options = dict((k, v) for k, v in options.items() if not v is None)
# Getting the OGR DataSource from the string parameter. # Getting the OGR DataSource from the string parameter.
try: try:
@ -110,7 +110,7 @@ class Command(LabelCommand):
mapping_dict = mapping(ds, **kwargs) mapping_dict = mapping(ds, **kwargs)
# This extra legwork is so that the dictionary definition comes # This extra legwork is so that the dictionary definition comes
# out in the same order as the fields in the model definition. # out in the same order as the fields in the model definition.
rev_mapping = dict([(v, k) for k, v in mapping_dict.items()]) rev_mapping = dict((v, k) for k, v in mapping_dict.items())
output.extend(['', '# Auto-generated `LayerMapping` dictionary for %s model' % model_name, output.extend(['', '# Auto-generated `LayerMapping` dictionary for %s model' % model_name,
'%s_mapping = {' % model_name.lower()]) '%s_mapping = {' % model_name.lower()])
output.extend([" '%s' : '%s'," % (rev_mapping[ogr_fld], ogr_fld) for ogr_fld in ds[options['layer_key']].fields]) output.extend([" '%s' : '%s'," % (rev_mapping[ogr_fld], ogr_fld) for ogr_fld in ds[options['layer_key']].fields])

View File

@ -292,7 +292,7 @@ class Distance(MeasureBase):
'Yard (Indian)' : 'indian_yd', 'Yard (Indian)' : 'indian_yd',
'Yard (Sears)' : 'sears_yd' 'Yard (Sears)' : 'sears_yd'
} }
LALIAS = dict([(k.lower(), v) for k, v in ALIAS.items()]) LALIAS = dict((k.lower(), v) for k, v in ALIAS.items())
def __mul__(self, other): def __mul__(self, other):
if isinstance(other, self.__class__): if isinstance(other, self.__class__):
@ -310,9 +310,9 @@ class Distance(MeasureBase):
class Area(MeasureBase): class Area(MeasureBase):
STANDARD_UNIT = AREA_PREFIX + Distance.STANDARD_UNIT STANDARD_UNIT = AREA_PREFIX + Distance.STANDARD_UNIT
# Getting the square units values and the alias dictionary. # Getting the square units values and the alias dictionary.
UNITS = dict([('%s%s' % (AREA_PREFIX, k), v ** 2) for k, v in Distance.UNITS.items()]) UNITS = dict(('%s%s' % (AREA_PREFIX, k), v ** 2) for k, v in Distance.UNITS.items())
ALIAS = dict([(k, '%s%s' % (AREA_PREFIX, v)) for k, v in Distance.ALIAS.items()]) ALIAS = dict((k, '%s%s' % (AREA_PREFIX, v)) for k, v in Distance.ALIAS.items())
LALIAS = dict([(k.lower(), v) for k, v in ALIAS.items()]) LALIAS = dict((k.lower(), v) for k, v in ALIAS.items())
def __truediv__(self, other): def __truediv__(self, other):
if isinstance(other, NUMERIC_TYPES): if isinstance(other, NUMERIC_TYPES):

View File

@ -99,7 +99,7 @@ def get_commands():
""" """
global _commands global _commands
if _commands is None: if _commands is None:
_commands = dict([(name, 'django.core') for name in find_commands(__path__[0])]) _commands = dict((name, 'django.core') for name in find_commands(__path__[0]))
# Find the installed apps # Find the installed apps
from django.conf import settings from django.conf import settings

View File

@ -537,4 +537,4 @@ class DatabaseWrapper(BaseDatabaseWrapper):
match = server_version_re.match(server_info) match = server_version_re.match(server_info)
if not match: if not match:
raise Exception('Unable to determine MySQL version from version string %r' % server_info) raise Exception('Unable to determine MySQL version from version string %r' % server_info)
return tuple([int(x) for x in match.groups()]) return tuple(int(x) for x in match.groups())

View File

@ -773,7 +773,7 @@ class FormatStylePlaceholderCursor(object):
try: try:
return dict((k, OracleParam(v, self, True)) for k, v in params.items()) return dict((k, OracleParam(v, self, True)) for k, v in params.items())
except AttributeError: except AttributeError:
return tuple([OracleParam(p, self, True) for p in params]) return tuple(OracleParam(p, self, True) for p in params)
def _guess_input_sizes(self, params_list): def _guess_input_sizes(self, params_list):
# Try dict handling; if that fails, treat as sequence # Try dict handling; if that fails, treat as sequence

View File

@ -139,7 +139,7 @@ class DatabaseIntrospection(BaseDatabaseIntrospection):
continue continue
# This will append (column_name, referenced_table_name, referenced_column_name) to key_columns # This will append (column_name, referenced_table_name, referenced_column_name) to key_columns
key_columns.append(tuple([s.strip('"') for s in m.groups()])) key_columns.append(tuple(s.strip('"') for s in m.groups()))
return key_columns return key_columns

View File

@ -227,7 +227,7 @@ class SingleRelatedObjectDescriptor(six.with_metaclass(RenameRelatedObjectDescri
if not router.allow_relation(value, instance): if not router.allow_relation(value, instance):
raise ValueError('Cannot assign "%r": the current database router prevents this relation.' % value) raise ValueError('Cannot assign "%r": the current database router prevents this relation.' % value)
related_pk = tuple([getattr(instance, field.attname) for field in self.related.field.foreign_related_fields]) related_pk = tuple(getattr(instance, field.attname) for field in self.related.field.foreign_related_fields)
if None in related_pk: if None in related_pk:
raise ValueError('Cannot assign "%r": "%s" instance isn\'t saved in the database.' % raise ValueError('Cannot assign "%r": "%s" instance isn\'t saved in the database.' %
(value, instance._meta.object_name)) (value, instance._meta.object_name))
@ -541,8 +541,8 @@ def create_many_related_manager(superclass, rel):
('_prefetch_related_val_%s' % f.attname, ('_prefetch_related_val_%s' % f.attname,
'%s.%s' % (qn(join_table), qn(f.column))) for f in fk.local_related_fields)) '%s.%s' % (qn(join_table), qn(f.column))) for f in fk.local_related_fields))
return (qs, return (qs,
lambda result: tuple([getattr(result, '_prefetch_related_val_%s' % f.attname) for f in fk.local_related_fields]), lambda result: tuple(getattr(result, '_prefetch_related_val_%s' % f.attname) for f in fk.local_related_fields),
lambda inst: tuple([getattr(inst, f.attname) for f in fk.foreign_related_fields]), lambda inst: tuple(getattr(inst, f.attname) for f in fk.foreign_related_fields),
False, False,
self.prefetch_cache_name) self.prefetch_cache_name)
@ -964,11 +964,11 @@ class ForeignObject(RelatedField):
@property @property
def local_related_fields(self): def local_related_fields(self):
return tuple([lhs_field for lhs_field, rhs_field in self.related_fields]) return tuple(lhs_field for lhs_field, rhs_field in self.related_fields)
@property @property
def foreign_related_fields(self): def foreign_related_fields(self):
return tuple([rhs_field for lhs_field, rhs_field in self.related_fields]) return tuple(rhs_field for lhs_field, rhs_field in self.related_fields)
def get_local_related_value(self, instance): def get_local_related_value(self, instance):
return self.get_instance_value_for_fields(instance, self.local_related_fields) return self.get_instance_value_for_fields(instance, self.local_related_fields)
@ -998,7 +998,7 @@ class ForeignObject(RelatedField):
def get_joining_columns(self, reverse_join=False): def get_joining_columns(self, reverse_join=False):
source = self.reverse_related_fields if reverse_join else self.related_fields source = self.reverse_related_fields if reverse_join else self.related_fields
return tuple([(lhs_field.column, rhs_field.column) for lhs_field, rhs_field in source]) return tuple((lhs_field.column, rhs_field.column) for lhs_field, rhs_field in source)
def get_reverse_joining_columns(self): def get_reverse_joining_columns(self):
return self.get_joining_columns(reverse_join=True) return self.get_joining_columns(reverse_join=True)
@ -1105,10 +1105,10 @@ class ForeignObject(RelatedField):
@property @property
def attnames(self): def attnames(self):
return tuple([field.attname for field in self.local_related_fields]) return tuple(field.attname for field in self.local_related_fields)
def get_defaults(self): def get_defaults(self):
return tuple([field.get_default() for field in self.local_related_fields]) return tuple(field.get_default() for field in self.local_related_fields)
def contribute_to_class(self, cls, name, virtual_only=False): def contribute_to_class(self, cls, name, virtual_only=False):
super(ForeignObject, self).contribute_to_class(cls, name, virtual_only=virtual_only) super(ForeignObject, self).contribute_to_class(cls, name, virtual_only=virtual_only)

View File

@ -534,7 +534,7 @@ class QuerySet(object):
if not id_list: if not id_list:
return {} return {}
qs = self.filter(pk__in=id_list).order_by() qs = self.filter(pk__in=id_list).order_by()
return dict([(obj._get_pk_val(), obj) for obj in qs]) return dict((obj._get_pk_val(), obj) for obj in qs)
def delete(self): def delete(self):
""" """

View File

@ -437,7 +437,7 @@ class SQLCompiler(object):
# Firstly, avoid infinite loops. # Firstly, avoid infinite loops.
if not already_seen: if not already_seen:
already_seen = set() already_seen = set()
join_tuple = tuple([self.query.alias_map[j].table_name for j in joins]) join_tuple = tuple(self.query.alias_map[j].table_name for j in joins)
if join_tuple in already_seen: if join_tuple in already_seen:
raise FieldError('Infinite loop caused by ordering.') raise FieldError('Infinite loop caused by ordering.')
already_seen.add(join_tuple) already_seen.add(join_tuple)
@ -866,7 +866,7 @@ class SQLInsertCompiler(SQLCompiler):
return [(" ".join(result), tuple(params))] return [(" ".join(result), tuple(params))]
if can_bulk: if can_bulk:
result.append(self.connection.ops.bulk_insert_sql(fields, len(values))) result.append(self.connection.ops.bulk_insert_sql(fields, len(values)))
return [(" ".join(result), tuple([v for val in values for v in val]))] return [(" ".join(result), tuple(v for val in values for v in val))]
else: else:
return [ return [
(" ".join(result + ["VALUES (%s)" % ", ".join(p)]), vals) (" ".join(result + ["VALUES (%s)" % ", ".join(p)]), vals)

View File

@ -37,7 +37,7 @@ class Date(object):
def as_sql(self, qn, connection): def as_sql(self, qn, connection):
if isinstance(self.col, (list, tuple)): if isinstance(self.col, (list, tuple)):
col = '%s.%s' % tuple([qn(c) for c in self.col]) col = '%s.%s' % tuple(qn(c) for c in self.col)
else: else:
col = self.col col = self.col
return connection.ops.date_trunc_sql(self.lookup_type, col), [] return connection.ops.date_trunc_sql(self.lookup_type, col), []
@ -57,7 +57,7 @@ class DateTime(object):
def as_sql(self, qn, connection): def as_sql(self, qn, connection):
if isinstance(self.col, (list, tuple)): if isinstance(self.col, (list, tuple)):
col = '%s.%s' % tuple([qn(c) for c in self.col]) col = '%s.%s' % tuple(qn(c) for c in self.col)
else: else:
col = self.col col = self.col
return connection.ops.datetime_trunc_sql(self.lookup_type, col, self.tzname) return connection.ops.datetime_trunc_sql(self.lookup_type, col, self.tzname)

View File

@ -762,7 +762,7 @@ class Query(object):
# 2. Rename the alias in the internal table/alias datastructures. # 2. Rename the alias in the internal table/alias datastructures.
for ident, aliases in self.join_map.items(): for ident, aliases in self.join_map.items():
del self.join_map[ident] del self.join_map[ident]
aliases = tuple([change_map.get(a, a) for a in aliases]) aliases = tuple(change_map.get(a, a) for a in aliases)
ident = (change_map.get(ident[0], ident[0]),) + ident[1:] ident = (change_map.get(ident[0], ident[0]),) + ident[1:]
self.join_map[ident] = aliases self.join_map[ident] = aliases
for old_alias, new_alias in six.iteritems(change_map): for old_alias, new_alias in six.iteritems(change_map):

View File

@ -543,7 +543,7 @@ class BaseModelFormSet(BaseFormSet):
def _existing_object(self, pk): def _existing_object(self, pk):
if not hasattr(self, '_object_dict'): if not hasattr(self, '_object_dict'):
self._object_dict = dict([(o.pk, o) for o in self.get_queryset()]) self._object_dict = dict((o.pk, o) for o in self.get_queryset())
return self._object_dict.get(pk) return self._object_dict.get(pk)
def _construct_form(self, i, **kwargs): def _construct_form(self, i, **kwargs):

View File

@ -78,7 +78,7 @@ class ExtendsNode(Node):
self.nodelist = nodelist self.nodelist = nodelist
self.parent_name = parent_name self.parent_name = parent_name
self.template_dirs = template_dirs self.template_dirs = template_dirs
self.blocks = dict([(n.name, n) for n in nodelist.get_nodes_by_type(BlockNode)]) self.blocks = dict((n.name, n) for n in nodelist.get_nodes_by_type(BlockNode))
def __repr__(self): def __repr__(self):
return '<ExtendsNode: extends %s>' % self.parent_name.token return '<ExtendsNode: extends %s>' % self.parent_name.token

View File

@ -147,7 +147,7 @@ class BlockTranslateNode(Node):
default_value = settings.TEMPLATE_STRING_IF_INVALID default_value = settings.TEMPLATE_STRING_IF_INVALID
render_value = lambda v: render_value_in_context( render_value = lambda v: render_value_in_context(
context.get(v, default_value), context) context.get(v, default_value), context)
data = dict([(v, render_value(v)) for v in vars]) data = dict((v, render_value(v)) for v in vars)
context.pop() context.pop()
try: try:
result = result % data result = result % data

View File

@ -58,7 +58,7 @@ def patch_cache_control(response, **kwargs):
if response.has_header('Cache-Control'): if response.has_header('Cache-Control'):
cc = cc_delim_re.split(response['Cache-Control']) cc = cc_delim_re.split(response['Cache-Control'])
cc = dict([dictitem(el) for el in cc]) cc = dict(dictitem(el) for el in cc)
else: else:
cc = {} cc = {}

View File

@ -334,7 +334,7 @@ class MultiValueDict(dict):
def __getstate__(self): def __getstate__(self):
obj_dict = self.__dict__.copy() obj_dict = self.__dict__.copy()
obj_dict['_data'] = dict([(k, self.getlist(k)) for k in self]) obj_dict['_data'] = dict((k, self.getlist(k)) for k in self)
return obj_dict return obj_dict
def __setstate__(self, obj_dict): def __setstate__(self, obj_dict):

View File

@ -257,7 +257,7 @@ class BaseConfigurator(object):
c = self.resolve(c) c = self.resolve(c)
props = config.pop('.', None) props = config.pop('.', None)
# Check for valid identifiers # Check for valid identifiers
kwargs = dict([(k, config[k]) for k in config if valid_ident(k)]) kwargs = dict((k, config[k]) for k in config if valid_ident(k))
result = c(**kwargs) result = c(**kwargs)
if props: if props:
for name, value in props.items(): for name, value in props.items():
@ -494,7 +494,7 @@ class DictConfigurator(BaseConfigurator):
'address' in config: 'address' in config:
config['address'] = self.as_tuple(config['address']) config['address'] = self.as_tuple(config['address'])
factory = klass factory = klass
kwargs = dict([(k, config[k]) for k in config if valid_ident(k)]) kwargs = dict((k, config[k]) for k in config if valid_ident(k))
try: try:
result = factory(**kwargs) result = factory(**kwargs)
except TypeError as te: except TypeError as te: