Replaced an antiquated pattern.

Thanks Lennart Regebro for pointing it out.
This commit is contained in:
Aymeric Augustin 2013-05-17 16:33:36 +02:00
parent b1bfd9630e
commit 9c487b5974
30 changed files with 49 additions and 43 deletions

View File

@ -37,7 +37,7 @@ from django.utils.encoding import force_text
HORIZONTAL, VERTICAL = 1, 2 HORIZONTAL, VERTICAL = 1, 2
# returns the <ul> class for a given radio_admin field # returns the <ul> class for a given radio_admin field
get_ul_class = lambda x: 'radiolist%s' % ((x == HORIZONTAL) and ' inline' or '') get_ul_class = lambda x: 'radiolist%s' % (' inline' if x == HORIZONTAL else '')
class IncorrectLookupParameters(Exception): class IncorrectLookupParameters(Exception):
@ -189,7 +189,7 @@ class BaseModelAdmin(six.with_metaclass(RenameBaseModelAdminMethods)):
kwargs['widget'] = widgets.AdminRadioSelect(attrs={ kwargs['widget'] = widgets.AdminRadioSelect(attrs={
'class': get_ul_class(self.radio_fields[db_field.name]), 'class': get_ul_class(self.radio_fields[db_field.name]),
}) })
kwargs['empty_label'] = db_field.blank and _('None') or None kwargs['empty_label'] = _('None') if db_field.blank else None
queryset = self.get_field_queryset(db, db_field, request) queryset = self.get_field_queryset(db, db_field, request)
if queryset is not None: if queryset is not None:

View File

@ -37,7 +37,7 @@ def next_redirect(request, fallback, **get_kwargs):
else: else:
anchor = '' anchor = ''
joiner = ('?' in next) and '&' or '?' joiner = '&' if '?' in next else '?'
next += joiner + urlencode(get_kwargs) + anchor next += joiner + urlencode(get_kwargs) + anchor
return HttpResponseRedirect(next) return HttpResponseRedirect(next)

View File

@ -75,7 +75,7 @@ def shortcut(request, content_type_id, object_id):
# If all that malarkey found an object domain, use it. Otherwise, fall back # If all that malarkey found an object domain, use it. Otherwise, fall back
# to whatever get_absolute_url() returned. # to whatever get_absolute_url() returned.
if object_domain is not None: if object_domain is not None:
protocol = request.is_secure() and 'https' or 'http' protocol = 'https' if request.is_secure() else 'http'
return http.HttpResponseRedirect('%s://%s%s' return http.HttpResponseRedirect('%s://%s%s'
% (protocol, object_domain, absurl)) % (protocol, object_domain, absurl))
else: else:

View File

@ -17,7 +17,7 @@ from django.contrib.formtools.wizard.views import (WizardView,
class DummyRequest(http.HttpRequest): class DummyRequest(http.HttpRequest):
def __init__(self, POST=None): def __init__(self, POST=None):
super(DummyRequest, self).__init__() super(DummyRequest, self).__init__()
self.method = POST and "POST" or "GET" self.method = "POST" if POST else "GET"
if POST is not None: if POST is not None:
self.POST.update(POST) self.POST.update(POST)
self.session = {} self.session = {}

View File

@ -20,7 +20,7 @@ def index(request, sitemaps):
""" """
current_site = get_current_site(request) current_site = get_current_site(request)
sites = [] sites = []
protocol = request.is_secure() and 'https' or 'http' protocol = 'https' if request.is_secure() else 'http'
for section, site in sitemaps.items(): for section, site in sitemaps.items():
if callable(site): if callable(site):
pages = site().paginator.num_pages pages = site().paginator.num_pages

View File

@ -201,7 +201,7 @@ class LayerMapping(object):
if not (ltype.name.startswith(gtype.name) or self.make_multi(ltype, model_field)): if not (ltype.name.startswith(gtype.name) or self.make_multi(ltype, model_field)):
raise LayerMapError('Invalid mapping geometry; model has %s%s, ' raise LayerMapError('Invalid mapping geometry; model has %s%s, '
'layer geometry type is %s.' % 'layer geometry type is %s.' %
(fld_name, (coord_dim == 3 and '(dim=3)') or '', ltype)) (fld_name, '(dim=3)' if coord_dim == 3 else '', ltype))
# Setting the `geom_field` attribute w/the name of the model field # Setting the `geom_field` attribute w/the name of the model field
# that is a Geometry. Also setting the coordinate dimension # that is a Geometry. Also setting the coordinate dimension

View File

@ -174,7 +174,7 @@ Type 'yes' to continue, or 'no' to cancel: """
"%(destination)s%(unmodified)s%(post_processed)s.\n") "%(destination)s%(unmodified)s%(post_processed)s.\n")
summary = template % { summary = template % {
'modified_count': modified_count, 'modified_count': modified_count,
'identifier': 'static file' + (modified_count != 1 and 's' or ''), 'identifier': 'static file' + ('' if modified_count == 1 else 's'),
'action': self.symlink and 'symlinked' or 'copied', 'action': self.symlink and 'symlinked' or 'copied',
'destination': (destination_path and " to '%s'" 'destination': (destination_path and " to '%s'"
% destination_path or ''), % destination_path or ''),

View File

@ -63,7 +63,7 @@ def find_management_module(app_name):
while parts: while parts:
part = parts.pop() part = parts.pop()
f, path, descr = imp.find_module(part, path and [path] or None) f, path, descr = imp.find_module(part, [path] if path else None)
if f: if f:
f.close() f.close()
return path return path

View File

@ -60,7 +60,7 @@ class OutputWrapper(object):
return getattr(self._out, name) return getattr(self._out, name)
def write(self, msg, style_func=None, ending=None): def write(self, msg, style_func=None, ending=None):
ending = ending is None and self.ending or ending ending = self.ending if ending is None else ending
if ending and not msg.endswith(ending): if ending and not msg.endswith(ending):
msg += ending msg += ending
style_func = [f for f in (style_func, self.style_func, lambda x:x) style_func = [f for f in (style_func, self.style_func, lambda x:x)
@ -311,7 +311,7 @@ class BaseCommand(object):
error_text = s.read() error_text = s.read()
raise CommandError("One or more models did not validate:\n%s" % error_text) raise CommandError("One or more models did not validate:\n%s" % error_text)
if display_num_errors: if display_num_errors:
self.stdout.write("%s error%s found" % (num_errors, num_errors != 1 and 's' or '')) self.stdout.write("%s error%s found" % (num_errors, '' if num_errors == 1 else 's'))
def handle(self, *args, **options): def handle(self, *args, **options):
""" """

View File

@ -44,7 +44,7 @@ class Command(LabelCommand):
elif f.unique: elif f.unique:
field_output.append("UNIQUE") field_output.append("UNIQUE")
if f.db_index: if f.db_index:
unique = f.unique and "UNIQUE " or "" unique = "UNIQUE " if f.unique else ""
index_output.append("CREATE %sINDEX %s ON %s (%s);" % \ index_output.append("CREATE %sINDEX %s ON %s (%s);" % \
(unique, qn('%s_%s' % (tablename, f.name)), qn(tablename), (unique, qn('%s_%s' % (tablename, f.name)), qn(tablename),
qn(f.name))) qn(f.name)))

View File

@ -65,7 +65,7 @@ class Command(BaseCommand):
elif self.use_ipv6 and not _fqdn: elif self.use_ipv6 and not _fqdn:
raise CommandError('"%s" is not a valid IPv6 address.' % self.addr) raise CommandError('"%s" is not a valid IPv6 address.' % self.addr)
if not self.addr: if not self.addr:
self.addr = self.use_ipv6 and '::1' or '127.0.0.1' self.addr = '::1' if self.use_ipv6 else '127.0.0.1'
self._raw_ipv6 = bool(self.use_ipv6) self._raw_ipv6 = bool(self.use_ipv6)
self.run(*args, **options) self.run(*args, **options)
@ -86,7 +86,7 @@ class Command(BaseCommand):
threading = options.get('use_threading') threading = options.get('use_threading')
shutdown_message = options.get('shutdown_message', '') shutdown_message = options.get('shutdown_message', '')
quit_command = (sys.platform == 'win32') and 'CTRL-BREAK' or 'CONTROL-C' quit_command = 'CTRL-BREAK' if sys.platform == 'win32' else 'CONTROL-C'
self.stdout.write("Validating models...\n\n") self.stdout.write("Validating models...\n\n")
self.validate(display_num_errors=True) self.validate(display_num_errors=True)

View File

@ -631,7 +631,7 @@ class Model(six.with_metaclass(ModelBase)):
# If possible, try an UPDATE. If that doesn't update anything, do an INSERT. # If possible, try an UPDATE. If that doesn't update anything, do an INSERT.
if pk_set and not force_insert: if pk_set and not force_insert:
base_qs = cls._base_manager.using(using) base_qs = cls._base_manager.using(using)
values = [(f, None, (raw and getattr(self, f.attname) or f.pre_save(self, False))) values = [(f, None, (getattr(self, f.attname) if raw else f.pre_save(self, False)))
for f in non_pks] for f in non_pks]
if not values: if not values:
# We can end up here when saving a model in inheritance chain where # We can end up here when saving a model in inheritance chain where
@ -698,8 +698,8 @@ class Model(six.with_metaclass(ModelBase)):
def _get_next_or_previous_by_FIELD(self, field, is_next, **kwargs): def _get_next_or_previous_by_FIELD(self, field, is_next, **kwargs):
if not self.pk: if not self.pk:
raise ValueError("get_next/get_previous cannot be used on unsaved objects.") raise ValueError("get_next/get_previous cannot be used on unsaved objects.")
op = is_next and 'gt' or 'lt' op = 'gt' if is_next else 'lt'
order = not is_next and '-' or '' order = '' if is_next else '-'
param = force_text(getattr(self, field.attname)) param = force_text(getattr(self, field.attname))
q = Q(**{'%s__%s' % (field.name, op): param}) q = Q(**{'%s__%s' % (field.name, op): param})
q = q | Q(**{field.name: param, 'pk__%s' % op: self.pk}) q = q | Q(**{field.name: param, 'pk__%s' % op: self.pk})
@ -712,8 +712,8 @@ class Model(six.with_metaclass(ModelBase)):
def _get_next_or_previous_in_order(self, is_next): def _get_next_or_previous_in_order(self, is_next):
cachename = "__%s_order_cache" % is_next cachename = "__%s_order_cache" % is_next
if not hasattr(self, cachename): if not hasattr(self, cachename):
op = is_next and 'gt' or 'lt' op = 'gt' if is_next else 'lt'
order = not is_next and '-_order' or '_order' order = '_order' if is_next else '-_order'
order_field = self._meta.order_with_respect_to order_field = self._meta.order_with_respect_to
obj = self._default_manager.filter(**{ obj = self._default_manager.filter(**{
order_field.name: getattr(self, order_field.attname) order_field.name: getattr(self, order_field.attname)

View File

@ -448,7 +448,7 @@ class Field(object):
def get_choices(self, include_blank=True, blank_choice=BLANK_CHOICE_DASH): def get_choices(self, include_blank=True, blank_choice=BLANK_CHOICE_DASH):
"""Returns choices with a default blank choices included, for use """Returns choices with a default blank choices included, for use
as SelectField choices for this field.""" as SelectField choices for this field."""
first_choice = include_blank and blank_choice or [] first_choice = blank_choice if include_blank else []
if self.choices: if self.choices:
return first_choice + list(self.choices) return first_choice + list(self.choices)
rel_model = self.rel.to rel_model = self.rel.to
@ -471,7 +471,7 @@ class Field(object):
""" """
Returns flattened choices with a default blank choice included. Returns flattened choices with a default blank choice included.
""" """
first_choice = include_blank and blank_choice or [] first_choice = blank_choice if include_blank else []
return first_choice + list(self.flatchoices) return first_choice + list(self.flatchoices)
def _get_val_from_obj(self, obj): def _get_val_from_obj(self, obj):

View File

@ -347,7 +347,7 @@ class Options(object):
""" """
Returns the requested field by name. Raises FieldDoesNotExist on error. Returns the requested field by name. Raises FieldDoesNotExist on error.
""" """
to_search = many_to_many and (self.fields + self.many_to_many) or self.fields to_search = (self.fields + self.many_to_many) if many_to_many else self.fields
for f in to_search: for f in to_search:
if f.name == name: if f.name == name:
return f return f

View File

@ -27,7 +27,7 @@ class RelatedObject(object):
Analogue of django.db.models.fields.Field.get_choices, provided Analogue of django.db.models.fields.Field.get_choices, provided
initially for utilisation by RelatedFieldListFilter. initially for utilisation by RelatedFieldListFilter.
""" """
first_choice = include_blank and blank_choice or [] first_choice = blank_choice if include_blank else []
queryset = self.model._default_manager.all() queryset = self.model._default_manager.all()
if limit_to_currently_related: if limit_to_currently_related:
queryset = queryset.complex_filter( queryset = queryset.complex_filter(

View File

@ -112,7 +112,7 @@ class StdDev(Aggregate):
def __init__(self, col, sample=False, **extra): def __init__(self, col, sample=False, **extra):
super(StdDev, self).__init__(col, **extra) super(StdDev, self).__init__(col, **extra)
self.sql_function = sample and 'STDDEV_SAMP' or 'STDDEV_POP' self.sql_function = 'STDDEV_SAMP' if sample else 'STDDEV_POP'
class Sum(Aggregate): class Sum(Aggregate):
sql_function = 'SUM' sql_function = 'SUM'
@ -122,4 +122,4 @@ class Variance(Aggregate):
def __init__(self, col, sample=False, **extra): def __init__(self, col, sample=False, **extra):
super(Variance, self).__init__(col, **extra) super(Variance, self).__init__(col, **extra)
self.sql_function = sample and 'VAR_SAMP' or 'VAR_POP' self.sql_function = 'VAR_SAMP' if sample else 'VAR_POP'

View File

@ -512,7 +512,7 @@ class SQLCompiler(object):
# Extra tables can end up in self.tables, but not in the # Extra tables can end up in self.tables, but not in the
# alias_map if they aren't in a join. That's OK. We skip them. # alias_map if they aren't in a join. That's OK. We skip them.
continue continue
alias_str = (alias != name and ' %s' % alias or '') alias_str = '' if alias == name else (' %s' % alias)
if join_type and not first: if join_type and not first:
extra_cond = join_field.get_extra_restriction( extra_cond = join_field.get_extra_restriction(
self.query.where_class, alias, lhs) self.query.where_class, alias, lhs)
@ -532,7 +532,7 @@ class SQLCompiler(object):
(qn(lhs), qn2(lhs_col), qn(alias), qn2(rhs_col))) (qn(lhs), qn2(lhs_col), qn(alias), qn2(rhs_col)))
result.append('%s)' % extra_sql) result.append('%s)' % extra_sql)
else: else:
connector = not first and ', ' or '' connector = '' if first else ', '
result.append('%s%s%s' % (connector, qn(name), alias_str)) result.append('%s%s%s' % (connector, qn(name), alias_str))
first = False first = False
for t in self.query.extra_tables: for t in self.query.extra_tables:
@ -541,7 +541,7 @@ class SQLCompiler(object):
# calls increments the refcount, so an alias refcount of one means # calls increments the refcount, so an alias refcount of one means
# this is the only reference. # this is the only reference.
if alias not in self.query.alias_map or self.query.alias_refcount[alias] == 1: if alias not in self.query.alias_map or self.query.alias_refcount[alias] == 1:
connector = not first and ', ' or '' connector = '' if first else ', '
result.append('%s%s' % (connector, qn(alias))) result.append('%s%s' % (connector, qn(alias)))
first = False first = False
return result, from_params return result, from_params
@ -959,7 +959,7 @@ class SQLUpdateCompiler(SQLCompiler):
related queries are not available. related queries are not available.
""" """
cursor = super(SQLUpdateCompiler, self).execute_sql(result_type) cursor = super(SQLUpdateCompiler, self).execute_sql(result_type)
rows = cursor and cursor.rowcount or 0 rows = cursor.rowcount if cursor else 0
is_empty = cursor is None is_empty = cursor is None
del cursor del cursor
for query in self.query.get_related_updates(): for query in self.query.get_related_updates():

View File

@ -532,7 +532,7 @@ class Query(object):
# Ordering uses the 'rhs' ordering, unless it has none, in which case # Ordering uses the 'rhs' ordering, unless it has none, in which case
# the current ordering is used. # the current ordering is used.
self.order_by = rhs.order_by and rhs.order_by[:] or self.order_by self.order_by = rhs.order_by[:] if rhs.order_by else self.order_by
self.extra_order_by = rhs.extra_order_by or self.extra_order_by self.extra_order_by = rhs.extra_order_by or self.extra_order_by
def deferred_to_data(self, target, callback): def deferred_to_data(self, target, callback):

View File

@ -245,7 +245,7 @@ class DateQuery(Query):
self.clear_select_clause() self.clear_select_clause()
self.select = [SelectInfo(select, None)] self.select = [SelectInfo(select, None)]
self.distinct = True self.distinct = True
self.order_by = order == 'ASC' and [1] or [-1] self.order_by = [1] if order == 'ASC' else [-1]
if field.null: if field.null:
self.add_filter(("%s__isnull" % field_name, False)) self.add_filter(("%s__isnull" % field_name, False))

View File

@ -523,7 +523,7 @@ class BoundField(object):
widget = self.field.widget widget = self.field.widget
id_ = widget.attrs.get('id') or self.auto_id id_ = widget.attrs.get('id') or self.auto_id
if id_: if id_:
attrs = attrs and flatatt(attrs) or '' attrs = flatatt(attrs) if attrs else ''
contents = format_html('<label for="{0}"{1}>{2}</label>', contents = format_html('<label for="{0}"{1}>{2}</label>',
widget.id_for_label(id_), attrs, contents widget.id_for_label(id_), attrs, contents
) )

View File

@ -119,7 +119,7 @@ class BaseFormSet(object):
return self.management_form.cleaned_data[INITIAL_FORM_COUNT] return self.management_form.cleaned_data[INITIAL_FORM_COUNT]
else: else:
# Use the length of the initial data if it's there, 0 otherwise. # Use the length of the initial data if it's there, 0 otherwise.
initial_forms = self.initial and len(self.initial) or 0 initial_forms = len(self.initial) if self.initial else 0
return initial_forms return initial_forms
def _construct_forms(self): def _construct_forms(self):

View File

@ -775,7 +775,7 @@ class MultiWidget(Widget):
You'll probably want to use this class with MultiValueField. You'll probably want to use this class with MultiValueField.
""" """
def __init__(self, widgets, attrs=None): def __init__(self, widgets, attrs=None):
self.widgets = [isinstance(w, type) and w() or w for w in widgets] self.widgets = [w() if isinstance(w, type) else w for w in widgets]
super(MultiWidget, self).__init__(attrs) super(MultiWidget, self).__init__(attrs)
def render(self, name, value, attrs=None): def render(self, name, value, attrs=None):

View File

@ -292,7 +292,7 @@ class LazyStream(six.Iterator):
def read(self, size=None): def read(self, size=None):
def parts(): def parts():
remaining = (size is not None and [size] or [self._remaining])[0] remaining = self._remaining if size is None else size
# do the whole thing in one shot if no limit was provided. # do the whole thing in one shot if no limit was provided.
if remaining is None: if remaining is None:
yield b''.join(self) yield b''.join(self)

View File

@ -641,7 +641,7 @@ class FilterExpression(object):
(name, len(nondefs), plen)) (name, len(nondefs), plen))
# Defaults can be overridden. # Defaults can be overridden.
defaults = defaults and list(defaults) or [] defaults = list(defaults) if defaults else []
try: try:
for parg in provided: for parg in provided:
defaults.pop(0) defaults.pop(0)

View File

@ -127,7 +127,7 @@ class ForNode(Node):
self.nodelist_empty = nodelist_empty self.nodelist_empty = nodelist_empty
def __repr__(self): def __repr__(self):
reversed_text = self.is_reversed and ' reversed' or '' reversed_text = ' reversed' if self.is_reversed else ''
return "<For Node: for %s in %s, tail_len: %d%s>" % \ return "<For Node: for %s in %s, tail_len: %d%s>" % \
(', '.join(self.loopvars), self.sequence, len(self.nodelist_loop), (', '.join(self.loopvars), self.sequence, len(self.nodelist_loop),
reversed_text) reversed_text)
@ -788,7 +788,7 @@ def do_for(parser, token):
" words: %s" % token.contents) " words: %s" % token.contents)
is_reversed = bits[-1] == 'reversed' is_reversed = bits[-1] == 'reversed'
in_index = is_reversed and -3 or -2 in_index = -3 if is_reversed else -2
if bits[in_index] != 'in': if bits[in_index] != 'in':
raise TemplateSyntaxError("'for' statements should use the format" raise TemplateSyntaxError("'for' statements should use the format"
" 'for x in y': %s" % token.contents) " 'for x in y': %s" % token.contents)

View File

@ -234,7 +234,7 @@ class DateFormat(TimeFormat):
def T(self): def T(self):
"Time zone of this machine; e.g. 'EST' or 'MDT'" "Time zone of this machine; e.g. 'EST' or 'MDT'"
name = self.timezone and self.timezone.tzname(self.data) or None name = self.timezone.tzname(self.data) if self.timezone else None
if name is None: if name is None:
name = self.format('O') name = self.format('O')
return six.text_type(name) return six.text_type(name)

View File

@ -187,7 +187,10 @@ def urlize(text, trim_url_limit=None, nofollow=False, autoescape=False):
If autoescape is True, the link text and URLs will get autoescaped. If autoescape is True, the link text and URLs will get autoescaped.
""" """
trim_url = lambda x, limit=trim_url_limit: limit is not None and (len(x) > limit and ('%s...' % x[:max(0, limit - 3)])) or x def trim_url(x, limit=trim_url_limit):
if limit is None or len(x) <= limit:
return x
return '%s...' % x[:max(0, limit - 3)]
safe_input = isinstance(text, SafeData) safe_input = isinstance(text, SafeData)
words = word_split_re.split(force_text(text)) words = word_split_re.split(force_text(text))
for i, word in enumerate(words): for i, word in enumerate(words):

View File

@ -111,7 +111,7 @@ class AdminEmailHandler(logging.Handler):
message = "%s\n\n%s" % (stack_trace, request_repr) message = "%s\n\n%s" % (stack_trace, request_repr)
reporter = ExceptionReporter(request, is_email=True, *exc_info) reporter = ExceptionReporter(request, is_email=True, *exc_info)
html_message = self.include_html and reporter.get_traceback_html() or None html_message = reporter.get_traceback_html() if self.include_html else None
mail.mail_admins(subject, message, fail_silently=True, mail.mail_admins(subject, message, fail_silently=True,
html_message=html_message, html_message=html_message,
connection=self.connection()) connection=self.connection())

View File

@ -651,7 +651,10 @@ def parse_accept_lang_header(lang_string):
first, lang, priority = pieces[i : i + 3] first, lang, priority = pieces[i : i + 3]
if first: if first:
return [] return []
priority = priority and float(priority) or 1.0 if priority:
priority = float(priority)
if not priority: # if priority is 0.0 at this point make it 1.0
priority = 1.0
result.append((lang, priority)) result.append((lang, priority))
result.sort(key=lambda k: k[1], reverse=True) result.sort(key=lambda k: k[1], reverse=True)
return result return result

View File

@ -20,7 +20,7 @@ class Node(object):
Constructs a new Node. If no connector is given, the default will be Constructs a new Node. If no connector is given, the default will be
used. used.
""" """
self.children = children and children[:] or [] self.children = children[:] if children else []
self.connector = connector or self.default self.connector = connector or self.default
self.negated = negated self.negated = negated