summaryrefslogtreecommitdiff
path: root/django/utils/encoding.py
diff options
context:
space:
mode:
authorMalcolm Tredinnick <malcolm.tredinnick@gmail.com>2007-11-04 03:37:04 +0000
committerMalcolm Tredinnick <malcolm.tredinnick@gmail.com>2007-11-04 03:37:04 +0000
commit3f1ce2e60280ef42c8864e65485e4572d7740e8d (patch)
tree9abb4bddf320090f255eb824f2368ccca368bd53 /django/utils/encoding.py
parent6f7fd897bcc20ef5a3b96a3caf01d805d631d3e4 (diff)
downloaddjango-3f1ce2e60280ef42c8864e65485e4572d7740e8d.tar.gz
Fixed #5640 -- Added some extra error reporting when smart_unicode() or
force_unicode() raise a UnicodeDecodeError. This should at least help people identify which is the bad piece of data they passed in. About the best we can do here. git-svn-id: http://code.djangoproject.com/svn/django/trunk@6649 bcc190cf-cafb-0310-a4f2-bffc1f526a37
Diffstat (limited to 'django/utils/encoding.py')
-rw-r--r--django/utils/encoding.py28
1 files changed, 21 insertions, 7 deletions
diff --git a/django/utils/encoding.py b/django/utils/encoding.py
index 2bd1ef6563..4bda9caa50 100644
--- a/django/utils/encoding.py
+++ b/django/utils/encoding.py
@@ -1,8 +1,19 @@
import types
import urllib
import datetime
+
from django.utils.functional import Promise
+class DjangoUnicodeDecodeError(UnicodeDecodeError):
+ def __init__(self, obj, *args):
+ self.obj = obj
+ UnicodeDecodeError.__init__(self, *args)
+
+ def __str__(self):
+ original = UnicodeDecodeError.__str__(self)
+ return '%s. You passed in %r (%s)' % (original, self.obj,
+ type(self.obj))
+
class StrAndUnicode(object):
"""
A class whose __str__ returns its __unicode__ as a UTF-8 bytestring.
@@ -33,13 +44,16 @@ def force_unicode(s, encoding='utf-8', strings_only=False, errors='strict'):
"""
if strings_only and isinstance(s, (types.NoneType, int, long, datetime.datetime, datetime.date, datetime.time, float)):
return s
- if not isinstance(s, basestring,):
- if hasattr(s, '__unicode__'):
- s = unicode(s)
- else:
- s = unicode(str(s), encoding, errors)
- elif not isinstance(s, unicode):
- s = unicode(s, encoding, errors)
+ try:
+ if not isinstance(s, basestring,):
+ if hasattr(s, '__unicode__'):
+ s = unicode(s)
+ else:
+ s = unicode(str(s), encoding, errors)
+ elif not isinstance(s, unicode):
+ s = unicode(s, encoding, errors)
+ except UnicodeDecodeError, e:
+ raise DjangoUnicodeDecodeError(s, *e.args)
return s
def smart_str(s, encoding='utf-8', strings_only=False, errors='strict'):