Removed redundant numbered parameters from str.format().
Since Python 2.7 and 3.1, "{0} {1}" is equivalent to "{} {}".
This commit is contained in:
parent
50c1d8f24b
commit
560b4207b1
|
@ -178,7 +178,7 @@ class AdminReadonlyField(object):
|
||||||
if not self.is_first:
|
if not self.is_first:
|
||||||
attrs["class"] = "inline"
|
attrs["class"] = "inline"
|
||||||
label = self.field['label']
|
label = self.field['label']
|
||||||
return format_html('<label{0}>{1}:</label>',
|
return format_html('<label{}>{}:</label>',
|
||||||
flatatt(attrs),
|
flatatt(attrs),
|
||||||
capfirst(force_text(label)))
|
capfirst(force_text(label)))
|
||||||
|
|
||||||
|
|
|
@ -34,9 +34,9 @@ def paginator_number(cl, i):
|
||||||
if i == DOT:
|
if i == DOT:
|
||||||
return '... '
|
return '... '
|
||||||
elif i == cl.page_num:
|
elif i == cl.page_num:
|
||||||
return format_html('<span class="this-page">{0}</span> ', i + 1)
|
return format_html('<span class="this-page">{}</span> ', i + 1)
|
||||||
else:
|
else:
|
||||||
return format_html('<a href="{0}"{1}>{2}</a> ',
|
return format_html('<a href="{}"{}>{}</a> ',
|
||||||
cl.get_query_string({PAGE_VAR: i}),
|
cl.get_query_string({PAGE_VAR: i}),
|
||||||
mark_safe(' class="end"' if i == cl.paginator.num_pages - 1 else ''),
|
mark_safe(' class="end"' if i == cl.paginator.num_pages - 1 else ''),
|
||||||
i + 1)
|
i + 1)
|
||||||
|
@ -117,13 +117,13 @@ def result_headers(cl):
|
||||||
# Not sortable
|
# Not sortable
|
||||||
yield {
|
yield {
|
||||||
"text": text,
|
"text": text,
|
||||||
"class_attrib": format_html(' class="column-{0}"', field_name),
|
"class_attrib": format_html(' class="column-{}"', field_name),
|
||||||
"sortable": False,
|
"sortable": False,
|
||||||
}
|
}
|
||||||
continue
|
continue
|
||||||
|
|
||||||
# OK, it is sortable if we got this far
|
# OK, it is sortable if we got this far
|
||||||
th_classes = ['sortable', 'column-{0}'.format(field_name)]
|
th_classes = ['sortable', 'column-{}'.format(field_name)]
|
||||||
order_type = ''
|
order_type = ''
|
||||||
new_order_type = 'asc'
|
new_order_type = 'asc'
|
||||||
sort_priority = 0
|
sort_priority = 0
|
||||||
|
@ -168,14 +168,14 @@ def result_headers(cl):
|
||||||
"url_primary": cl.get_query_string({ORDER_VAR: '.'.join(o_list_primary)}),
|
"url_primary": cl.get_query_string({ORDER_VAR: '.'.join(o_list_primary)}),
|
||||||
"url_remove": cl.get_query_string({ORDER_VAR: '.'.join(o_list_remove)}),
|
"url_remove": cl.get_query_string({ORDER_VAR: '.'.join(o_list_remove)}),
|
||||||
"url_toggle": cl.get_query_string({ORDER_VAR: '.'.join(o_list_toggle)}),
|
"url_toggle": cl.get_query_string({ORDER_VAR: '.'.join(o_list_toggle)}),
|
||||||
"class_attrib": format_html(' class="{0}"', ' '.join(th_classes)) if th_classes else '',
|
"class_attrib": format_html(' class="{}"', ' '.join(th_classes)) if th_classes else '',
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
def _boolean_icon(field_val):
|
def _boolean_icon(field_val):
|
||||||
icon_url = static('admin/img/icon-%s.gif' %
|
icon_url = static('admin/img/icon-%s.gif' %
|
||||||
{True: 'yes', False: 'no', None: 'unknown'}[field_val])
|
{True: 'yes', False: 'no', None: 'unknown'}[field_val])
|
||||||
return format_html('<img src="{0}" alt="{1}" />', icon_url, field_val)
|
return format_html('<img src="{}" alt="{}" />', icon_url, field_val)
|
||||||
|
|
||||||
|
|
||||||
def items_for_result(cl, result, form):
|
def items_for_result(cl, result, form):
|
||||||
|
@ -249,15 +249,15 @@ def items_for_result(cl, result, form):
|
||||||
value = result.serializable_value(attr)
|
value = result.serializable_value(attr)
|
||||||
result_id = escapejs(value)
|
result_id = escapejs(value)
|
||||||
link_or_text = format_html(
|
link_or_text = format_html(
|
||||||
'<a href="{0}"{1}>{2}</a>',
|
'<a href="{}"{}>{}</a>',
|
||||||
url,
|
url,
|
||||||
format_html(
|
format_html(
|
||||||
' onclick="opener.dismissRelatedLookupPopup(window, '
|
' onclick="opener.dismissRelatedLookupPopup(window, '
|
||||||
''{0}'); return false;"', result_id
|
''{}'); return false;"', result_id
|
||||||
) if cl.is_popup else '',
|
) if cl.is_popup else '',
|
||||||
result_repr)
|
result_repr)
|
||||||
|
|
||||||
yield format_html('<{0}{1}>{2}</{3}>',
|
yield format_html('<{}{}>{}</{}>',
|
||||||
table_tag,
|
table_tag,
|
||||||
row_class,
|
row_class,
|
||||||
link_or_text,
|
link_or_text,
|
||||||
|
@ -271,9 +271,9 @@ def items_for_result(cl, result, form):
|
||||||
form[cl.model._meta.pk.name].is_hidden)):
|
form[cl.model._meta.pk.name].is_hidden)):
|
||||||
bf = form[field_name]
|
bf = form[field_name]
|
||||||
result_repr = mark_safe(force_text(bf.errors) + force_text(bf))
|
result_repr = mark_safe(force_text(bf.errors) + force_text(bf))
|
||||||
yield format_html('<td{0}>{1}</td>', row_class, result_repr)
|
yield format_html('<td{}>{}</td>', row_class, result_repr)
|
||||||
if form and not form[cl.model._meta.pk.name].is_hidden:
|
if form and not form[cl.model._meta.pk.name].is_hidden:
|
||||||
yield format_html('<td>{0}</td>', force_text(form[cl.model._meta.pk.name]))
|
yield format_html('<td>{}</td>', force_text(form[cl.model._meta.pk.name]))
|
||||||
|
|
||||||
|
|
||||||
class ResultList(list):
|
class ResultList(list):
|
||||||
|
|
|
@ -142,7 +142,7 @@ def get_deleted_objects(objs, opts, user, admin_site, using):
|
||||||
if not user.has_perm(p):
|
if not user.has_perm(p):
|
||||||
perms_needed.add(opts.verbose_name)
|
perms_needed.add(opts.verbose_name)
|
||||||
# Display a link to the admin page.
|
# Display a link to the admin page.
|
||||||
return format_html('{0}: <a href="{1}">{2}</a>',
|
return format_html('{}: <a href="{}">{}</a>',
|
||||||
capfirst(opts.verbose_name),
|
capfirst(opts.verbose_name),
|
||||||
admin_url,
|
admin_url,
|
||||||
obj)
|
obj)
|
||||||
|
|
|
@ -87,7 +87,7 @@ class AdminSplitDateTime(forms.SplitDateTimeWidget):
|
||||||
forms.MultiWidget.__init__(self, widgets, attrs)
|
forms.MultiWidget.__init__(self, widgets, attrs)
|
||||||
|
|
||||||
def format_output(self, rendered_widgets):
|
def format_output(self, rendered_widgets):
|
||||||
return format_html('<p class="datetime">{0} {1}<br />{2} {3}</p>',
|
return format_html('<p class="datetime">{} {}<br />{} {}</p>',
|
||||||
_('Date:'), rendered_widgets[0],
|
_('Date:'), rendered_widgets[0],
|
||||||
_('Time:'), rendered_widgets[1])
|
_('Time:'), rendered_widgets[1])
|
||||||
|
|
||||||
|
@ -95,9 +95,9 @@ class AdminSplitDateTime(forms.SplitDateTimeWidget):
|
||||||
class AdminRadioFieldRenderer(RadioFieldRenderer):
|
class AdminRadioFieldRenderer(RadioFieldRenderer):
|
||||||
def render(self):
|
def render(self):
|
||||||
"""Outputs a <ul> for this set of radio fields."""
|
"""Outputs a <ul> for this set of radio fields."""
|
||||||
return format_html('<ul{0}>\n{1}\n</ul>',
|
return format_html('<ul{}>\n{}\n</ul>',
|
||||||
flatatt(self.attrs),
|
flatatt(self.attrs),
|
||||||
format_html_join('\n', '<li>{0}</li>',
|
format_html_join('\n', '<li>{}</li>',
|
||||||
((force_text(w),) for w in self)))
|
((force_text(w),) for w in self)))
|
||||||
|
|
||||||
|
|
||||||
|
@ -325,7 +325,7 @@ class AdminURLFieldWidget(forms.URLInput):
|
||||||
value = force_text(self._format_value(value))
|
value = force_text(self._format_value(value))
|
||||||
final_attrs = {'href': smart_urlquote(value)}
|
final_attrs = {'href': smart_urlquote(value)}
|
||||||
html = format_html(
|
html = format_html(
|
||||||
'<p class="url">{0} <a{1}>{2}</a><br />{3} {4}</p>',
|
'<p class="url">{} <a{}>{}</a><br />{} {}</p>',
|
||||||
_('Currently:'), flatatt(final_attrs), value,
|
_('Currently:'), flatatt(final_attrs), value,
|
||||||
_('Change:'), html
|
_('Change:'), html
|
||||||
)
|
)
|
||||||
|
|
|
@ -44,12 +44,12 @@ class ReadOnlyPasswordHashWidget(forms.Widget):
|
||||||
"Invalid password format or unknown hashing algorithm."))
|
"Invalid password format or unknown hashing algorithm."))
|
||||||
else:
|
else:
|
||||||
summary = format_html_join('',
|
summary = format_html_join('',
|
||||||
"<strong>{0}</strong>: {1} ",
|
"<strong>{}</strong>: {} ",
|
||||||
((ugettext(key), value)
|
((ugettext(key), value)
|
||||||
for key, value in hasher.safe_summary(encoded).items())
|
for key, value in hasher.safe_summary(encoded).items())
|
||||||
)
|
)
|
||||||
|
|
||||||
return format_html("<div{0}>{1}</div>", flatatt(final_attrs), summary)
|
return format_html("<div{}>{}</div>", flatatt(final_attrs), summary)
|
||||||
|
|
||||||
|
|
||||||
class ReadOnlyPasswordHashField(forms.Field):
|
class ReadOnlyPasswordHashField(forms.Field):
|
||||||
|
|
|
@ -121,17 +121,17 @@ class GoogleMap(object):
|
||||||
@property
|
@property
|
||||||
def body(self):
|
def body(self):
|
||||||
"Returns HTML body tag for loading and unloading Google Maps javascript."
|
"Returns HTML body tag for loading and unloading Google Maps javascript."
|
||||||
return format_html('<body {0} {1}>', self.onload, self.onunload)
|
return format_html('<body {} {}>', self.onload, self.onunload)
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def onload(self):
|
def onload(self):
|
||||||
"Returns the `onload` HTML <body> attribute."
|
"Returns the `onload` HTML <body> attribute."
|
||||||
return format_html('onload="{0}.{1}_load()"', self.js_module, self.dom_id)
|
return format_html('onload="{}.{}_load()"', self.js_module, self.dom_id)
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def api_script(self):
|
def api_script(self):
|
||||||
"Returns the <script> tag for the Google Maps API javascript."
|
"Returns the <script> tag for the Google Maps API javascript."
|
||||||
return format_html('<script src="{0}{1}" type="text/javascript"></script>',
|
return format_html('<script src="{}{}" type="text/javascript"></script>',
|
||||||
self.api_url, self.key)
|
self.api_url, self.key)
|
||||||
|
|
||||||
@property
|
@property
|
||||||
|
@ -142,18 +142,18 @@ class GoogleMap(object):
|
||||||
@property
|
@property
|
||||||
def scripts(self):
|
def scripts(self):
|
||||||
"Returns all <script></script> tags required with Google Maps JavaScript."
|
"Returns all <script></script> tags required with Google Maps JavaScript."
|
||||||
return format_html('{0}\n <script type="text/javascript">\n//<![CDATA[\n{1}//]]>\n </script>',
|
return format_html('{}\n <script type="text/javascript">\n//<![CDATA[\n{}//]]>\n </script>',
|
||||||
self.api_script, mark_safe(self.js))
|
self.api_script, mark_safe(self.js))
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def style(self):
|
def style(self):
|
||||||
"Returns additional CSS styling needed for Google Maps on IE."
|
"Returns additional CSS styling needed for Google Maps on IE."
|
||||||
return format_html('<style type="text/css">{0}</style>', self.vml_css)
|
return format_html('<style type="text/css">{}</style>', self.vml_css)
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def xhtml(self):
|
def xhtml(self):
|
||||||
"Returns XHTML information needed for IE VML overlays."
|
"Returns XHTML information needed for IE VML overlays."
|
||||||
return format_html('<html xmlns="http://www.w3.org/1999/xhtml" {0}>', self.xmlns)
|
return format_html('<html xmlns="http://www.w3.org/1999/xhtml" {}>', self.xmlns)
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def icons(self):
|
def icons(self):
|
||||||
|
|
|
@ -601,7 +601,7 @@ class SessionMiddlewareTests(unittest.TestCase):
|
||||||
# A deleted cookie header looks like:
|
# A deleted cookie header looks like:
|
||||||
# Set-Cookie: sessionid=; expires=Thu, 01-Jan-1970 00:00:00 GMT; Max-Age=0; Path=/
|
# Set-Cookie: sessionid=; expires=Thu, 01-Jan-1970 00:00:00 GMT; Max-Age=0; Path=/
|
||||||
self.assertEqual(
|
self.assertEqual(
|
||||||
'Set-Cookie: {0}=; expires=Thu, 01-Jan-1970 00:00:00 GMT; '
|
'Set-Cookie: {}=; expires=Thu, 01-Jan-1970 00:00:00 GMT; '
|
||||||
'Max-Age=0; Path=/'.format(settings.SESSION_COOKIE_NAME),
|
'Max-Age=0; Path=/'.format(settings.SESSION_COOKIE_NAME),
|
||||||
str(response.cookies[settings.SESSION_COOKIE_NAME])
|
str(response.cookies[settings.SESSION_COOKIE_NAME])
|
||||||
)
|
)
|
||||||
|
|
|
@ -645,7 +645,7 @@ class BoundField(object):
|
||||||
# Translators: If found as last label character, these punctuation
|
# Translators: If found as last label character, these punctuation
|
||||||
# characters will prevent the default label_suffix to be appended to the label
|
# characters will prevent the default label_suffix to be appended to the label
|
||||||
if label_suffix and contents and contents[-1] not in _(':?.!'):
|
if label_suffix and contents and contents[-1] not in _(':?.!'):
|
||||||
contents = format_html('{0}{1}', contents, label_suffix)
|
contents = format_html('{}{}', contents, label_suffix)
|
||||||
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_:
|
||||||
|
@ -659,7 +659,7 @@ class BoundField(object):
|
||||||
else:
|
else:
|
||||||
attrs['class'] = self.form.required_css_class
|
attrs['class'] = self.form.required_css_class
|
||||||
attrs = flatatt(attrs) if attrs else ''
|
attrs = flatatt(attrs) if attrs else ''
|
||||||
contents = format_html('<label{0}>{1}</label>', attrs, contents)
|
contents = format_html('<label{}>{}</label>', attrs, contents)
|
||||||
else:
|
else:
|
||||||
contents = conditional_escape(contents)
|
contents = conditional_escape(contents)
|
||||||
return mark_safe(contents)
|
return mark_safe(contents)
|
||||||
|
|
|
@ -39,8 +39,8 @@ def flatatt(attrs):
|
||||||
key_value_attrs.append((attr, value))
|
key_value_attrs.append((attr, value))
|
||||||
|
|
||||||
return (
|
return (
|
||||||
format_html_join('', ' {0}="{1}"', sorted(key_value_attrs)) +
|
format_html_join('', ' {}="{}"', sorted(key_value_attrs)) +
|
||||||
format_html_join('', ' {0}', sorted(boolean_attrs))
|
format_html_join('', ' {}', sorted(boolean_attrs))
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
|
@ -61,8 +61,8 @@ class ErrorDict(dict):
|
||||||
if not self:
|
if not self:
|
||||||
return ''
|
return ''
|
||||||
return format_html(
|
return format_html(
|
||||||
'<ul class="errorlist">{0}</ul>',
|
'<ul class="errorlist">{}</ul>',
|
||||||
format_html_join('', '<li>{0}{1}</li>', ((k, force_text(v)) for k, v in self.items()))
|
format_html_join('', '<li>{}{}</li>', ((k, force_text(v)) for k, v in self.items()))
|
||||||
)
|
)
|
||||||
|
|
||||||
def as_text(self):
|
def as_text(self):
|
||||||
|
@ -110,9 +110,9 @@ class ErrorList(UserList, list):
|
||||||
return ''
|
return ''
|
||||||
|
|
||||||
return format_html(
|
return format_html(
|
||||||
'<ul class="{0}">{1}</ul>',
|
'<ul class="{}">{}</ul>',
|
||||||
self.error_class,
|
self.error_class,
|
||||||
format_html_join('', '<li>{0}</li>', ((force_text(e),) for e in self))
|
format_html_join('', '<li>{}</li>', ((force_text(e),) for e in self))
|
||||||
)
|
)
|
||||||
|
|
||||||
def as_text(self):
|
def as_text(self):
|
||||||
|
|
|
@ -53,7 +53,7 @@ class Media(object):
|
||||||
def render_js(self):
|
def render_js(self):
|
||||||
return [
|
return [
|
||||||
format_html(
|
format_html(
|
||||||
'<script type="text/javascript" src="{0}"></script>',
|
'<script type="text/javascript" src="{}"></script>',
|
||||||
self.absolute_path(path)
|
self.absolute_path(path)
|
||||||
) for path in self._js
|
) for path in self._js
|
||||||
]
|
]
|
||||||
|
@ -64,7 +64,7 @@ class Media(object):
|
||||||
media = sorted(self._css.keys())
|
media = sorted(self._css.keys())
|
||||||
return chain(*[[
|
return chain(*[[
|
||||||
format_html(
|
format_html(
|
||||||
'<link href="{0}" type="text/css" media="{1}" rel="stylesheet" />',
|
'<link href="{}" type="text/css" media="{}" rel="stylesheet" />',
|
||||||
self.absolute_path(path), medium
|
self.absolute_path(path), medium
|
||||||
) for path in self._css[medium]
|
) for path in self._css[medium]
|
||||||
] for medium in media])
|
] for medium in media])
|
||||||
|
@ -252,7 +252,7 @@ class Input(Widget):
|
||||||
if value != '':
|
if value != '':
|
||||||
# Only add the 'value' attribute if a value is non-empty.
|
# Only add the 'value' attribute if a value is non-empty.
|
||||||
final_attrs['value'] = force_text(self._format_value(value))
|
final_attrs['value'] = force_text(self._format_value(value))
|
||||||
return format_html('<input{0} />', flatatt(final_attrs))
|
return format_html('<input{} />', flatatt(final_attrs))
|
||||||
|
|
||||||
|
|
||||||
class TextInput(Input):
|
class TextInput(Input):
|
||||||
|
@ -315,7 +315,7 @@ class MultipleHiddenInput(HiddenInput):
|
||||||
# An ID attribute was given. Add a numeric index as a suffix
|
# An ID attribute was given. Add a numeric index as a suffix
|
||||||
# so that the inputs don't all have the same ID attribute.
|
# so that the inputs don't all have the same ID attribute.
|
||||||
input_attrs['id'] = '%s_%s' % (id_, i)
|
input_attrs['id'] = '%s_%s' % (id_, i)
|
||||||
inputs.append(format_html('<input{0} />', flatatt(input_attrs)))
|
inputs.append(format_html('<input{} />', flatatt(input_attrs)))
|
||||||
return mark_safe('\n'.join(inputs))
|
return mark_safe('\n'.join(inputs))
|
||||||
|
|
||||||
def value_from_datadict(self, data, files, name):
|
def value_from_datadict(self, data, files, name):
|
||||||
|
@ -429,7 +429,7 @@ class Textarea(Widget):
|
||||||
if value is None:
|
if value is None:
|
||||||
value = ''
|
value = ''
|
||||||
final_attrs = self.build_attrs(attrs, name=name)
|
final_attrs = self.build_attrs(attrs, name=name)
|
||||||
return format_html('<textarea{0}>\r\n{1}</textarea>',
|
return format_html('<textarea{}>\r\n{}</textarea>',
|
||||||
flatatt(final_attrs),
|
flatatt(final_attrs),
|
||||||
force_text(value))
|
force_text(value))
|
||||||
|
|
||||||
|
@ -478,7 +478,7 @@ class CheckboxInput(Widget):
|
||||||
if not (value is True or value is False or value is None or value == ''):
|
if not (value is True or value is False or value is None or value == ''):
|
||||||
# Only add the 'value' attribute if a value is non-empty.
|
# Only add the 'value' attribute if a value is non-empty.
|
||||||
final_attrs['value'] = force_text(value)
|
final_attrs['value'] = force_text(value)
|
||||||
return format_html('<input{0} />', flatatt(final_attrs))
|
return format_html('<input{} />', flatatt(final_attrs))
|
||||||
|
|
||||||
def value_from_datadict(self, data, files, name):
|
def value_from_datadict(self, data, files, name):
|
||||||
if name not in data:
|
if name not in data:
|
||||||
|
@ -507,7 +507,7 @@ class Select(Widget):
|
||||||
if value is None:
|
if value is None:
|
||||||
value = ''
|
value = ''
|
||||||
final_attrs = self.build_attrs(attrs, name=name)
|
final_attrs = self.build_attrs(attrs, name=name)
|
||||||
output = [format_html('<select{0}>', flatatt(final_attrs))]
|
output = [format_html('<select{}>', flatatt(final_attrs))]
|
||||||
options = self.render_options(choices, [value])
|
options = self.render_options(choices, [value])
|
||||||
if options:
|
if options:
|
||||||
output.append(options)
|
output.append(options)
|
||||||
|
@ -525,7 +525,7 @@ class Select(Widget):
|
||||||
selected_choices.remove(option_value)
|
selected_choices.remove(option_value)
|
||||||
else:
|
else:
|
||||||
selected_html = ''
|
selected_html = ''
|
||||||
return format_html('<option value="{0}"{1}>{2}</option>',
|
return format_html('<option value="{}"{}>{}</option>',
|
||||||
option_value,
|
option_value,
|
||||||
selected_html,
|
selected_html,
|
||||||
force_text(option_label))
|
force_text(option_label))
|
||||||
|
@ -536,7 +536,7 @@ class Select(Widget):
|
||||||
output = []
|
output = []
|
||||||
for option_value, option_label in chain(self.choices, choices):
|
for option_value, option_label in chain(self.choices, choices):
|
||||||
if isinstance(option_label, (list, tuple)):
|
if isinstance(option_label, (list, tuple)):
|
||||||
output.append(format_html('<optgroup label="{0}">', force_text(option_value)))
|
output.append(format_html('<optgroup label="{}">', force_text(option_value)))
|
||||||
for option in option_label:
|
for option in option_label:
|
||||||
output.append(self.render_option(selected_choices, *option))
|
output.append(self.render_option(selected_choices, *option))
|
||||||
output.append('</optgroup>')
|
output.append('</optgroup>')
|
||||||
|
@ -579,7 +579,7 @@ class SelectMultiple(Select):
|
||||||
if value is None:
|
if value is None:
|
||||||
value = []
|
value = []
|
||||||
final_attrs = self.build_attrs(attrs, name=name)
|
final_attrs = self.build_attrs(attrs, name=name)
|
||||||
output = [format_html('<select multiple="multiple"{0}>', flatatt(final_attrs))]
|
output = [format_html('<select multiple="multiple"{}>', flatatt(final_attrs))]
|
||||||
options = self.render_options(choices, value)
|
options = self.render_options(choices, value)
|
||||||
if options:
|
if options:
|
||||||
output.append(options)
|
output.append(options)
|
||||||
|
@ -615,12 +615,12 @@ class ChoiceInput(SubWidget):
|
||||||
|
|
||||||
def render(self, name=None, value=None, attrs=None, choices=()):
|
def render(self, name=None, value=None, attrs=None, choices=()):
|
||||||
if self.id_for_label:
|
if self.id_for_label:
|
||||||
label_for = format_html(' for="{0}"', self.id_for_label)
|
label_for = format_html(' for="{}"', self.id_for_label)
|
||||||
else:
|
else:
|
||||||
label_for = ''
|
label_for = ''
|
||||||
attrs = dict(self.attrs, **attrs) if attrs else self.attrs
|
attrs = dict(self.attrs, **attrs) if attrs else self.attrs
|
||||||
return format_html(
|
return format_html(
|
||||||
'<label{0}>{1} {2}</label>', label_for, self.tag(attrs), self.choice_label
|
'<label{}>{} {}</label>', label_for, self.tag(attrs), self.choice_label
|
||||||
)
|
)
|
||||||
|
|
||||||
def is_checked(self):
|
def is_checked(self):
|
||||||
|
@ -631,7 +631,7 @@ class ChoiceInput(SubWidget):
|
||||||
final_attrs = dict(attrs, type=self.input_type, name=self.name, value=self.choice_value)
|
final_attrs = dict(attrs, type=self.input_type, name=self.name, value=self.choice_value)
|
||||||
if self.is_checked():
|
if self.is_checked():
|
||||||
final_attrs['checked'] = 'checked'
|
final_attrs['checked'] = 'checked'
|
||||||
return format_html('<input{0} />', flatatt(final_attrs))
|
return format_html('<input{} />', flatatt(final_attrs))
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def id_for_label(self):
|
def id_for_label(self):
|
||||||
|
@ -693,7 +693,7 @@ class ChoiceFieldRenderer(object):
|
||||||
if isinstance(choice_label, (tuple, list)):
|
if isinstance(choice_label, (tuple, list)):
|
||||||
attrs_plus = self.attrs.copy()
|
attrs_plus = self.attrs.copy()
|
||||||
if id_:
|
if id_:
|
||||||
attrs_plus['id'] += '_{0}'.format(i)
|
attrs_plus['id'] += '_{}'.format(i)
|
||||||
sub_ul_renderer = ChoiceFieldRenderer(name=self.name,
|
sub_ul_renderer = ChoiceFieldRenderer(name=self.name,
|
||||||
value=self.value,
|
value=self.value,
|
||||||
attrs=attrs_plus,
|
attrs=attrs_plus,
|
||||||
|
@ -707,7 +707,7 @@ class ChoiceFieldRenderer(object):
|
||||||
output.append(format_html(self.inner_html,
|
output.append(format_html(self.inner_html,
|
||||||
choice_value=force_text(w), sub_widgets=''))
|
choice_value=force_text(w), sub_widgets=''))
|
||||||
return format_html(self.outer_html,
|
return format_html(self.outer_html,
|
||||||
id_attr=format_html(' id="{0}"', id_) if id_ else '',
|
id_attr=format_html(' id="{}"', id_) if id_ else '',
|
||||||
content=mark_safe('\n'.join(output)))
|
content=mark_safe('\n'.join(output)))
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -56,7 +56,7 @@ class CsrfTokenNode(Node):
|
||||||
if csrf_token == 'NOTPROVIDED':
|
if csrf_token == 'NOTPROVIDED':
|
||||||
return format_html("")
|
return format_html("")
|
||||||
else:
|
else:
|
||||||
return format_html("<input type='hidden' name='csrfmiddlewaretoken' value='{0}' />", csrf_token)
|
return format_html("<input type='hidden' name='csrfmiddlewaretoken' value='{}' />", csrf_token)
|
||||||
else:
|
else:
|
||||||
# It's very probable that the token is missing because of
|
# It's very probable that the token is missing because of
|
||||||
# misconfiguration, so we raise a warning
|
# misconfiguration, so we raise a warning
|
||||||
|
@ -195,7 +195,7 @@ class ForNode(Node):
|
||||||
# Check loop variable count before unpacking
|
# Check loop variable count before unpacking
|
||||||
if num_loopvars != len_item:
|
if num_loopvars != len_item:
|
||||||
warnings.warn(
|
warnings.warn(
|
||||||
"Need {0} values to unpack in for loop; got {1}. "
|
"Need {} values to unpack in for loop; got {}. "
|
||||||
"This will raise an exception in Django 2.0."
|
"This will raise an exception in Django 2.0."
|
||||||
.format(num_loopvars, len_item),
|
.format(num_loopvars, len_item),
|
||||||
RemovedInDjango20Warning)
|
RemovedInDjango20Warning)
|
||||||
|
|
|
@ -105,7 +105,7 @@ def format_html_join(sep, format_string, args_generator):
|
||||||
|
|
||||||
Example:
|
Example:
|
||||||
|
|
||||||
format_html_join('\n', "<li>{0} {1}</li>", ((u.first_name, u.last_name)
|
format_html_join('\n', "<li>{} {}</li>", ((u.first_name, u.last_name)
|
||||||
for u in users))
|
for u in users))
|
||||||
|
|
||||||
"""
|
"""
|
||||||
|
|
|
@ -109,7 +109,7 @@ class AdminEmailHandler(logging.Handler):
|
||||||
record.getMessage()
|
record.getMessage()
|
||||||
)
|
)
|
||||||
filter = get_exception_reporter_filter(request)
|
filter = get_exception_reporter_filter(request)
|
||||||
request_repr = '\n{0}'.format(force_text(filter.get_request_repr(request)))
|
request_repr = '\n{}'.format(force_text(filter.get_request_repr(request)))
|
||||||
except Exception:
|
except Exception:
|
||||||
subject = '%s: %s' % (
|
subject = '%s: %s' % (
|
||||||
record.levelname,
|
record.levelname,
|
||||||
|
|
|
@ -106,7 +106,7 @@ the assembly and transmission of a large CSV file::
|
||||||
# Generate a sequence of rows. The range is based on the maximum number of
|
# Generate a sequence of rows. The range is based on the maximum number of
|
||||||
# rows that can be handled by a single sheet in most spreadsheet
|
# rows that can be handled by a single sheet in most spreadsheet
|
||||||
# applications.
|
# applications.
|
||||||
rows = (["Row {0}".format(idx), str(idx)] for idx in range(65536))
|
rows = (["Row {}".format(idx), str(idx)] for idx in range(65536))
|
||||||
pseudo_buffer = Echo()
|
pseudo_buffer = Echo()
|
||||||
writer = csv.writer(pseudo_buffer)
|
writer = csv.writer(pseudo_buffer)
|
||||||
response = StreamingHttpResponse((writer.writerow(row) for row in rows),
|
response = StreamingHttpResponse((writer.writerow(row) for row in rows),
|
||||||
|
|
|
@ -325,7 +325,7 @@ the following ``render`` method after the existing ``__init__`` method::
|
||||||
value = force_text(self._format_value(value))
|
value = force_text(self._format_value(value))
|
||||||
final_attrs = {'href': mark_safe(smart_urlquote(value))}
|
final_attrs = {'href': mark_safe(smart_urlquote(value))}
|
||||||
html = format_html(
|
html = format_html(
|
||||||
'<p class="url">{0} <a {1}>{2}</a><br />{3} {4}</p>',
|
'<p class="url">{} <a {}>{}</a><br />{} {}</p>',
|
||||||
_('Currently:'), flatatt(final_attrs), value,
|
_('Currently:'), flatatt(final_attrs), value,
|
||||||
_('Change:'), html
|
_('Change:'), html
|
||||||
)
|
)
|
||||||
|
@ -443,7 +443,7 @@ This patch file contains all your changes and should look this:
|
||||||
+ value = force_text(self._format_value(value))
|
+ value = force_text(self._format_value(value))
|
||||||
+ final_attrs = {'href': mark_safe(smart_urlquote(value))}
|
+ final_attrs = {'href': mark_safe(smart_urlquote(value))}
|
||||||
+ html = format_html(
|
+ html = format_html(
|
||||||
+ '<p class="url">{0} <a {1}>{2}</a><br />{3} {4}</p>',
|
+ '<p class="url">{} <a {}>{}</a><br />{} {}</p>',
|
||||||
+ _('Currently:'), flatatt(final_attrs), value,
|
+ _('Currently:'), flatatt(final_attrs), value,
|
||||||
+ _('Change:'), html
|
+ _('Change:'), html
|
||||||
+ )
|
+ )
|
||||||
|
|
|
@ -590,7 +590,7 @@ subclass::
|
||||||
color_code = models.CharField(max_length=6)
|
color_code = models.CharField(max_length=6)
|
||||||
|
|
||||||
def colored_name(self):
|
def colored_name(self):
|
||||||
return format_html('<span style="color: #{0};">{1} {2}</span>',
|
return format_html('<span style="color: #{};">{} {}</span>',
|
||||||
self.color_code,
|
self.color_code,
|
||||||
self.first_name,
|
self.first_name,
|
||||||
self.last_name)
|
self.last_name)
|
||||||
|
@ -647,7 +647,7 @@ subclass::
|
||||||
color_code = models.CharField(max_length=6)
|
color_code = models.CharField(max_length=6)
|
||||||
|
|
||||||
def colored_first_name(self):
|
def colored_first_name(self):
|
||||||
return format_html('<span style="color: #{0};">{1}</span>',
|
return format_html('<span style="color: #{};">{}</span>',
|
||||||
self.color_code,
|
self.color_code,
|
||||||
self.first_name)
|
self.first_name)
|
||||||
|
|
||||||
|
@ -1060,7 +1060,7 @@ subclass::
|
||||||
# line by a linebreak
|
# line by a linebreak
|
||||||
return format_html_join(
|
return format_html_join(
|
||||||
mark_safe('<br/>'),
|
mark_safe('<br/>'),
|
||||||
'{0}',
|
'{}',
|
||||||
((line,) for line in instance.get_full_address()),
|
((line,) for line in instance.get_full_address()),
|
||||||
) or "<span class='errors'>I can't determine this address.</span>"
|
) or "<span class='errors'>I can't determine this address.</span>"
|
||||||
|
|
||||||
|
|
|
@ -605,7 +605,7 @@ escaping HTML.
|
||||||
|
|
||||||
You should instead use::
|
You should instead use::
|
||||||
|
|
||||||
format_html("{0} <b>{1}</b> {2}",
|
format_html("{} <b>{}</b> {}",
|
||||||
mark_safe(some_html), some_text, some_other_text)
|
mark_safe(some_html), some_text, some_other_text)
|
||||||
|
|
||||||
This has the advantage that you don't need to apply :func:`escape` to each
|
This has the advantage that you don't need to apply :func:`escape` to each
|
||||||
|
@ -627,7 +627,7 @@ escaping HTML.
|
||||||
``args_generator`` should be an iterator that returns the sequence of
|
``args_generator`` should be an iterator that returns the sequence of
|
||||||
``args`` that will be passed to :func:`format_html`. For example::
|
``args`` that will be passed to :func:`format_html`. For example::
|
||||||
|
|
||||||
format_html_join('\n', "<li>{0} {1}</li>", ((u.first_name, u.last_name)
|
format_html_join('\n', "<li>{} {}</li>", ((u.first_name, u.last_name)
|
||||||
for u in users))
|
for u in users))
|
||||||
|
|
||||||
.. function:: strip_tags(value)
|
.. function:: strip_tags(value)
|
||||||
|
|
|
@ -239,7 +239,7 @@ class FileUploadTests(TestCase):
|
||||||
for name, filename, _ in cases:
|
for name, filename, _ in cases:
|
||||||
payload.write("\r\n".join([
|
payload.write("\r\n".join([
|
||||||
'--' + client.BOUNDARY,
|
'--' + client.BOUNDARY,
|
||||||
'Content-Disposition: form-data; name="{0}"; filename="{1}"',
|
'Content-Disposition: form-data; name="{}"; filename="{}"',
|
||||||
'Content-Type: application/octet-stream',
|
'Content-Type: application/octet-stream',
|
||||||
'',
|
'',
|
||||||
'Oops.',
|
'Oops.',
|
||||||
|
@ -258,7 +258,7 @@ class FileUploadTests(TestCase):
|
||||||
result = json.loads(response.content.decode('utf-8'))
|
result = json.loads(response.content.decode('utf-8'))
|
||||||
for name, _, expected in cases:
|
for name, _, expected in cases:
|
||||||
got = result[name]
|
got = result[name]
|
||||||
self.assertEqual(expected, got, 'Mismatch for {0}'.format(name))
|
self.assertEqual(expected, got, 'Mismatch for {}'.format(name))
|
||||||
self.assertLess(len(got), 256,
|
self.assertLess(len(got), 256,
|
||||||
"Got a long file name (%s characters)." % len(got))
|
"Got a long file name (%s characters)." % len(got))
|
||||||
|
|
||||||
|
|
|
@ -1384,7 +1384,7 @@ class FormsTestCase(TestCase):
|
||||||
"""
|
"""
|
||||||
class CustomWidget(TextInput):
|
class CustomWidget(TextInput):
|
||||||
def render(self, name, value, attrs=None):
|
def render(self, name, value, attrs=None):
|
||||||
return format_html(str('<input{0} />'), ' id=custom')
|
return format_html(str('<input{} />'), ' id=custom')
|
||||||
|
|
||||||
class SampleForm(Form):
|
class SampleForm(Form):
|
||||||
name = CharField(widget=CustomWidget)
|
name = CharField(widget=CustomWidget)
|
||||||
|
|
|
@ -316,7 +316,7 @@ class EmptyLabelTestCase(TestCase):
|
||||||
m = f.save()
|
m = f.save()
|
||||||
self.assertEqual(expected, getattr(m, key))
|
self.assertEqual(expected, getattr(m, key))
|
||||||
self.assertEqual('No Preference',
|
self.assertEqual('No Preference',
|
||||||
getattr(m, 'get_{0}_display'.format(key))())
|
getattr(m, 'get_{}_display'.format(key))())
|
||||||
|
|
||||||
def test_empty_field_integer(self):
|
def test_empty_field_integer(self):
|
||||||
f = EmptyIntegerLabelChoiceForm()
|
f = EmptyIntegerLabelChoiceForm()
|
||||||
|
|
|
@ -319,12 +319,12 @@ class TemplateRegressionTests(TestCase):
|
||||||
# When the IfChangeNode stores state at 'self' it stays at '3' and skip the last yielded value below.
|
# When the IfChangeNode stores state at 'self' it stays at '3' and skip the last yielded value below.
|
||||||
iter2 = iter([1, 2, 3])
|
iter2 = iter([1, 2, 3])
|
||||||
output2 = template.render(Context({'foo': range(3), 'get_value': lambda: next(iter2)}))
|
output2 = template.render(Context({'foo': range(3), 'get_value': lambda: next(iter2)}))
|
||||||
self.assertEqual(output2, '[0,1,2,3]', 'Expected [0,1,2,3] in second parallel template, got {0}'.format(output2))
|
self.assertEqual(output2, '[0,1,2,3]', 'Expected [0,1,2,3] in second parallel template, got {}'.format(output2))
|
||||||
yield 3
|
yield 3
|
||||||
|
|
||||||
gen1 = gen()
|
gen1 = gen()
|
||||||
output1 = template.render(Context({'foo': range(3), 'get_value': lambda: next(gen1)}))
|
output1 = template.render(Context({'foo': range(3), 'get_value': lambda: next(gen1)}))
|
||||||
self.assertEqual(output1, '[0,1,2,3]', 'Expected [0,1,2,3] in first template, got {0}'.format(output1))
|
self.assertEqual(output1, '[0,1,2,3]', 'Expected [0,1,2,3] in first template, got {}'.format(output1))
|
||||||
|
|
||||||
def test_cache_regression_20130(self):
|
def test_cache_regression_20130(self):
|
||||||
t = Template('{% load cache %}{% cache 1 regression_20130 %}foo{% endcache %}')
|
t = Template('{% load cache %}{% cache 1 regression_20130 %}foo{% endcache %}')
|
||||||
|
|
|
@ -43,7 +43,7 @@ class TestUtilsHtml(TestCase):
|
||||||
|
|
||||||
def test_format_html(self):
|
def test_format_html(self):
|
||||||
self.assertEqual(
|
self.assertEqual(
|
||||||
html.format_html("{0} {1} {third} {fourth}",
|
html.format_html("{} {} {third} {fourth}",
|
||||||
"< Dangerous >",
|
"< Dangerous >",
|
||||||
html.mark_safe("<b>safe</b>"),
|
html.mark_safe("<b>safe</b>"),
|
||||||
third="< dangerous again",
|
third="< dangerous again",
|
||||||
|
|
|
@ -28,13 +28,13 @@ class TestNumberFormat(TestCase):
|
||||||
self.assertEqual(nformat('-1234.33', '.', decimal_pos=1), '-1234.3')
|
self.assertEqual(nformat('-1234.33', '.', decimal_pos=1), '-1234.3')
|
||||||
|
|
||||||
def test_large_number(self):
|
def test_large_number(self):
|
||||||
most_max = ('{0}179769313486231570814527423731704356798070567525844996'
|
most_max = ('{}179769313486231570814527423731704356798070567525844996'
|
||||||
'598917476803157260780028538760589558632766878171540458953'
|
'598917476803157260780028538760589558632766878171540458953'
|
||||||
'514382464234321326889464182768467546703537516986049910576'
|
'514382464234321326889464182768467546703537516986049910576'
|
||||||
'551282076245490090389328944075868508455133942304583236903'
|
'551282076245490090389328944075868508455133942304583236903'
|
||||||
'222948165808559332123348274797826204144723168738177180919'
|
'222948165808559332123348274797826204144723168738177180919'
|
||||||
'29988125040402618412485836{1}')
|
'29988125040402618412485836{}')
|
||||||
most_max2 = ('{0}35953862697246314162905484746340871359614113505168999'
|
most_max2 = ('{}35953862697246314162905484746340871359614113505168999'
|
||||||
'31978349536063145215600570775211791172655337563430809179'
|
'31978349536063145215600570775211791172655337563430809179'
|
||||||
'07028764928468642653778928365536935093407075033972099821'
|
'07028764928468642653778928365536935093407075033972099821'
|
||||||
'15310256415249098018077865788815173701691026788460916647'
|
'15310256415249098018077865788815173701691026788460916647'
|
||||||
|
|
|
@ -17,7 +17,7 @@ class SafeJoinTests(unittest.TestCase):
|
||||||
drive, path = os.path.splitdrive(safe_join("/", "path"))
|
drive, path = os.path.splitdrive(safe_join("/", "path"))
|
||||||
self.assertEqual(
|
self.assertEqual(
|
||||||
path,
|
path,
|
||||||
"{0}path".format(os.path.sep),
|
"{}path".format(os.path.sep),
|
||||||
)
|
)
|
||||||
|
|
||||||
drive, path = os.path.splitdrive(safe_join("/", ""))
|
drive, path = os.path.splitdrive(safe_join("/", ""))
|
||||||
|
|
Loading…
Reference in New Issue