mirror of
				https://github.com/django/django.git
				synced 2025-10-24 22:26:08 +00:00 
			
		
		
		
	Refs #27795 -- Removed unneeded force_text calls
Thanks Tim Graham for the review.
This commit is contained in:
		| @@ -14,12 +14,11 @@ def setup(set_prefix=True): | |||||||
|     from django.apps import apps |     from django.apps import apps | ||||||
|     from django.conf import settings |     from django.conf import settings | ||||||
|     from django.urls import set_script_prefix |     from django.urls import set_script_prefix | ||||||
|     from django.utils.encoding import force_text |  | ||||||
|     from django.utils.log import configure_logging |     from django.utils.log import configure_logging | ||||||
|  |  | ||||||
|     configure_logging(settings.LOGGING_CONFIG, settings.LOGGING) |     configure_logging(settings.LOGGING_CONFIG, settings.LOGGING) | ||||||
|     if set_prefix: |     if set_prefix: | ||||||
|         set_script_prefix( |         set_script_prefix( | ||||||
|             '/' if settings.FORCE_SCRIPT_NAME is None else force_text(settings.FORCE_SCRIPT_NAME) |             '/' if settings.FORCE_SCRIPT_NAME is None else settings.FORCE_SCRIPT_NAME | ||||||
|         ) |         ) | ||||||
|     apps.populate(settings.INSTALLED_APPS) |     apps.populate(settings.INSTALLED_APPS) | ||||||
|   | |||||||
| @@ -10,7 +10,6 @@ from django.core.exceptions import ObjectDoesNotExist | |||||||
| from django.db.models.fields.related import ManyToManyRel | from django.db.models.fields.related import ManyToManyRel | ||||||
| from django.forms.utils import flatatt | from django.forms.utils import flatatt | ||||||
| from django.template.defaultfilters import capfirst, linebreaksbr | from django.template.defaultfilters import capfirst, linebreaksbr | ||||||
| from django.utils.encoding import force_text |  | ||||||
| from django.utils.html import conditional_escape, format_html | from django.utils.html import conditional_escape, format_html | ||||||
| from django.utils.safestring import mark_safe | from django.utils.safestring import mark_safe | ||||||
| from django.utils.translation import gettext, gettext_lazy as _ | from django.utils.translation import gettext, gettext_lazy as _ | ||||||
| @@ -135,7 +134,7 @@ class AdminField: | |||||||
|  |  | ||||||
|     def label_tag(self): |     def label_tag(self): | ||||||
|         classes = [] |         classes = [] | ||||||
|         contents = conditional_escape(force_text(self.field.label)) |         contents = conditional_escape(self.field.label) | ||||||
|         if self.is_checkbox: |         if self.is_checkbox: | ||||||
|             classes.append('vCheckboxLabel') |             classes.append('vCheckboxLabel') | ||||||
|  |  | ||||||
| @@ -193,9 +192,7 @@ class AdminReadonlyField: | |||||||
|         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{}>{}:</label>', |         return format_html('<label{}>{}:</label>', flatatt(attrs), capfirst(label)) | ||||||
|                            flatatt(attrs), |  | ||||||
|                            capfirst(force_text(label))) |  | ||||||
|  |  | ||||||
|     def contents(self): |     def contents(self): | ||||||
|         from django.contrib.admin.templatetags.admin_list import _boolean_icon |         from django.contrib.admin.templatetags.admin_list import _boolean_icon | ||||||
| @@ -213,7 +210,7 @@ class AdminReadonlyField: | |||||||
|                     if hasattr(value, "__html__"): |                     if hasattr(value, "__html__"): | ||||||
|                         result_repr = value |                         result_repr = value | ||||||
|                     else: |                     else: | ||||||
|                         result_repr = linebreaksbr(force_text(value)) |                         result_repr = linebreaksbr(value) | ||||||
|             else: |             else: | ||||||
|                 if isinstance(f.remote_field, ManyToManyRel) and value is not None: |                 if isinstance(f.remote_field, ManyToManyRel) and value is not None: | ||||||
|                     result_repr = ", ".join(map(str, value.all())) |                     result_repr = ", ".join(map(str, value.all())) | ||||||
|   | |||||||
| @@ -1058,7 +1058,7 @@ class ModelAdmin(BaseModelAdmin): | |||||||
|         else: |         else: | ||||||
|             obj_repr = force_text(obj) |             obj_repr = force_text(obj) | ||||||
|         msg_dict = { |         msg_dict = { | ||||||
|             'name': force_text(opts.verbose_name), |             'name': opts.verbose_name, | ||||||
|             'obj': obj_repr, |             'obj': obj_repr, | ||||||
|         } |         } | ||||||
|         # Here, we distinguish between different save types by checking for |         # Here, we distinguish between different save types by checking for | ||||||
| @@ -1150,7 +1150,7 @@ class ModelAdmin(BaseModelAdmin): | |||||||
|         preserved_filters = self.get_preserved_filters(request) |         preserved_filters = self.get_preserved_filters(request) | ||||||
|  |  | ||||||
|         msg_dict = { |         msg_dict = { | ||||||
|             'name': force_text(opts.verbose_name), |             'name': opts.verbose_name, | ||||||
|             'obj': format_html('<a href="{}">{}</a>', urlquote(request.path), obj), |             'obj': format_html('<a href="{}">{}</a>', urlquote(request.path), obj), | ||||||
|         } |         } | ||||||
|         if "_continue" in request.POST: |         if "_continue" in request.POST: | ||||||
| @@ -1320,8 +1320,8 @@ class ModelAdmin(BaseModelAdmin): | |||||||
|         self.message_user( |         self.message_user( | ||||||
|             request, |             request, | ||||||
|             _('The %(name)s "%(obj)s" was deleted successfully.') % { |             _('The %(name)s "%(obj)s" was deleted successfully.') % { | ||||||
|                 'name': force_text(opts.verbose_name), |                 'name': opts.verbose_name, | ||||||
|                 'obj': force_text(obj_display), |                 'obj': obj_display, | ||||||
|             }, |             }, | ||||||
|             messages.SUCCESS, |             messages.SUCCESS, | ||||||
|         ) |         ) | ||||||
| @@ -1394,7 +1394,7 @@ class ModelAdmin(BaseModelAdmin): | |||||||
|         and return a redirect to the admin index page. |         and return a redirect to the admin index page. | ||||||
|         """ |         """ | ||||||
|         msg = _("""%(name)s with ID "%(key)s" doesn't exist. Perhaps it was deleted?""") % { |         msg = _("""%(name)s with ID "%(key)s" doesn't exist. Perhaps it was deleted?""") % { | ||||||
|             'name': force_text(opts.verbose_name), |             'name': opts.verbose_name, | ||||||
|             'key': unquote(object_id), |             'key': unquote(object_id), | ||||||
|         } |         } | ||||||
|         self.message_user(request, msg, messages.WARNING) |         self.message_user(request, msg, messages.WARNING) | ||||||
| @@ -1478,7 +1478,7 @@ class ModelAdmin(BaseModelAdmin): | |||||||
|  |  | ||||||
|         context = dict( |         context = dict( | ||||||
|             self.admin_site.each_context(request), |             self.admin_site.each_context(request), | ||||||
|             title=(_('Add %s') if add else _('Change %s')) % force_text(opts.verbose_name), |             title=(_('Add %s') if add else _('Change %s')) % opts.verbose_name, | ||||||
|             adminform=adminForm, |             adminform=adminForm, | ||||||
|             object_id=object_id, |             object_id=object_id, | ||||||
|             original=obj, |             original=obj, | ||||||
| @@ -1620,7 +1620,6 @@ class ModelAdmin(BaseModelAdmin): | |||||||
|                     ) % { |                     ) % { | ||||||
|                         'count': changecount, |                         'count': changecount, | ||||||
|                         'name': model_ngettext(opts, changecount), |                         'name': model_ngettext(opts, changecount), | ||||||
|                         'obj': force_text(obj), |  | ||||||
|                     } |                     } | ||||||
|                     self.message_user(request, msg, messages.SUCCESS) |                     self.message_user(request, msg, messages.SUCCESS) | ||||||
|  |  | ||||||
| @@ -1768,7 +1767,7 @@ class ModelAdmin(BaseModelAdmin): | |||||||
|  |  | ||||||
|         context = dict( |         context = dict( | ||||||
|             self.admin_site.each_context(request), |             self.admin_site.each_context(request), | ||||||
|             title=_('Change history: %s') % force_text(obj), |             title=_('Change history: %s') % obj, | ||||||
|             action_list=action_list, |             action_list=action_list, | ||||||
|             module_name=capfirst(force_text(opts.verbose_name_plural)), |             module_name=capfirst(force_text(opts.verbose_name_plural)), | ||||||
|             object=obj, |             object=obj, | ||||||
|   | |||||||
| @@ -281,7 +281,7 @@ def items_for_result(cl, result, form): | |||||||
|                 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{}>{}</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>{}</td>', force_text(form[cl.model._meta.pk.name])) |         yield format_html('<td>{}</td>', form[cl.model._meta.pk.name]) | ||||||
|  |  | ||||||
|  |  | ||||||
| class ResultList(list): | class ResultList(list): | ||||||
| @@ -308,7 +308,7 @@ def result_hidden_fields(cl): | |||||||
|     if cl.formset: |     if cl.formset: | ||||||
|         for res, form in zip(cl.result_list, cl.formset.forms): |         for res, form in zip(cl.result_list, cl.formset.forms): | ||||||
|             if form[cl.model._meta.pk.name].is_hidden: |             if form[cl.model._meta.pk.name].is_hidden: | ||||||
|                 yield mark_safe(force_text(form[cl.model._meta.pk.name])) |                 yield mark_safe(form[cl.model._meta.pk.name]) | ||||||
|  |  | ||||||
|  |  | ||||||
| @register.inclusion_tag("admin/change_list_results.html") | @register.inclusion_tag("admin/change_list_results.html") | ||||||
|   | |||||||
| @@ -11,7 +11,7 @@ from django.db.models.sql.constants import QUERY_TERMS | |||||||
| from django.forms.utils import pretty_name | from django.forms.utils import pretty_name | ||||||
| from django.urls import NoReverseMatch, reverse | from django.urls import NoReverseMatch, reverse | ||||||
| from django.utils import formats, timezone | from django.utils import formats, timezone | ||||||
| from django.utils.encoding import force_text, smart_text | from django.utils.encoding import force_text | ||||||
| from django.utils.html import format_html | from django.utils.html import format_html | ||||||
| from django.utils.text import capfirst | from django.utils.text import capfirst | ||||||
| from django.utils.translation import ngettext, override as translation_override | from django.utils.translation import ngettext, override as translation_override | ||||||
| @@ -136,8 +136,7 @@ def get_deleted_objects(objs, opts, user, admin_site, using): | |||||||
|         has_admin = obj.__class__ in admin_site._registry |         has_admin = obj.__class__ in admin_site._registry | ||||||
|         opts = obj._meta |         opts = obj._meta | ||||||
|  |  | ||||||
|         no_edit_link = '%s: %s' % (capfirst(opts.verbose_name), |         no_edit_link = '%s: %s' % (capfirst(opts.verbose_name), obj) | ||||||
|                                    force_text(obj)) |  | ||||||
|  |  | ||||||
|         if has_admin: |         if has_admin: | ||||||
|             try: |             try: | ||||||
| @@ -249,8 +248,8 @@ def model_format_dict(obj): | |||||||
|     else: |     else: | ||||||
|         opts = obj |         opts = obj | ||||||
|     return { |     return { | ||||||
|         'verbose_name': force_text(opts.verbose_name), |         'verbose_name': opts.verbose_name, | ||||||
|         'verbose_name_plural': force_text(opts.verbose_name_plural) |         'verbose_name_plural': opts.verbose_name_plural, | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -384,7 +383,7 @@ def help_text_for_field(name, model): | |||||||
|     else: |     else: | ||||||
|         if hasattr(field, 'help_text'): |         if hasattr(field, 'help_text'): | ||||||
|             help_text = field.help_text |             help_text = field.help_text | ||||||
|     return smart_text(help_text) |     return help_text | ||||||
|  |  | ||||||
|  |  | ||||||
| def display_for_field(value, field, empty_value_display): | def display_for_field(value, field, empty_value_display): | ||||||
|   | |||||||
| @@ -16,7 +16,6 @@ from django.core.exceptions import ( | |||||||
| from django.core.paginator import InvalidPage | from django.core.paginator import InvalidPage | ||||||
| from django.db import models | from django.db import models | ||||||
| from django.urls import reverse | from django.urls import reverse | ||||||
| from django.utils.encoding import force_text |  | ||||||
| from django.utils.http import urlencode | from django.utils.http import urlencode | ||||||
| from django.utils.translation import gettext | from django.utils.translation import gettext | ||||||
|  |  | ||||||
| @@ -79,7 +78,7 @@ class ChangeList: | |||||||
|             title = gettext('Select %s') |             title = gettext('Select %s') | ||||||
|         else: |         else: | ||||||
|             title = gettext('Select %s to change') |             title = gettext('Select %s to change') | ||||||
|         self.title = title % force_text(self.opts.verbose_name) |         self.title = title % self.opts.verbose_name | ||||||
|         self.pk_attname = self.lookup_opts.pk.attname |         self.pk_attname = self.lookup_opts.pk.attname | ||||||
|  |  | ||||||
|     def get_filters_params(self, params=None): |     def get_filters_params(self, params=None): | ||||||
|   | |||||||
| @@ -14,7 +14,6 @@ from django.http import Http404, HttpResponseRedirect | |||||||
| from django.template.response import TemplateResponse | from django.template.response import TemplateResponse | ||||||
| from django.urls import reverse | from django.urls import reverse | ||||||
| from django.utils.decorators import method_decorator | from django.utils.decorators import method_decorator | ||||||
| from django.utils.encoding import force_text |  | ||||||
| from django.utils.html import escape | from django.utils.html import escape | ||||||
| from django.utils.translation import gettext, gettext_lazy as _ | from django.utils.translation import gettext, gettext_lazy as _ | ||||||
| from django.views.decorators.csrf import csrf_protect | from django.views.decorators.csrf import csrf_protect | ||||||
| @@ -135,7 +134,7 @@ class UserAdmin(admin.ModelAdmin): | |||||||
|         user = self.get_object(request, unquote(id)) |         user = self.get_object(request, unquote(id)) | ||||||
|         if user is None: |         if user is None: | ||||||
|             raise Http404(_('%(name)s object with primary key %(key)r does not exist.') % { |             raise Http404(_('%(name)s object with primary key %(key)r does not exist.') % { | ||||||
|                 'name': force_text(self.model._meta.verbose_name), |                 'name': self.model._meta.verbose_name, | ||||||
|                 'key': escape(id), |                 'key': escape(id), | ||||||
|             }) |             }) | ||||||
|         if request.method == 'POST': |         if request.method == 'POST': | ||||||
|   | |||||||
| @@ -10,7 +10,6 @@ from django.contrib.auth.hashers import ( | |||||||
| ) | ) | ||||||
| from django.db import models | from django.db import models | ||||||
| from django.utils.crypto import get_random_string, salted_hmac | from django.utils.crypto import get_random_string, salted_hmac | ||||||
| from django.utils.encoding import force_text |  | ||||||
| from django.utils.translation import gettext_lazy as _ | from django.utils.translation import gettext_lazy as _ | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -142,4 +141,4 @@ class AbstractBaseUser(models.Model): | |||||||
|  |  | ||||||
|     @classmethod |     @classmethod | ||||||
|     def normalize_username(cls, username): |     def normalize_username(cls, username): | ||||||
|         return unicodedata.normalize('NFKC', force_text(username)) |         return unicodedata.normalize('NFKC', username) if username else username | ||||||
|   | |||||||
| @@ -19,7 +19,6 @@ from django.template.response import TemplateResponse | |||||||
| from django.urls import reverse, reverse_lazy | from django.urls import reverse, reverse_lazy | ||||||
| from django.utils.decorators import method_decorator | from django.utils.decorators import method_decorator | ||||||
| from django.utils.deprecation import RemovedInDjango21Warning | from django.utils.deprecation import RemovedInDjango21Warning | ||||||
| from django.utils.encoding import force_text |  | ||||||
| from django.utils.http import is_safe_url, urlsafe_base64_decode | from django.utils.http import is_safe_url, urlsafe_base64_decode | ||||||
| from django.utils.translation import gettext_lazy as _ | from django.utils.translation import gettext_lazy as _ | ||||||
| from django.views.decorators.cache import never_cache | from django.views.decorators.cache import never_cache | ||||||
| @@ -303,7 +302,7 @@ def password_reset_confirm(request, uidb64=None, token=None, | |||||||
|         post_reset_redirect = resolve_url(post_reset_redirect) |         post_reset_redirect = resolve_url(post_reset_redirect) | ||||||
|     try: |     try: | ||||||
|         # urlsafe_base64_decode() decodes to bytestring |         # urlsafe_base64_decode() decodes to bytestring | ||||||
|         uid = force_text(urlsafe_base64_decode(uidb64)) |         uid = urlsafe_base64_decode(uidb64).decode() | ||||||
|         user = UserModel._default_manager.get(pk=uid) |         user = UserModel._default_manager.get(pk=uid) | ||||||
|     except (TypeError, ValueError, OverflowError, UserModel.DoesNotExist): |     except (TypeError, ValueError, OverflowError, UserModel.DoesNotExist): | ||||||
|         user = None |         user = None | ||||||
| @@ -447,7 +446,7 @@ class PasswordResetConfirmView(PasswordContextMixin, FormView): | |||||||
|     def get_user(self, uidb64): |     def get_user(self, uidb64): | ||||||
|         try: |         try: | ||||||
|             # urlsafe_base64_decode() decodes to bytestring |             # urlsafe_base64_decode() decodes to bytestring | ||||||
|             uid = force_text(urlsafe_base64_decode(uidb64)) |             uid = urlsafe_base64_decode(uidb64).decode() | ||||||
|             user = UserModel._default_manager.get(pk=uid) |             user = UserModel._default_manager.get(pk=uid) | ||||||
|         except (TypeError, ValueError, OverflowError, UserModel.DoesNotExist): |         except (TypeError, ValueError, OverflowError, UserModel.DoesNotExist): | ||||||
|             user = None |             user = None | ||||||
|   | |||||||
| @@ -7,7 +7,6 @@ from django.contrib.staticfiles.storage import staticfiles_storage | |||||||
| from django.core.files.storage import FileSystemStorage | from django.core.files.storage import FileSystemStorage | ||||||
| from django.core.management.base import BaseCommand, CommandError | from django.core.management.base import BaseCommand, CommandError | ||||||
| from django.core.management.color import no_style | from django.core.management.color import no_style | ||||||
| from django.utils.encoding import force_text |  | ||||||
| from django.utils.functional import cached_property | from django.utils.functional import cached_property | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -234,9 +233,9 @@ class Command(BaseCommand): | |||||||
|         for f in files: |         for f in files: | ||||||
|             fpath = os.path.join(path, f) |             fpath = os.path.join(path, f) | ||||||
|             if self.dry_run: |             if self.dry_run: | ||||||
|                 self.log("Pretending to delete '%s'" % force_text(fpath), level=1) |                 self.log("Pretending to delete '%s'" % fpath, level=1) | ||||||
|             else: |             else: | ||||||
|                 self.log("Deleting '%s'" % force_text(fpath), level=1) |                 self.log("Deleting '%s'" % fpath, level=1) | ||||||
|                 try: |                 try: | ||||||
|                     full_path = self.storage.path(fpath) |                     full_path = self.storage.path(fpath) | ||||||
|                 except NotImplementedError: |                 except NotImplementedError: | ||||||
|   | |||||||
| @@ -2,7 +2,6 @@ import os | |||||||
|  |  | ||||||
| from django.contrib.staticfiles import finders | from django.contrib.staticfiles import finders | ||||||
| from django.core.management.base import LabelCommand | from django.core.management.base import LabelCommand | ||||||
| from django.utils.encoding import force_text |  | ||||||
|  |  | ||||||
|  |  | ||||||
| class Command(LabelCommand): | class Command(LabelCommand): | ||||||
| @@ -20,18 +19,17 @@ class Command(LabelCommand): | |||||||
|     def handle_label(self, path, **options): |     def handle_label(self, path, **options): | ||||||
|         verbosity = options['verbosity'] |         verbosity = options['verbosity'] | ||||||
|         result = finders.find(path, all=options['all']) |         result = finders.find(path, all=options['all']) | ||||||
|         path = force_text(path) |  | ||||||
|         if verbosity >= 2: |         if verbosity >= 2: | ||||||
|             searched_locations = ( |             searched_locations = ( | ||||||
|                 "\nLooking in the following locations:\n  %s" % |                 "\nLooking in the following locations:\n  %s" % | ||||||
|                 "\n  ".join(force_text(location) for location in finders.searched_locations) |                 "\n  ".join(finders.searched_locations) | ||||||
|             ) |             ) | ||||||
|         else: |         else: | ||||||
|             searched_locations = '' |             searched_locations = '' | ||||||
|         if result: |         if result: | ||||||
|             if not isinstance(result, (list, tuple)): |             if not isinstance(result, (list, tuple)): | ||||||
|                 result = [result] |                 result = [result] | ||||||
|             result = (force_text(os.path.realpath(path)) for path in result) |             result = (os.path.realpath(path) for path in result) | ||||||
|             if verbosity >= 1: |             if verbosity >= 1: | ||||||
|                 file_list = '\n  '.join(result) |                 file_list = '\n  '.join(result) | ||||||
|                 return ("Found '%s' here:\n  %s%s" % |                 return ("Found '%s' here:\n  %s%s" % | ||||||
|   | |||||||
| @@ -14,7 +14,7 @@ from django.core.cache import ( | |||||||
| from django.core.exceptions import ImproperlyConfigured | from django.core.exceptions import ImproperlyConfigured | ||||||
| from django.core.files.base import ContentFile | from django.core.files.base import ContentFile | ||||||
| from django.core.files.storage import FileSystemStorage, get_storage_class | from django.core.files.storage import FileSystemStorage, get_storage_class | ||||||
| from django.utils.encoding import force_bytes, force_text | from django.utils.encoding import force_bytes | ||||||
| from django.utils.functional import LazyObject | from django.utils.functional import LazyObject | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -308,7 +308,7 @@ class HashedFilesMixin: | |||||||
|                         self.delete(hashed_name) |                         self.delete(hashed_name) | ||||||
|  |  | ||||||
|                     saved_name = self._save(hashed_name, content_file) |                     saved_name = self._save(hashed_name, content_file) | ||||||
|                     hashed_name = force_text(self.clean_name(saved_name)) |                     hashed_name = self.clean_name(saved_name) | ||||||
|                     # If the file hash stayed the same, this file didn't change |                     # If the file hash stayed the same, this file didn't change | ||||||
|                     if old_hashed_name == hashed_name: |                     if old_hashed_name == hashed_name: | ||||||
|                         substitutions = False |                         substitutions = False | ||||||
| @@ -320,7 +320,7 @@ class HashedFilesMixin: | |||||||
|                     if not hashed_file_exists: |                     if not hashed_file_exists: | ||||||
|                         processed = True |                         processed = True | ||||||
|                         saved_name = self._save(hashed_name, original_file) |                         saved_name = self._save(hashed_name, original_file) | ||||||
|                         hashed_name = force_text(self.clean_name(saved_name)) |                         hashed_name = self.clean_name(saved_name) | ||||||
|  |  | ||||||
|                 # and then set the cache accordingly |                 # and then set the cache accordingly | ||||||
|                 hashed_files[hash_key] = hashed_name |                 hashed_files[hash_key] = hashed_name | ||||||
|   | |||||||
| @@ -2,7 +2,6 @@ import os | |||||||
| from io import BytesIO, StringIO, UnsupportedOperation | from io import BytesIO, StringIO, UnsupportedOperation | ||||||
|  |  | ||||||
| from django.core.files.utils import FileProxyMixin | from django.core.files.utils import FileProxyMixin | ||||||
| from django.utils.encoding import force_text |  | ||||||
|  |  | ||||||
|  |  | ||||||
| class File(FileProxyMixin): | class File(FileProxyMixin): | ||||||
| @@ -17,7 +16,7 @@ class File(FileProxyMixin): | |||||||
|             self.mode = file.mode |             self.mode = file.mode | ||||||
|  |  | ||||||
|     def __str__(self): |     def __str__(self): | ||||||
|         return force_text(self.name or '') |         return self.name or '' | ||||||
|  |  | ||||||
|     def __repr__(self): |     def __repr__(self): | ||||||
|         return "<%s: %s>" % (self.__class__.__name__, self or "None") |         return "<%s: %s>" % (self.__class__.__name__, self or "None") | ||||||
|   | |||||||
| @@ -11,7 +11,7 @@ from django.utils import timezone | |||||||
| from django.utils._os import safe_join | from django.utils._os import safe_join | ||||||
| from django.utils.crypto import get_random_string | from django.utils.crypto import get_random_string | ||||||
| from django.utils.deconstruct import deconstructible | from django.utils.deconstruct import deconstructible | ||||||
| from django.utils.encoding import filepath_to_uri, force_text | from django.utils.encoding import filepath_to_uri | ||||||
| from django.utils.functional import LazyObject, cached_property | from django.utils.functional import LazyObject, cached_property | ||||||
| from django.utils.module_loading import import_string | from django.utils.module_loading import import_string | ||||||
| from django.utils.text import get_valid_filename | from django.utils.text import get_valid_filename | ||||||
| @@ -288,7 +288,7 @@ class FileSystemStorage(Storage): | |||||||
|             os.chmod(full_path, self.file_permissions_mode) |             os.chmod(full_path, self.file_permissions_mode) | ||||||
|  |  | ||||||
|         # Store filenames with forward slashes, even on Windows. |         # Store filenames with forward slashes, even on Windows. | ||||||
|         return force_text(name.replace('\\', '/')) |         return name.replace('\\', '/') | ||||||
|  |  | ||||||
|     def delete(self, name): |     def delete(self, name): | ||||||
|         assert name, "The name argument is not allowed to be empty." |         assert name, "The name argument is not allowed to be empty." | ||||||
|   | |||||||
| @@ -8,7 +8,7 @@ from django.core import signals | |||||||
| from django.core.handlers import base | from django.core.handlers import base | ||||||
| from django.http import HttpRequest, QueryDict, parse_cookie | from django.http import HttpRequest, QueryDict, parse_cookie | ||||||
| from django.urls import set_script_prefix | from django.urls import set_script_prefix | ||||||
| from django.utils.encoding import force_text, repercent_broken_unicode | from django.utils.encoding import repercent_broken_unicode | ||||||
| from django.utils.functional import cached_property | from django.utils.functional import cached_property | ||||||
|  |  | ||||||
| _slashes_re = re.compile(br'/+') | _slashes_re = re.compile(br'/+') | ||||||
| @@ -173,7 +173,7 @@ def get_script_name(environ): | |||||||
|     set (to anything). |     set (to anything). | ||||||
|     """ |     """ | ||||||
|     if settings.FORCE_SCRIPT_NAME is not None: |     if settings.FORCE_SCRIPT_NAME is not None: | ||||||
|         return force_text(settings.FORCE_SCRIPT_NAME) |         return settings.FORCE_SCRIPT_NAME | ||||||
|  |  | ||||||
|     # If Apache's mod_rewrite had a whack at the URL, Apache set either |     # If Apache's mod_rewrite had a whack at the URL, Apache set either | ||||||
|     # SCRIPT_URL or REDIRECT_URL to the full resource URL before applying any |     # SCRIPT_URL or REDIRECT_URL to the full resource URL before applying any | ||||||
|   | |||||||
| @@ -6,7 +6,6 @@ from django.db import ( | |||||||
|     DEFAULT_DB_ALIAS, connections, models, router, transaction, |     DEFAULT_DB_ALIAS, connections, models, router, transaction, | ||||||
| ) | ) | ||||||
| from django.db.utils import DatabaseError | from django.db.utils import DatabaseError | ||||||
| from django.utils.encoding import force_text |  | ||||||
|  |  | ||||||
|  |  | ||||||
| class Command(BaseCommand): | class Command(BaseCommand): | ||||||
| @@ -101,7 +100,7 @@ class Command(BaseCommand): | |||||||
|                 except DatabaseError as e: |                 except DatabaseError as e: | ||||||
|                     raise CommandError( |                     raise CommandError( | ||||||
|                         "Cache table '%s' could not be created.\nThe error was: %s." % |                         "Cache table '%s' could not be created.\nThe error was: %s." % | ||||||
|                         (tablename, force_text(e))) |                         (tablename, e)) | ||||||
|                 for statement in index_output: |                 for statement in index_output: | ||||||
|                     curs.execute(statement) |                     curs.execute(statement) | ||||||
|  |  | ||||||
|   | |||||||
| @@ -5,7 +5,6 @@ from collections import OrderedDict | |||||||
| from django.core.management.base import BaseCommand, CommandError | from django.core.management.base import BaseCommand, CommandError | ||||||
| from django.db import DEFAULT_DB_ALIAS, connections | from django.db import DEFAULT_DB_ALIAS, connections | ||||||
| from django.db.models.constants import LOOKUP_SEP | from django.db.models.constants import LOOKUP_SEP | ||||||
| from django.utils.encoding import force_text |  | ||||||
|  |  | ||||||
|  |  | ||||||
| class Command(BaseCommand): | class Command(BaseCommand): | ||||||
| @@ -79,7 +78,7 @@ class Command(BaseCommand): | |||||||
|                     table_description = connection.introspection.get_table_description(cursor, table_name) |                     table_description = connection.introspection.get_table_description(cursor, table_name) | ||||||
|                 except Exception as e: |                 except Exception as e: | ||||||
|                     yield "# Unable to inspect table '%s'" % table_name |                     yield "# Unable to inspect table '%s'" % table_name | ||||||
|                     yield "# The error was: %s" % force_text(e) |                     yield "# The error was: %s" % e | ||||||
|                     continue |                     continue | ||||||
|  |  | ||||||
|                 yield '' |                 yield '' | ||||||
|   | |||||||
| @@ -17,7 +17,6 @@ from django.db import ( | |||||||
|     DEFAULT_DB_ALIAS, DatabaseError, IntegrityError, connections, router, |     DEFAULT_DB_ALIAS, DatabaseError, IntegrityError, connections, router, | ||||||
|     transaction, |     transaction, | ||||||
| ) | ) | ||||||
| from django.utils.encoding import force_text |  | ||||||
| from django.utils.functional import cached_property | from django.utils.functional import cached_property | ||||||
|  |  | ||||||
| try: | try: | ||||||
| @@ -177,7 +176,7 @@ class Command(BaseCommand): | |||||||
|                                 'app_label': obj.object._meta.app_label, |                                 'app_label': obj.object._meta.app_label, | ||||||
|                                 'object_name': obj.object._meta.object_name, |                                 'object_name': obj.object._meta.object_name, | ||||||
|                                 'pk': obj.object.pk, |                                 'pk': obj.object.pk, | ||||||
|                                 'error_msg': force_text(e) |                                 'error_msg': e, | ||||||
|                             },) |                             },) | ||||||
|                             raise |                             raise | ||||||
|                 if objects and show_progress: |                 if objects and show_progress: | ||||||
|   | |||||||
| @@ -11,7 +11,6 @@ from django.core.servers.basehttp import ( | |||||||
|     WSGIServer, get_internal_wsgi_application, run, |     WSGIServer, get_internal_wsgi_application, run, | ||||||
| ) | ) | ||||||
| from django.utils import autoreload | from django.utils import autoreload | ||||||
| from django.utils.encoding import force_text |  | ||||||
|  |  | ||||||
|  |  | ||||||
| naiveip_re = re.compile(r"""^(?: | naiveip_re = re.compile(r"""^(?: | ||||||
| @@ -151,7 +150,7 @@ class Command(BaseCommand): | |||||||
|             try: |             try: | ||||||
|                 error_text = ERRORS[e.errno] |                 error_text = ERRORS[e.errno] | ||||||
|             except KeyError: |             except KeyError: | ||||||
|                 error_text = force_text(e) |                 error_text = e | ||||||
|             self.stderr.write("Error: %s" % error_text) |             self.stderr.write("Error: %s" % error_text) | ||||||
|             # Need to use an OS exit because sys.exit doesn't work in a thread |             # Need to use an OS exit because sys.exit doesn't work in a thread | ||||||
|             os._exit(1) |             os._exit(1) | ||||||
|   | |||||||
| @@ -108,7 +108,6 @@ class URLValidator(RegexValidator): | |||||||
|             self.schemes = schemes |             self.schemes = schemes | ||||||
|  |  | ||||||
|     def __call__(self, value): |     def __call__(self, value): | ||||||
|         value = force_text(value) |  | ||||||
|         # Check first if the scheme is valid |         # Check first if the scheme is valid | ||||||
|         scheme = value.split('://')[0].lower() |         scheme = value.split('://')[0].lower() | ||||||
|         if scheme not in self.schemes: |         if scheme not in self.schemes: | ||||||
| @@ -188,8 +187,6 @@ class EmailValidator: | |||||||
|             self.domain_whitelist = whitelist |             self.domain_whitelist = whitelist | ||||||
|  |  | ||||||
|     def __call__(self, value): |     def __call__(self, value): | ||||||
|         value = force_text(value) |  | ||||||
|  |  | ||||||
|         if not value or '@' not in value: |         if not value or '@' not in value: | ||||||
|             raise ValidationError(self.message, code=self.code) |             raise ValidationError(self.message, code=self.code) | ||||||
|  |  | ||||||
|   | |||||||
| @@ -9,7 +9,6 @@ from django.db.backends.base.introspection import ( | |||||||
| from django.db.models.indexes import Index | from django.db.models.indexes import Index | ||||||
| from django.utils.datastructures import OrderedSet | from django.utils.datastructures import OrderedSet | ||||||
| from django.utils.deprecation import RemovedInDjango21Warning | from django.utils.deprecation import RemovedInDjango21Warning | ||||||
| from django.utils.encoding import force_text |  | ||||||
|  |  | ||||||
| FieldInfo = namedtuple('FieldInfo', FieldInfo._fields + ('extra',)) | FieldInfo = namedtuple('FieldInfo', FieldInfo._fields + ('extra',)) | ||||||
| InfoLine = namedtuple('InfoLine', 'col_name data_type max_len num_prec num_scale extra column_default') | InfoLine = namedtuple('InfoLine', 'col_name data_type max_len num_prec num_scale extra column_default') | ||||||
| @@ -79,7 +78,7 @@ class DatabaseIntrospection(BaseDatabaseIntrospection): | |||||||
|  |  | ||||||
|         fields = [] |         fields = [] | ||||||
|         for line in cursor.description: |         for line in cursor.description: | ||||||
|             col_name = force_text(line[0]) |             col_name = line[0] | ||||||
|             fields.append( |             fields.append( | ||||||
|                 FieldInfo(*( |                 FieldInfo(*( | ||||||
|                     (col_name,) + |                     (col_name,) + | ||||||
|   | |||||||
| @@ -5,7 +5,6 @@ from django.db.backends.base.introspection import ( | |||||||
| ) | ) | ||||||
| from django.db.models.indexes import Index | from django.db.models.indexes import Index | ||||||
| from django.utils.deprecation import RemovedInDjango21Warning | from django.utils.deprecation import RemovedInDjango21Warning | ||||||
| from django.utils.encoding import force_text |  | ||||||
|  |  | ||||||
|  |  | ||||||
| class DatabaseIntrospection(BaseDatabaseIntrospection): | class DatabaseIntrospection(BaseDatabaseIntrospection): | ||||||
| @@ -79,11 +78,8 @@ class DatabaseIntrospection(BaseDatabaseIntrospection): | |||||||
|         field_map = {line[0]: line[1:] for line in cursor.fetchall()} |         field_map = {line[0]: line[1:] for line in cursor.fetchall()} | ||||||
|         cursor.execute("SELECT * FROM %s LIMIT 1" % self.connection.ops.quote_name(table_name)) |         cursor.execute("SELECT * FROM %s LIMIT 1" % self.connection.ops.quote_name(table_name)) | ||||||
|         return [ |         return [ | ||||||
|             FieldInfo(*( |             FieldInfo(*(line[0:6] + (field_map[line.name][0] == 'YES', field_map[line.name][1]))) | ||||||
|                 (force_text(line[0]),) + |             for line in cursor.description | ||||||
|                 line[1:6] + |  | ||||||
|                 (field_map[force_text(line[0])][0] == 'YES', field_map[force_text(line[0])][1]) |  | ||||||
|             )) for line in cursor.description |  | ||||||
|         ] |         ] | ||||||
|  |  | ||||||
|     def get_relations(self, cursor, table_name): |     def get_relations(self, cursor, table_name): | ||||||
|   | |||||||
| @@ -4,14 +4,13 @@ import sys | |||||||
|  |  | ||||||
| from django.core.exceptions import ImproperlyConfigured | from django.core.exceptions import ImproperlyConfigured | ||||||
| from django.db.backends.base.creation import BaseDatabaseCreation | from django.db.backends.base.creation import BaseDatabaseCreation | ||||||
| from django.utils.encoding import force_text |  | ||||||
|  |  | ||||||
|  |  | ||||||
| class DatabaseCreation(BaseDatabaseCreation): | class DatabaseCreation(BaseDatabaseCreation): | ||||||
|  |  | ||||||
|     @staticmethod |     @staticmethod | ||||||
|     def is_in_memory_db(database_name): |     def is_in_memory_db(database_name): | ||||||
|         return database_name == ':memory:' or 'mode=memory' in force_text(database_name) |         return database_name == ':memory:' or 'mode=memory' in database_name | ||||||
|  |  | ||||||
|     def _get_test_db_name(self): |     def _get_test_db_name(self): | ||||||
|         test_database_name = self.connection.settings_dict['TEST']['NAME'] |         test_database_name = self.connection.settings_dict['TEST']['NAME'] | ||||||
|   | |||||||
| @@ -10,7 +10,6 @@ from django.db.models.fields.proxy import OrderWrt | |||||||
| from django.db.models.fields.related import RECURSIVE_RELATIONSHIP_CONSTANT | from django.db.models.fields.related import RECURSIVE_RELATIONSHIP_CONSTANT | ||||||
| from django.db.models.options import DEFAULT_NAMES, normalize_together | from django.db.models.options import DEFAULT_NAMES, normalize_together | ||||||
| from django.db.models.utils import make_model_tuple | from django.db.models.utils import make_model_tuple | ||||||
| from django.utils.encoding import force_text |  | ||||||
| from django.utils.functional import cached_property | from django.utils.functional import cached_property | ||||||
| from django.utils.module_loading import import_string | from django.utils.module_loading import import_string | ||||||
| from django.utils.version import get_docs_version | from django.utils.version import get_docs_version | ||||||
| @@ -363,7 +362,7 @@ class ModelState: | |||||||
|  |  | ||||||
|     def __init__(self, app_label, name, fields, options=None, bases=None, managers=None): |     def __init__(self, app_label, name, fields, options=None, bases=None, managers=None): | ||||||
|         self.app_label = app_label |         self.app_label = app_label | ||||||
|         self.name = force_text(name) |         self.name = name | ||||||
|         self.fields = fields |         self.fields = fields | ||||||
|         self.options = options or {} |         self.options = options or {} | ||||||
|         self.options.setdefault('indexes', []) |         self.options.setdefault('indexes', []) | ||||||
| @@ -411,7 +410,7 @@ class ModelState: | |||||||
|                 continue |                 continue | ||||||
|             if isinstance(field, OrderWrt): |             if isinstance(field, OrderWrt): | ||||||
|                 continue |                 continue | ||||||
|             name = force_text(field.name, strings_only=True) |             name = field.name | ||||||
|             try: |             try: | ||||||
|                 fields.append((name, field.clone())) |                 fields.append((name, field.clone())) | ||||||
|             except TypeError as e: |             except TypeError as e: | ||||||
| @@ -422,7 +421,7 @@ class ModelState: | |||||||
|                 )) |                 )) | ||||||
|         if not exclude_rels: |         if not exclude_rels: | ||||||
|             for field in model._meta.local_many_to_many: |             for field in model._meta.local_many_to_many: | ||||||
|                 name = force_text(field.name, strings_only=True) |                 name = field.name | ||||||
|                 try: |                 try: | ||||||
|                     fields.append((name, field.clone())) |                     fields.append((name, field.clone())) | ||||||
|                 except TypeError as e: |                 except TypeError as e: | ||||||
| @@ -489,8 +488,7 @@ class ModelState: | |||||||
|         manager_names = set() |         manager_names = set() | ||||||
|         default_manager_shim = None |         default_manager_shim = None | ||||||
|         for manager in model._meta.managers: |         for manager in model._meta.managers: | ||||||
|             manager_name = force_text(manager.name) |             if manager.name in manager_names: | ||||||
|             if manager_name in manager_names: |  | ||||||
|                 # Skip overridden managers. |                 # Skip overridden managers. | ||||||
|                 continue |                 continue | ||||||
|             elif manager.use_in_migrations: |             elif manager.use_in_migrations: | ||||||
| @@ -506,8 +504,8 @@ class ModelState: | |||||||
|                     default_manager_shim = new_manager |                     default_manager_shim = new_manager | ||||||
|             else: |             else: | ||||||
|                 continue |                 continue | ||||||
|             manager_names.add(manager_name) |             manager_names.add(manager.name) | ||||||
|             managers.append((manager_name, new_manager)) |             managers.append((manager.name, new_manager)) | ||||||
|  |  | ||||||
|         # Ignore a shimmed default manager called objects if it's the only one. |         # Ignore a shimmed default manager called objects if it's the only one. | ||||||
|         if managers == [('objects', default_manager_shim)]: |         if managers == [('objects', default_manager_shim)]: | ||||||
| @@ -528,7 +526,6 @@ class ModelState: | |||||||
|         # Sort all managers by their creation counter |         # Sort all managers by their creation counter | ||||||
|         sorted_managers = sorted(self.managers, key=lambda v: v[1].creation_counter) |         sorted_managers = sorted(self.managers, key=lambda v: v[1].creation_counter) | ||||||
|         for mgr_name, manager in sorted_managers: |         for mgr_name, manager in sorted_managers: | ||||||
|             mgr_name = force_text(mgr_name) |  | ||||||
|             as_manager, manager_path, qs_path, args, kwargs = manager.deconstruct() |             as_manager, manager_path, qs_path, args, kwargs = manager.deconstruct() | ||||||
|             if as_manager: |             if as_manager: | ||||||
|                 qs_class = import_string(qs_path) |                 qs_class = import_string(qs_path) | ||||||
|   | |||||||
| @@ -7,7 +7,6 @@ from django.apps import apps | |||||||
| from django.db import migrations | from django.db import migrations | ||||||
| from django.db.migrations.loader import MigrationLoader | from django.db.migrations.loader import MigrationLoader | ||||||
| from django.db.migrations.serializer import serializer_factory | from django.db.migrations.serializer import serializer_factory | ||||||
| from django.utils.encoding import force_text |  | ||||||
| from django.utils.inspect import get_func_args | from django.utils.inspect import get_func_args | ||||||
| from django.utils.module_loading import module_dir | from django.utils.module_loading import module_dir | ||||||
| from django.utils.timezone import now | from django.utils.timezone import now | ||||||
| @@ -161,8 +160,6 @@ class MigrationWriter: | |||||||
|                 dependencies.append("        migrations.swappable_dependency(settings.%s)," % dependency[1]) |                 dependencies.append("        migrations.swappable_dependency(settings.%s)," % dependency[1]) | ||||||
|                 imports.add("from django.conf import settings") |                 imports.add("from django.conf import settings") | ||||||
|             else: |             else: | ||||||
|                 # No need to output bytestrings for dependencies |  | ||||||
|                 dependency = tuple(force_text(s) for s in dependency) |  | ||||||
|                 dependencies.append("        %s," % self.serialize(dependency)[0]) |                 dependencies.append("        %s," % self.serialize(dependency)[0]) | ||||||
|         items["dependencies"] = "\n".join(dependencies) + "\n" if dependencies else "" |         items["dependencies"] = "\n".join(dependencies) + "\n" if dependencies else "" | ||||||
|  |  | ||||||
|   | |||||||
| @@ -885,7 +885,7 @@ class Model(metaclass=ModelBase): | |||||||
|             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 = 'gt' if is_next else 'lt' |         op = 'gt' if is_next else 'lt' | ||||||
|         order = '' if is_next else '-' |         order = '' if is_next else '-' | ||||||
|         param = force_text(getattr(self, field.attname)) |         param = 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}) | ||||||
|         qs = self.__class__._default_manager.using(self._state.db).filter(**kwargs).filter(q).order_by( |         qs = self.__class__._default_manager.using(self._state.db).filter(**kwargs).filter(q).order_by( | ||||||
|   | |||||||
| @@ -438,12 +438,7 @@ class Field(RegisterLookupMixin): | |||||||
|         if path.startswith("django.db.models.fields"): |         if path.startswith("django.db.models.fields"): | ||||||
|             path = path.replace("django.db.models.fields", "django.db.models") |             path = path.replace("django.db.models.fields", "django.db.models") | ||||||
|         # Return basic info - other fields should override this. |         # Return basic info - other fields should override this. | ||||||
|         return ( |         return (self.name, path, [], keywords) | ||||||
|             force_text(self.name, strings_only=True), |  | ||||||
|             path, |  | ||||||
|             [], |  | ||||||
|             keywords, |  | ||||||
|         ) |  | ||||||
|  |  | ||||||
|     def clone(self): |     def clone(self): | ||||||
|         """ |         """ | ||||||
|   | |||||||
| @@ -9,7 +9,6 @@ from django.core.files.storage import default_storage | |||||||
| from django.core.validators import validate_image_file_extension | from django.core.validators import validate_image_file_extension | ||||||
| from django.db.models import signals | from django.db.models import signals | ||||||
| from django.db.models.fields import Field | from django.db.models.fields import Field | ||||||
| from django.utils.encoding import force_text |  | ||||||
| from django.utils.translation import gettext_lazy as _ | from django.utils.translation import gettext_lazy as _ | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -302,7 +301,7 @@ class FileField(Field): | |||||||
|         if callable(self.upload_to): |         if callable(self.upload_to): | ||||||
|             filename = self.upload_to(instance, filename) |             filename = self.upload_to(instance, filename) | ||||||
|         else: |         else: | ||||||
|             dirname = force_text(datetime.datetime.now().strftime(self.upload_to)) |             dirname = datetime.datetime.now().strftime(self.upload_to) | ||||||
|             filename = posixpath.join(dirname, filename) |             filename = posixpath.join(dirname, filename) | ||||||
|         return self.storage.generate_filename(filename) |         return self.storage.generate_filename(filename) | ||||||
|  |  | ||||||
|   | |||||||
| @@ -12,7 +12,6 @@ from django.db.models.constants import LOOKUP_SEP | |||||||
| from django.db.models.deletion import CASCADE, SET_DEFAULT, SET_NULL | from django.db.models.deletion import CASCADE, SET_DEFAULT, SET_NULL | ||||||
| from django.db.models.query_utils import PathInfo | from django.db.models.query_utils import PathInfo | ||||||
| from django.db.models.utils import make_model_tuple | from django.db.models.utils import make_model_tuple | ||||||
| from django.utils.encoding import force_text |  | ||||||
| from django.utils.functional import cached_property, curry | from django.utils.functional import cached_property, curry | ||||||
| from django.utils.translation import gettext_lazy as _ | from django.utils.translation import gettext_lazy as _ | ||||||
|  |  | ||||||
| @@ -300,7 +299,7 @@ class RelatedField(Field): | |||||||
|             else: |             else: | ||||||
|                 related_name = self.opts.default_related_name |                 related_name = self.opts.default_related_name | ||||||
|             if related_name: |             if related_name: | ||||||
|                 related_name = force_text(related_name) % { |                 related_name = related_name % { | ||||||
|                     'class': cls.__name__.lower(), |                     'class': cls.__name__.lower(), | ||||||
|                     'model_name': cls._meta.model_name.lower(), |                     'model_name': cls._meta.model_name.lower(), | ||||||
|                     'app_label': cls._meta.app_label.lower() |                     'app_label': cls._meta.app_label.lower() | ||||||
| @@ -308,7 +307,7 @@ class RelatedField(Field): | |||||||
|                 self.remote_field.related_name = related_name |                 self.remote_field.related_name = related_name | ||||||
|  |  | ||||||
|             if self.remote_field.related_query_name: |             if self.remote_field.related_query_name: | ||||||
|                 related_query_name = force_text(self.remote_field.related_query_name) % { |                 related_query_name = self.remote_field.related_query_name % { | ||||||
|                     'class': cls.__name__.lower(), |                     'class': cls.__name__.lower(), | ||||||
|                     'app_label': cls._meta.app_label.lower(), |                     'app_label': cls._meta.app_label.lower(), | ||||||
|                 } |                 } | ||||||
|   | |||||||
| @@ -108,13 +108,12 @@ class BoundField: | |||||||
|                 'It will be mandatory in Django 2.1.' % widget.__class__, |                 'It will be mandatory in Django 2.1.' % widget.__class__, | ||||||
|                 RemovedInDjango21Warning, stacklevel=2, |                 RemovedInDjango21Warning, stacklevel=2, | ||||||
|             ) |             ) | ||||||
|         html = widget.render( |         return widget.render( | ||||||
|             name=name, |             name=name, | ||||||
|             value=self.value(), |             value=self.value(), | ||||||
|             attrs=attrs, |             attrs=attrs, | ||||||
|             **kwargs |             **kwargs | ||||||
|         ) |         ) | ||||||
|         return force_text(html) |  | ||||||
|  |  | ||||||
|     def as_text(self, attrs=None, **kwargs): |     def as_text(self, attrs=None, **kwargs): | ||||||
|         """ |         """ | ||||||
|   | |||||||
| @@ -225,14 +225,14 @@ class BaseForm: | |||||||
|                     label = '' |                     label = '' | ||||||
|  |  | ||||||
|                 if field.help_text: |                 if field.help_text: | ||||||
|                     help_text = help_text_html % force_text(field.help_text) |                     help_text = help_text_html % field.help_text | ||||||
|                 else: |                 else: | ||||||
|                     help_text = '' |                     help_text = '' | ||||||
|  |  | ||||||
|                 output.append(normal_row % { |                 output.append(normal_row % { | ||||||
|                     'errors': force_text(bf_errors), |                     'errors': bf_errors, | ||||||
|                     'label': force_text(label), |                     'label': label, | ||||||
|                     'field': str(bf), |                     'field': bf, | ||||||
|                     'help_text': help_text, |                     'help_text': help_text, | ||||||
|                     'html_class_attr': html_class_attr, |                     'html_class_attr': html_class_attr, | ||||||
|                     'css_classes': css_classes, |                     'css_classes': css_classes, | ||||||
| @@ -240,7 +240,7 @@ class BaseForm: | |||||||
|                 }) |                 }) | ||||||
|  |  | ||||||
|         if top_errors: |         if top_errors: | ||||||
|             output.insert(0, error_row % force_text(top_errors)) |             output.insert(0, error_row % top_errors) | ||||||
|  |  | ||||||
|         if hidden_fields:  # Insert any hidden fields in the last row. |         if hidden_fields:  # Insert any hidden fields in the last row. | ||||||
|             str_hidden = ''.join(hidden_fields) |             str_hidden = ''.join(hidden_fields) | ||||||
|   | |||||||
| @@ -4,7 +4,6 @@ from collections import UserList | |||||||
| from django.conf import settings | from django.conf import settings | ||||||
| from django.core.exceptions import ValidationError  # backwards compatibility | from django.core.exceptions import ValidationError  # backwards compatibility | ||||||
| from django.utils import timezone | from django.utils import timezone | ||||||
| from django.utils.encoding import force_text |  | ||||||
| from django.utils.html import escape, format_html, format_html_join, html_safe | from django.utils.html import escape, format_html, format_html_join, html_safe | ||||||
| from django.utils.translation import gettext_lazy as _ | from django.utils.translation import gettext_lazy as _ | ||||||
|  |  | ||||||
| @@ -60,7 +59,7 @@ class ErrorDict(dict): | |||||||
|             return '' |             return '' | ||||||
|         return format_html( |         return format_html( | ||||||
|             '<ul class="errorlist">{}</ul>', |             '<ul class="errorlist">{}</ul>', | ||||||
|             format_html_join('', '<li>{}{}</li>', ((k, force_text(v)) for k, v in self.items())) |             format_html_join('', '<li>{}{}</li>', self.items()) | ||||||
|         ) |         ) | ||||||
|  |  | ||||||
|     def as_text(self): |     def as_text(self): | ||||||
| @@ -110,7 +109,7 @@ class ErrorList(UserList, list): | |||||||
|         return format_html( |         return format_html( | ||||||
|             '<ul class="{}">{}</ul>', |             '<ul class="{}">{}</ul>', | ||||||
|             self.error_class, |             self.error_class, | ||||||
|             format_html_join('', '<li>{}</li>', ((force_text(e),) for e in self)) |             format_html_join('', '<li>{}</li>', ((e,) for e in self)) | ||||||
|         ) |         ) | ||||||
|  |  | ||||||
|     def as_text(self): |     def as_text(self): | ||||||
| @@ -132,7 +131,7 @@ class ErrorList(UserList, list): | |||||||
|         error = self.data[i] |         error = self.data[i] | ||||||
|         if isinstance(error, ValidationError): |         if isinstance(error, ValidationError): | ||||||
|             return list(error)[0] |             return list(error)[0] | ||||||
|         return force_text(error) |         return error | ||||||
|  |  | ||||||
|     def __reduce_ex__(self, *args, **kwargs): |     def __reduce_ex__(self, *args, **kwargs): | ||||||
|         # The `list` reduce function returns an iterator as the fourth element |         # The `list` reduce function returns an iterator as the fourth element | ||||||
|   | |||||||
| @@ -166,8 +166,7 @@ def lazystr(text): | |||||||
|     """ |     """ | ||||||
|     Shortcut for the common case of a lazy callable that returns str. |     Shortcut for the common case of a lazy callable that returns str. | ||||||
|     """ |     """ | ||||||
|     from django.utils.encoding import force_text  # Avoid circular import |     return lazy(str, str)(text) | ||||||
|     return lazy(force_text, str)(text) |  | ||||||
|  |  | ||||||
|  |  | ||||||
| def keep_lazy(*resultclasses): | def keep_lazy(*resultclasses): | ||||||
|   | |||||||
| @@ -38,8 +38,6 @@ def wrap(text, width): | |||||||
|     Don't wrap long words, thus the output text may have lines longer than |     Don't wrap long words, thus the output text may have lines longer than | ||||||
|     ``width``. |     ``width``. | ||||||
|     """ |     """ | ||||||
|     text = force_text(text) |  | ||||||
|  |  | ||||||
|     def _generator(): |     def _generator(): | ||||||
|         for line in text.splitlines(True):  # True keeps trailing linebreaks |         for line in text.splitlines(True):  # True keeps trailing linebreaks | ||||||
|             max_width = min((line.endswith('\n') and width + 1 or width), width) |             max_width = min((line.endswith('\n') and width + 1 or width), width) | ||||||
| @@ -71,7 +69,6 @@ class Truncator(SimpleLazyObject): | |||||||
|             truncate = pgettext( |             truncate = pgettext( | ||||||
|                 'String to return when truncating text', |                 'String to return when truncating text', | ||||||
|                 '%(truncated_text)s...') |                 '%(truncated_text)s...') | ||||||
|         truncate = force_text(truncate) |  | ||||||
|         if '%(truncated_text)s' in truncate: |         if '%(truncated_text)s' in truncate: | ||||||
|             return truncate % {'truncated_text': text} |             return truncate % {'truncated_text': text} | ||||||
|         # The truncation text didn't contain the %(truncated_text)s string |         # The truncation text didn't contain the %(truncated_text)s string | ||||||
|   | |||||||
| @@ -14,7 +14,6 @@ from django.conf.locale import LANG_INFO | |||||||
| from django.core.exceptions import AppRegistryNotReady | from django.core.exceptions import AppRegistryNotReady | ||||||
| from django.core.signals import setting_changed | from django.core.signals import setting_changed | ||||||
| from django.dispatch import receiver | from django.dispatch import receiver | ||||||
| from django.utils.encoding import force_text |  | ||||||
| from django.utils.safestring import SafeData, mark_safe | from django.utils.safestring import SafeData, mark_safe | ||||||
| from django.utils.translation import LANGUAGE_SESSION_KEY | from django.utils.translation import LANGUAGE_SESSION_KEY | ||||||
|  |  | ||||||
| @@ -327,8 +326,7 @@ def pgettext(context, message): | |||||||
|     result = gettext(msg_with_ctxt) |     result = gettext(msg_with_ctxt) | ||||||
|     if CONTEXT_SEPARATOR in result: |     if CONTEXT_SEPARATOR in result: | ||||||
|         # Translation not found |         # Translation not found | ||||||
|         # force str, because the lazy version expects str. |         result = message | ||||||
|         result = force_text(message) |  | ||||||
|     return result |     return result | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
| @@ -5,7 +5,6 @@ from django.core.exceptions import ImproperlyConfigured | |||||||
| from django.db import models | from django.db import models | ||||||
| from django.http import Http404 | from django.http import Http404 | ||||||
| from django.utils import timezone | from django.utils import timezone | ||||||
| from django.utils.encoding import force_text |  | ||||||
| from django.utils.functional import cached_property | from django.utils.functional import cached_property | ||||||
| from django.utils.translation import gettext as _ | from django.utils.translation import gettext as _ | ||||||
| from django.views.generic.base import View | from django.views.generic.base import View | ||||||
| @@ -326,7 +325,7 @@ class BaseDateListView(MultipleObjectMixin, DateMixin, View): | |||||||
|             is_empty = len(qs) == 0 if paginate_by is None else not qs.exists() |             is_empty = len(qs) == 0 if paginate_by is None else not qs.exists() | ||||||
|             if is_empty: |             if is_empty: | ||||||
|                 raise Http404(_("No %(verbose_name_plural)s available") % { |                 raise Http404(_("No %(verbose_name_plural)s available") % { | ||||||
|                     'verbose_name_plural': force_text(qs.model._meta.verbose_name_plural) |                     'verbose_name_plural': qs.model._meta.verbose_name_plural, | ||||||
|                 }) |                 }) | ||||||
|  |  | ||||||
|         return qs |         return qs | ||||||
| @@ -353,9 +352,11 @@ class BaseDateListView(MultipleObjectMixin, DateMixin, View): | |||||||
|         else: |         else: | ||||||
|             date_list = queryset.dates(date_field, date_type, ordering) |             date_list = queryset.dates(date_field, date_type, ordering) | ||||||
|         if date_list is not None and not date_list and not allow_empty: |         if date_list is not None and not date_list and not allow_empty: | ||||||
|             name = force_text(queryset.model._meta.verbose_name_plural) |             raise Http404( | ||||||
|             raise Http404(_("No %(verbose_name_plural)s available") % |                 _("No %(verbose_name_plural)s available") % { | ||||||
|                           {'verbose_name_plural': name}) |                     'verbose_name_plural': queryset.model._meta.verbose_name_plural, | ||||||
|  |                 } | ||||||
|  |             ) | ||||||
|  |  | ||||||
|         return date_list |         return date_list | ||||||
|  |  | ||||||
|   | |||||||
| @@ -635,8 +635,6 @@ class MailTests(HeadersCheckMixin, SimpleTestCase): | |||||||
|         # Simple ASCII address - string form |         # Simple ASCII address - string form | ||||||
|         self.assertEqual(sanitize_address('to@example.com', 'ascii'), 'to@example.com') |         self.assertEqual(sanitize_address('to@example.com', 'ascii'), 'to@example.com') | ||||||
|         self.assertEqual(sanitize_address('to@example.com', 'utf-8'), 'to@example.com') |         self.assertEqual(sanitize_address('to@example.com', 'utf-8'), 'to@example.com') | ||||||
|         # Bytestrings are transformed to normal strings. |  | ||||||
|         self.assertEqual(sanitize_address(b'to@example.com', 'utf-8'), 'to@example.com') |  | ||||||
|  |  | ||||||
|         # Simple ASCII address - tuple form |         # Simple ASCII address - tuple form | ||||||
|         self.assertEqual( |         self.assertEqual( | ||||||
|   | |||||||
| @@ -359,7 +359,7 @@ class StateTests(SimpleTestCase): | |||||||
|                 # The ordering we really want is objects, mgr1, mgr2 |                 # The ordering we really want is objects, mgr1, mgr2 | ||||||
|                 ('default', base_mgr), |                 ('default', base_mgr), | ||||||
|                 ('food_mgr2', mgr2), |                 ('food_mgr2', mgr2), | ||||||
|                 (b'food_mgr1', mgr1), |                 ('food_mgr1', mgr1), | ||||||
|             ] |             ] | ||||||
|         )) |         )) | ||||||
|  |  | ||||||
|   | |||||||
| @@ -30,7 +30,7 @@ def get_foo(): | |||||||
|  |  | ||||||
| class Bar(models.Model): | class Bar(models.Model): | ||||||
|     b = models.CharField(max_length=10) |     b = models.CharField(max_length=10) | ||||||
|     a = models.ForeignKey(Foo, models.CASCADE, default=get_foo, related_name=b'bars') |     a = models.ForeignKey(Foo, models.CASCADE, default=get_foo, related_name='bars') | ||||||
|  |  | ||||||
|  |  | ||||||
| class Whiz(models.Model): | class Whiz(models.Model): | ||||||
|   | |||||||
| @@ -42,8 +42,8 @@ class SimpleTests(HStoreTestCase): | |||||||
|         self.assertEqual(reloaded.field, value) |         self.assertEqual(reloaded.field, value) | ||||||
|  |  | ||||||
|     def test_key_val_cast_to_string(self): |     def test_key_val_cast_to_string(self): | ||||||
|         value = {'a': 1, 'b': 'B', 2: 'c', 'ï': 'ê', b'x': b'test'} |         value = {'a': 1, 'b': 'B', 2: 'c', 'ï': 'ê'} | ||||||
|         expected_value = {'a': '1', 'b': 'B', '2': 'c', 'ï': 'ê', 'x': 'test'} |         expected_value = {'a': '1', 'b': 'B', '2': 'c', 'ï': 'ê'} | ||||||
|  |  | ||||||
|         instance = HStoreModel.objects.create(field=value) |         instance = HStoreModel.objects.create(field=value) | ||||||
|         instance = HStoreModel.objects.get() |         instance = HStoreModel.objects.get() | ||||||
|   | |||||||
| @@ -51,9 +51,6 @@ class StringLookupTests(TestCase): | |||||||
|         fx.save() |         fx.save() | ||||||
|         self.assertEqual(Foo.objects.get(friend__contains='\xe7'), fx) |         self.assertEqual(Foo.objects.get(friend__contains='\xe7'), fx) | ||||||
|  |  | ||||||
|         # We can also do the above query using UTF-8 strings. |  | ||||||
|         self.assertEqual(Foo.objects.get(friend__contains=b'\xc3\xa7'), fx) |  | ||||||
|  |  | ||||||
|     def test_queries_on_textfields(self): |     def test_queries_on_textfields(self): | ||||||
|         """ |         """ | ||||||
|         Regression tests for #5087 |         Regression tests for #5087 | ||||||
|   | |||||||
| @@ -157,11 +157,6 @@ class TestUtilsText(SimpleTestCase): | |||||||
|         self.assertEqual(text.normalize_newlines(""), "") |         self.assertEqual(text.normalize_newlines(""), "") | ||||||
|         self.assertEqual(text.normalize_newlines(lazystr("abc\ndef\rghi\r\n")), "abc\ndef\nghi\n") |         self.assertEqual(text.normalize_newlines(lazystr("abc\ndef\rghi\r\n")), "abc\ndef\nghi\n") | ||||||
|  |  | ||||||
|     def test_normalize_newlines_bytes(self): |  | ||||||
|         """normalize_newlines should be able to handle bytes too""" |  | ||||||
|         normalized = text.normalize_newlines(b"abc\ndef\rghi\r\n") |  | ||||||
|         self.assertEqual(normalized, "abc\ndef\nghi\n") |  | ||||||
|  |  | ||||||
|     def test_phone2numeric(self): |     def test_phone2numeric(self): | ||||||
|         numeric = text.phone2numeric('0800 flowers') |         numeric = text.phone2numeric('0800 flowers') | ||||||
|         self.assertEqual(numeric, '0800 3569377') |         self.assertEqual(numeric, '0800 3569377') | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user