summaryrefslogtreecommitdiff
path: root/django/utils/encoding.py
diff options
context:
space:
mode:
Diffstat (limited to 'django/utils/encoding.py')
-rw-r--r--django/utils/encoding.py9
1 files changed, 8 insertions, 1 deletions
diff --git a/django/utils/encoding.py b/django/utils/encoding.py
index dbd2c7a211..7e87b05c79 100644
--- a/django/utils/encoding.py
+++ b/django/utils/encoding.py
@@ -1,8 +1,15 @@
import types
import urllib
import datetime
+
from django.utils.functional import Promise
+try:
+ from decimal import Decimal
+except ImportError:
+ from django.utils._decimal import Decimal # Python 2.3 fallback
+
+
class DjangoUnicodeDecodeError(UnicodeDecodeError):
def __init__(self, obj, *args):
self.obj = obj
@@ -41,7 +48,7 @@ def force_unicode(s, encoding='utf-8', strings_only=False, errors='strict'):
If strings_only is True, don't convert (some) non-string-like objects.
"""
- if strings_only and isinstance(s, (types.NoneType, int, long, datetime.datetime, datetime.date, datetime.time, float)):
+ if strings_only and isinstance(s, (types.NoneType, int, long, datetime.datetime, datetime.date, datetime.time, float, Decimal)):
return s
try:
if not isinstance(s, basestring,):