[py3] Replaced basestring by six.string_types.

This commit is contained in:
Aymeric Augustin 2012-07-20 14:22:00 +02:00
parent cacd845996
commit 3cb2457f46
73 changed files with 230 additions and 150 deletions

View File

@ -15,6 +15,7 @@ from django.conf import global_settings
from django.core.exceptions import ImproperlyConfigured from django.core.exceptions import ImproperlyConfigured
from django.utils.functional import LazyObject, empty from django.utils.functional import LazyObject, empty
from django.utils import importlib from django.utils import importlib
from django.utils import six
ENVIRONMENT_VARIABLE = "DJANGO_SETTINGS_MODULE" ENVIRONMENT_VARIABLE = "DJANGO_SETTINGS_MODULE"
@ -73,7 +74,7 @@ class BaseSettings(object):
elif name == "ADMIN_MEDIA_PREFIX": elif name == "ADMIN_MEDIA_PREFIX":
warnings.warn("The ADMIN_MEDIA_PREFIX setting has been removed; " warnings.warn("The ADMIN_MEDIA_PREFIX setting has been removed; "
"use STATIC_URL instead.", DeprecationWarning) "use STATIC_URL instead.", DeprecationWarning)
elif name == "ALLOWED_INCLUDE_ROOTS" and isinstance(value, basestring): elif name == "ALLOWED_INCLUDE_ROOTS" and isinstance(value, six.string_types):
raise ValueError("The ALLOWED_INCLUDE_ROOTS setting must be set " raise ValueError("The ALLOWED_INCLUDE_ROOTS setting must be set "
"to a tuple, not a string.") "to a tuple, not a string.")
object.__setattr__(self, name, value) object.__setattr__(self, name, value)
@ -102,7 +103,7 @@ class Settings(BaseSettings):
if setting == setting.upper(): if setting == setting.upper():
setting_value = getattr(mod, setting) setting_value = getattr(mod, setting)
if setting in tuple_settings and \ if setting in tuple_settings and \
isinstance(setting_value, basestring): isinstance(setting_value, six.string_types):
warnings.warn("The %s setting must be a tuple. Please fix your " warnings.warn("The %s setting must be a tuple. Please fix your "
"settings, as auto-correction is now deprecated." % setting, "settings, as auto-correction is now deprecated." % setting,
PendingDeprecationWarning) PendingDeprecationWarning)

View File

@ -2,6 +2,7 @@ from django.core.urlresolvers import (RegexURLPattern,
RegexURLResolver, LocaleRegexURLResolver) RegexURLResolver, LocaleRegexURLResolver)
from django.core.exceptions import ImproperlyConfigured from django.core.exceptions import ImproperlyConfigured
from django.utils.importlib import import_module from django.utils.importlib import import_module
from django.utils import six
__all__ = ['handler403', 'handler404', 'handler500', 'include', 'patterns', 'url'] __all__ = ['handler403', 'handler404', 'handler500', 'include', 'patterns', 'url']
@ -20,7 +21,7 @@ def include(arg, namespace=None, app_name=None):
# No namespace hint - use manually provided namespace # No namespace hint - use manually provided namespace
urlconf_module = arg urlconf_module = arg
if isinstance(urlconf_module, basestring): if isinstance(urlconf_module, six.string_types):
urlconf_module = import_module(urlconf_module) urlconf_module = import_module(urlconf_module)
patterns = getattr(urlconf_module, 'urlpatterns', urlconf_module) patterns = getattr(urlconf_module, 'urlpatterns', urlconf_module)
@ -52,7 +53,7 @@ def url(regex, view, kwargs=None, name=None, prefix=''):
urlconf_module, app_name, namespace = view urlconf_module, app_name, namespace = view
return RegexURLResolver(regex, urlconf_module, kwargs, app_name=app_name, namespace=namespace) return RegexURLResolver(regex, urlconf_module, kwargs, app_name=app_name, namespace=namespace)
else: else:
if isinstance(view, basestring): if isinstance(view, six.string_types):
if not view: if not view:
raise ImproperlyConfigured('Empty URL pattern view name not permitted (for pattern %r)' % regex) raise ImproperlyConfigured('Empty URL pattern view name not permitted (for pattern %r)' % regex)
if prefix: if prefix:

View File

@ -12,6 +12,7 @@ from django.template.defaultfilters import capfirst
from django.utils.encoding import force_unicode, smart_unicode from django.utils.encoding import force_unicode, smart_unicode
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 import six
from django.utils.translation import ugettext_lazy as _ from django.utils.translation import ugettext_lazy as _
from django.conf import settings from django.conf import settings
@ -49,7 +50,7 @@ class AdminForm(object):
try: try:
fieldset_name, fieldset_options = self.fieldsets[0] fieldset_name, fieldset_options = self.fieldsets[0]
field_name = fieldset_options['fields'][0] field_name = fieldset_options['fields'][0]
if not isinstance(field_name, basestring): if not isinstance(field_name, six.string_types):
field_name = field_name[0] field_name = field_name[0]
return self.form[field_name] return self.form[field_name]
except (KeyError, IndexError): except (KeyError, IndexError):

View File

@ -52,7 +52,7 @@ def quote(s):
quoting is slightly different so that it doesn't get automatically quoting is slightly different so that it doesn't get automatically
unquoted by the Web browser. unquoted by the Web browser.
""" """
if not isinstance(s, basestring): if not isinstance(s, six.string_types):
return s return s
res = list(s) res = list(s)
for i in range(len(res)): for i in range(len(res)):

View File

@ -2,6 +2,7 @@
import pickle import pickle
from django.utils.crypto import salted_hmac from django.utils.crypto import salted_hmac
from django.utils import six
def form_hmac(form): def form_hmac(form):
@ -16,7 +17,7 @@ def form_hmac(form):
value = bf.data or '' value = bf.data or ''
else: else:
value = bf.field.clean(bf.data) or '' value = bf.field.clean(bf.data) or ''
if isinstance(value, basestring): if isinstance(value, six.string_types):
value = value.strip() value = value.strip()
data.append((bf.name, value)) data.append((bf.name, value))

View File

@ -1,6 +1,7 @@
from django.forms.widgets import Textarea from django.forms.widgets import Textarea
from django.template import loader, Context from django.template import loader, Context
from django.templatetags.static import static from django.templatetags.static import static
from django.utils import six
from django.utils import translation from django.utils import translation
from django.contrib.gis.gdal import OGRException from django.contrib.gis.gdal import OGRException
@ -25,7 +26,7 @@ class OpenLayersWidget(Textarea):
# If a string reaches here (via a validation error on another # If a string reaches here (via a validation error on another
# field) then just reconstruct the Geometry. # field) then just reconstruct the Geometry.
if isinstance(value, basestring): if isinstance(value, six.string_types):
try: try:
value = GEOSGeometry(value) value = GEOSGeometry(value)
except (GEOSException, ValueError): except (GEOSException, ValueError):
@ -109,7 +110,7 @@ class OpenLayersWidget(Textarea):
""" Compare geographic value of data with its initial value. """ """ Compare geographic value of data with its initial value. """
# Ensure we are dealing with a geographic object # Ensure we are dealing with a geographic object
if isinstance(initial, basestring): if isinstance(initial, six.string_types):
try: try:
initial = GEOSGeometry(initial) initial = GEOSGeometry(initial)
except (GEOSException, ValueError): except (GEOSException, ValueError):

View File

@ -121,7 +121,7 @@ class OracleOperations(DatabaseOperations, BaseSpatialOperations):
'exact' : SDOOperation('SDO_EQUAL'), 'exact' : SDOOperation('SDO_EQUAL'),
'overlaps' : SDOOperation('SDO_OVERLAPS'), 'overlaps' : SDOOperation('SDO_OVERLAPS'),
'same_as' : SDOOperation('SDO_EQUAL'), 'same_as' : SDOOperation('SDO_EQUAL'),
'relate' : (SDORelate, basestring), # Oracle uses a different syntax, e.g., 'mask=inside+touch' 'relate' : (SDORelate, six.string_types), # Oracle uses a different syntax, e.g., 'mask=inside+touch'
'touches' : SDOOperation('SDO_TOUCH'), 'touches' : SDOOperation('SDO_TOUCH'),
'within' : SDOOperation('SDO_INSIDE'), 'within' : SDOOperation('SDO_INSIDE'),
} }

View File

@ -162,7 +162,7 @@ class PostGISOperations(DatabaseOperations, BaseSpatialOperations):
'overlaps' : PostGISFunction(prefix, 'Overlaps'), 'overlaps' : PostGISFunction(prefix, 'Overlaps'),
'contains' : PostGISFunction(prefix, 'Contains'), 'contains' : PostGISFunction(prefix, 'Contains'),
'intersects' : PostGISFunction(prefix, 'Intersects'), 'intersects' : PostGISFunction(prefix, 'Intersects'),
'relate' : (PostGISRelate, basestring), 'relate' : (PostGISRelate, six.string_types),
} }
# Valid distance types and substitutions # Valid distance types and substitutions

View File

@ -1,5 +1,6 @@
from django.contrib.gis.gdal import OGRGeomType from django.contrib.gis.gdal import OGRGeomType
from django.db.backends.sqlite3.introspection import DatabaseIntrospection, FlexibleFieldLookupDict from django.db.backends.sqlite3.introspection import DatabaseIntrospection, FlexibleFieldLookupDict
from django.utils import six
class GeoFlexibleFieldLookupDict(FlexibleFieldLookupDict): class GeoFlexibleFieldLookupDict(FlexibleFieldLookupDict):
""" """
@ -43,7 +44,7 @@ class SpatiaLiteIntrospection(DatabaseIntrospection):
field_params = {} field_params = {}
if srid != 4326: if srid != 4326:
field_params['srid'] = srid field_params['srid'] = srid
if isinstance(dim, basestring) and 'Z' in dim: if isinstance(dim, six.string_types) and 'Z' in dim:
field_params['dim'] = 3 field_params['dim'] = 3
finally: finally:
cursor.close() cursor.close()

View File

@ -90,7 +90,7 @@ class SpatiaLiteOperations(DatabaseOperations, BaseSpatialOperations):
'overlaps' : SpatiaLiteFunction('Overlaps'), 'overlaps' : SpatiaLiteFunction('Overlaps'),
'contains' : SpatiaLiteFunction('Contains'), 'contains' : SpatiaLiteFunction('Contains'),
'intersects' : SpatiaLiteFunction('Intersects'), 'intersects' : SpatiaLiteFunction('Intersects'),
'relate' : (SpatiaLiteRelate, basestring), 'relate' : (SpatiaLiteRelate, six.string_types),
# Returns true if B's bounding box completely contains A's bounding box. # Returns true if B's bounding box completely contains A's bounding box.
'contained' : SpatiaLiteFunction('MbrWithin'), 'contained' : SpatiaLiteFunction('MbrWithin'),
# Returns true if A's bounding box completely contains B's bounding box. # Returns true if A's bounding box completely contains B's bounding box.

View File

@ -3,13 +3,15 @@ A collection of utility routines and classes used by the spatial
backends. backends.
""" """
from django.utils import six
def gqn(val): def gqn(val):
""" """
The geographic quote name function; used for quoting tables and The geographic quote name function; used for quoting tables and
geometries (they use single rather than the double quotes of the geometries (they use single rather than the double quotes of the
backend quotename function). backend quotename function).
""" """
if isinstance(val, basestring): if isinstance(val, six.string_types):
if isinstance(val, unicode): val = val.encode('ascii') if isinstance(val, unicode): val = val.encode('ascii')
return "'%s'" % val return "'%s'" % val
else: else:

View File

@ -4,6 +4,7 @@ from django.utils.translation import ugettext_lazy as _
from django.contrib.gis import forms from django.contrib.gis import forms
from django.contrib.gis.db.models.proxy import GeometryProxy from django.contrib.gis.db.models.proxy import GeometryProxy
from django.contrib.gis.geometry.backend import Geometry, GeometryException from django.contrib.gis.geometry.backend import Geometry, GeometryException
from django.utils import six
# Local cache of the spatial_ref_sys table, which holds SRID data for each # Local cache of the spatial_ref_sys table, which holds SRID data for each
# spatial database alias. This cache exists so that the database isn't queried # spatial database alias. This cache exists so that the database isn't queried
@ -159,7 +160,7 @@ class GeometryField(Field):
# from the given string input. # from the given string input.
if isinstance(geom, Geometry): if isinstance(geom, Geometry):
pass pass
elif isinstance(geom, basestring) or hasattr(geom, '__geo_interface__'): elif isinstance(geom, six.string_types) or hasattr(geom, '__geo_interface__'):
try: try:
geom = Geometry(geom) geom = Geometry(geom)
except GeometryException: except GeometryException:

View File

@ -5,6 +5,7 @@ corresponding to geographic model fields.
Thanks to Robert Coup for providing this functionality (see #4322). Thanks to Robert Coup for providing this functionality (see #4322).
""" """
from django.utils import six
class GeometryProxy(object): class GeometryProxy(object):
def __init__(self, klass, field): def __init__(self, klass, field):
@ -53,7 +54,7 @@ class GeometryProxy(object):
if isinstance(value, self._klass) and (str(value.geom_type).upper() == gtype or gtype == 'GEOMETRY'): if isinstance(value, self._klass) and (str(value.geom_type).upper() == gtype or gtype == 'GEOMETRY'):
# Assigning the SRID to the geometry. # Assigning the SRID to the geometry.
if value.srid is None: value.srid = self._field.srid if value.srid is None: value.srid = self._field.srid
elif value is None or isinstance(value, (basestring, buffer)): elif value is None or isinstance(value, six.string_types + (buffer,)):
# Set with None, WKT, HEX, or WKB # Set with None, WKT, HEX, or WKB
pass pass
else: else:

View File

@ -8,6 +8,8 @@ from django.contrib.gis.geometry.backend import Geometry
from django.contrib.gis.measure import Area, Distance from django.contrib.gis.measure import Area, Distance
from django.utils import six from django.utils import six
from django.utils import six
class GeoQuerySet(QuerySet): class GeoQuerySet(QuerySet):
"The Geographic QuerySet." "The Geographic QuerySet."
@ -534,7 +536,7 @@ class GeoQuerySet(QuerySet):
geo_field = settings['geo_field'] geo_field = settings['geo_field']
# The attribute to attach to the model. # The attribute to attach to the model.
if not isinstance(model_att, basestring): model_att = att if not isinstance(model_att, six.string_types): model_att = att
# Special handling for any argument that is a geometry. # Special handling for any argument that is a geometry.
for name in settings['geom_args']: for name in settings['geom_args']:

View File

@ -45,6 +45,8 @@ from django.contrib.gis.gdal.layer import Layer
# Getting the ctypes prototypes for the DataSource. # Getting the ctypes prototypes for the DataSource.
from django.contrib.gis.gdal.prototypes import ds as capi from django.contrib.gis.gdal.prototypes import ds as capi
from django.utils import six
# For more information, see the OGR C API source code: # For more information, see the OGR C API source code:
# http://www.gdal.org/ogr/ogr__api_8h.html # http://www.gdal.org/ogr/ogr__api_8h.html
# #
@ -65,7 +67,7 @@ class DataSource(GDALBase):
if not capi.get_driver_count(): if not capi.get_driver_count():
capi.register_all() capi.register_all()
if isinstance(ds_input, basestring): if isinstance(ds_input, six.string_types):
# The data source driver is a void pointer. # The data source driver is a void pointer.
ds_driver = Driver.ptr_type() ds_driver = Driver.ptr_type()
try: try:
@ -98,7 +100,7 @@ class DataSource(GDALBase):
def __getitem__(self, index): def __getitem__(self, index):
"Allows use of the index [] operator to get a layer at the index." "Allows use of the index [] operator to get a layer at the index."
if isinstance(index, basestring): if isinstance(index, six.string_types):
l = capi.get_layer_by_name(self.ptr, index) l = capi.get_layer_by_name(self.ptr, index)
if not l: raise OGRIndexError('invalid OGR Layer name given: "%s"' % index) if not l: raise OGRIndexError('invalid OGR Layer name given: "%s"' % index)
elif isinstance(index, int): elif isinstance(index, int):

View File

@ -4,6 +4,8 @@ from django.contrib.gis.gdal.base import GDALBase
from django.contrib.gis.gdal.error import OGRException from django.contrib.gis.gdal.error import OGRException
from django.contrib.gis.gdal.prototypes import ds as capi from django.contrib.gis.gdal.prototypes import ds as capi
from django.utils import six
# For more information, see the OGR C API source code: # For more information, see the OGR C API source code:
# http://www.gdal.org/ogr/ogr__api_8h.html # http://www.gdal.org/ogr/ogr__api_8h.html
# #
@ -22,7 +24,7 @@ class Driver(GDALBase):
def __init__(self, dr_input): def __init__(self, dr_input):
"Initializes an OGR driver on either a string or integer input." "Initializes an OGR driver on either a string or integer input."
if isinstance(dr_input, basestring): if isinstance(dr_input, six.string_types):
# If a string name of the driver was passed in # If a string name of the driver was passed in
self._register() self._register()

View File

@ -7,6 +7,8 @@ from django.contrib.gis.gdal.geometries import OGRGeometry, OGRGeomType
# ctypes function prototypes # ctypes function prototypes
from django.contrib.gis.gdal.prototypes import ds as capi, geom as geom_api from django.contrib.gis.gdal.prototypes import ds as capi, geom as geom_api
from django.utils import six
# For more information, see the OGR C API source code: # For more information, see the OGR C API source code:
# http://www.gdal.org/ogr/ogr__api_8h.html # http://www.gdal.org/ogr/ogr__api_8h.html
# #
@ -33,7 +35,7 @@ class Feature(GDALBase):
is not the field's _value_ -- use the `get` method instead to is not the field's _value_ -- use the `get` method instead to
retrieve the value (e.g. an integer) instead of a Field instance. retrieve the value (e.g. an integer) instead of a Field instance.
""" """
if isinstance(index, basestring): if isinstance(index, six.string_types):
i = self.index(index) i = self.index(index)
else: else:
if index < 0 or index > self.num_fields: if index < 0 or index > self.num_fields:

View File

@ -71,7 +71,7 @@ class OGRGeometry(GDALBase):
def __init__(self, geom_input, srs=None): def __init__(self, geom_input, srs=None):
"Initializes Geometry on either WKT or an OGR pointer as input." "Initializes Geometry on either WKT or an OGR pointer as input."
str_instance = isinstance(geom_input, basestring) str_instance = isinstance(geom_input, six.string_types)
# If HEX, unpack input to to a binary buffer. # If HEX, unpack input to to a binary buffer.
if str_instance and hex_regex.match(geom_input): if str_instance and hex_regex.match(geom_input):
@ -283,7 +283,7 @@ class OGRGeometry(GDALBase):
# (decremented) when this geometry's destructor is called. # (decremented) when this geometry's destructor is called.
if isinstance(srs, SpatialReference): if isinstance(srs, SpatialReference):
srs_ptr = srs.ptr srs_ptr = srs.ptr
elif isinstance(srs, six.integer_types + (basestring,)): elif isinstance(srs, six.integer_types + six.string_types):
sr = SpatialReference(srs) sr = SpatialReference(srs)
srs_ptr = sr.ptr srs_ptr = sr.ptr
else: else:
@ -412,7 +412,7 @@ class OGRGeometry(GDALBase):
capi.geom_transform(self.ptr, coord_trans.ptr) capi.geom_transform(self.ptr, coord_trans.ptr)
elif isinstance(coord_trans, SpatialReference): elif isinstance(coord_trans, SpatialReference):
capi.geom_transform_to(self.ptr, coord_trans.ptr) capi.geom_transform_to(self.ptr, coord_trans.ptr)
elif isinstance(coord_trans, six.integer_types + (basestring,)): elif isinstance(coord_trans, six.integer_types + six.string_types):
sr = SpatialReference(coord_trans) sr = SpatialReference(coord_trans)
capi.geom_transform_to(self.ptr, sr.ptr) capi.geom_transform_to(self.ptr, sr.ptr)
else: else:
@ -687,7 +687,7 @@ class GeometryCollection(OGRGeometry):
for g in geom: capi.add_geom(self.ptr, g.ptr) for g in geom: capi.add_geom(self.ptr, g.ptr)
else: else:
capi.add_geom(self.ptr, geom.ptr) capi.add_geom(self.ptr, geom.ptr)
elif isinstance(geom, basestring): elif isinstance(geom, six.string_types):
tmp = OGRGeometry(geom) tmp = OGRGeometry(geom)
capi.add_geom(self.ptr, tmp.ptr) capi.add_geom(self.ptr, tmp.ptr)
else: else:

View File

@ -1,5 +1,7 @@
from django.contrib.gis.gdal.error import OGRException from django.contrib.gis.gdal.error import OGRException
from django.utils import six
#### OGRGeomType #### #### OGRGeomType ####
class OGRGeomType(object): class OGRGeomType(object):
"Encapulates OGR Geometry Types." "Encapulates OGR Geometry Types."
@ -32,7 +34,7 @@ class OGRGeomType(object):
"Figures out the correct OGR Type based upon the input." "Figures out the correct OGR Type based upon the input."
if isinstance(type_input, OGRGeomType): if isinstance(type_input, OGRGeomType):
num = type_input.num num = type_input.num
elif isinstance(type_input, basestring): elif isinstance(type_input, six.string_types):
type_input = type_input.lower() type_input = type_input.lower()
if type_input == 'geometry': type_input='unknown' if type_input == 'geometry': type_input='unknown'
num = self._str_types.get(type_input, None) num = self._str_types.get(type_input, None)
@ -59,7 +61,7 @@ class OGRGeomType(object):
""" """
if isinstance(other, OGRGeomType): if isinstance(other, OGRGeomType):
return self.num == other.num return self.num == other.num
elif isinstance(other, basestring): elif isinstance(other, six.string_types):
return self.name.lower() == other.lower() return self.name.lower() == other.lower()
elif isinstance(other, int): elif isinstance(other, int):
return self.num == other return self.num == other

View File

@ -54,7 +54,7 @@ class SpatialReference(GDALBase):
buf = c_char_p('') buf = c_char_p('')
srs_type = 'user' srs_type = 'user'
if isinstance(srs_input, basestring): if isinstance(srs_input, six.string_types):
# Encoding to ASCII if unicode passed in. # Encoding to ASCII if unicode passed in.
if isinstance(srs_input, unicode): if isinstance(srs_input, unicode):
srs_input = srs_input.encode('ascii') srs_input = srs_input.encode('ascii')
@ -135,7 +135,7 @@ class SpatialReference(GDALBase):
The attribute value for the given target node (e.g. 'PROJCS'). The index The attribute value for the given target node (e.g. 'PROJCS'). The index
keyword specifies an index of the child node to return. keyword specifies an index of the child node to return.
""" """
if not isinstance(target, basestring) or not isinstance(index, int): if not isinstance(target, six.string_types) or not isinstance(index, int):
raise TypeError raise TypeError
return capi.get_attr_value(self.ptr, target, index) return capi.get_attr_value(self.ptr, target, index)

View File

@ -10,6 +10,8 @@ from django.contrib.gis.geoip.prototypes import (
GeoIP_country_code_by_addr, GeoIP_country_code_by_name, GeoIP_country_code_by_addr, GeoIP_country_code_by_name,
GeoIP_country_name_by_addr, GeoIP_country_name_by_name) GeoIP_country_name_by_addr, GeoIP_country_name_by_name)
from django.utils import six
# Regular expressions for recognizing the GeoIP free database editions. # Regular expressions for recognizing the GeoIP free database editions.
free_regex = re.compile(r'^GEO-\d{3}FREE') free_regex = re.compile(r'^GEO-\d{3}FREE')
lite_regex = re.compile(r'^GEO-\d{3}LITE') lite_regex = re.compile(r'^GEO-\d{3}LITE')
@ -86,7 +88,7 @@ class GeoIP(object):
if not path: if not path:
path = GEOIP_SETTINGS.get('GEOIP_PATH', None) path = GEOIP_SETTINGS.get('GEOIP_PATH', None)
if not path: raise GeoIPException('GeoIP path must be provided via parameter or the GEOIP_PATH setting.') if not path: raise GeoIPException('GeoIP path must be provided via parameter or the GEOIP_PATH setting.')
if not isinstance(path, basestring): if not isinstance(path, six.string_types):
raise TypeError('Invalid path type: %s' % type(path).__name__) raise TypeError('Invalid path type: %s' % type(path).__name__)
if os.path.isdir(path): if os.path.isdir(path):
@ -129,7 +131,7 @@ class GeoIP(object):
def _check_query(self, query, country=False, city=False, city_or_country=False): def _check_query(self, query, country=False, city=False, city_or_country=False):
"Helper routine for checking the query and database availability." "Helper routine for checking the query and database availability."
# Making sure a string was passed in for the query. # Making sure a string was passed in for the query.
if not isinstance(query, basestring): if not isinstance(query, six.string_types):
raise TypeError('GeoIP query must be a string, not type %s' % type(query).__name__) raise TypeError('GeoIP query must be a string, not type %s' % type(query).__name__)
# GeoIP only takes ASCII-encoded strings. # GeoIP only takes ASCII-encoded strings.

View File

@ -6,6 +6,8 @@ from django.contrib.gis.geos import GEOSGeometry
from django.contrib.gis.geoip import GeoIP, GeoIPException from django.contrib.gis.geoip import GeoIP, GeoIPException
from django.utils import unittest from django.utils import unittest
from django.utils import six
# Note: Requires use of both the GeoIP country and city datasets. # Note: Requires use of both the GeoIP country and city datasets.
# The GEOIP_DATA path should be the only setting set (the directory # The GEOIP_DATA path should be the only setting set (the directory
# should contain links or the actual database files 'GeoIP.dat' and # should contain links or the actual database files 'GeoIP.dat' and
@ -35,7 +37,7 @@ class GeoIPTest(unittest.TestCase):
bad_params = (23, 'foo', 15.23) bad_params = (23, 'foo', 15.23)
for bad in bad_params: for bad in bad_params:
self.assertRaises(GeoIPException, GeoIP, cache=bad) self.assertRaises(GeoIPException, GeoIP, cache=bad)
if isinstance(bad, basestring): if isinstance(bad, six.string_types):
e = GeoIPException e = GeoIPException
else: else:
e = TypeError e = TypeError

View File

@ -1,12 +1,14 @@
from django.contrib.gis.geos.geometry import GEOSGeometry, wkt_regex, hex_regex from django.contrib.gis.geos.geometry import GEOSGeometry, wkt_regex, hex_regex
from django.utils import six
def fromfile(file_h): def fromfile(file_h):
""" """
Given a string file name, returns a GEOSGeometry. The file may contain WKB, Given a string file name, returns a GEOSGeometry. The file may contain WKB,
WKT, or HEX. WKT, or HEX.
""" """
# If given a file name, get a real handle. # If given a file name, get a real handle.
if isinstance(file_h, basestring): if isinstance(file_h, six.string_types):
with open(file_h, 'rb') as file_h: with open(file_h, 'rb') as file_h:
buf = file_h.read() buf = file_h.read()
else: else:

View File

@ -27,6 +27,8 @@ from django.contrib.gis.geos.prototypes.io import wkt_r, wkt_w, wkb_r, wkb_w, ew
# For recognizing geometry input. # For recognizing geometry input.
from django.contrib.gis.geometry.regex import hex_regex, wkt_regex, json_regex from django.contrib.gis.geometry.regex import hex_regex, wkt_regex, json_regex
from django.utils import six
class GEOSGeometry(GEOSBase, ListMixin): class GEOSGeometry(GEOSBase, ListMixin):
"A class that, generally, encapsulates a GEOS geometry." "A class that, generally, encapsulates a GEOS geometry."
@ -52,7 +54,7 @@ class GEOSGeometry(GEOSBase, ListMixin):
The `srid` keyword is used to specify the Source Reference Identifier The `srid` keyword is used to specify the Source Reference Identifier
(SRID) number for this Geometry. If not set, the SRID will be None. (SRID) number for this Geometry. If not set, the SRID will be None.
""" """
if isinstance(geo_input, basestring): if isinstance(geo_input, six.string_types):
if isinstance(geo_input, unicode): if isinstance(geo_input, unicode):
# Encoding to ASCII, WKT or HEXEWKB doesn't need any more. # Encoding to ASCII, WKT or HEXEWKB doesn't need any more.
geo_input = geo_input.encode('ascii') geo_input = geo_input.encode('ascii')
@ -153,7 +155,7 @@ class GEOSGeometry(GEOSBase, ListMixin):
Equivalence testing, a Geometry may be compared with another Geometry Equivalence testing, a Geometry may be compared with another Geometry
or a WKT representation. or a WKT representation.
""" """
if isinstance(other, basestring): if isinstance(other, six.string_types):
return self.wkt == other return self.wkt == other
elif isinstance(other, GEOSGeometry): elif isinstance(other, GEOSGeometry):
return self.equals_exact(other) return self.equals_exact(other)
@ -333,7 +335,7 @@ class GEOSGeometry(GEOSBase, ListMixin):
Returns true if the elements in the DE-9IM intersection matrix for the Returns true if the elements in the DE-9IM intersection matrix for the
two Geometries match the elements in pattern. two Geometries match the elements in pattern.
""" """
if not isinstance(pattern, basestring) or len(pattern) > 9: if not isinstance(pattern, six.string_types) or len(pattern) > 9:
raise GEOSException('invalid intersection matrix pattern') raise GEOSException('invalid intersection matrix pattern')
return capi.geos_relatepattern(self.ptr, other.ptr, pattern) return capi.geos_relatepattern(self.ptr, other.ptr, pattern)

View File

@ -6,6 +6,8 @@ from django.contrib.gis.geos.prototypes.errcheck import check_geom, check_string
from django.contrib.gis.geos.prototypes.geom import c_uchar_p, geos_char_p from django.contrib.gis.geos.prototypes.geom import c_uchar_p, geos_char_p
from django.contrib.gis.geos.prototypes.threadsafe import GEOSFunc from django.contrib.gis.geos.prototypes.threadsafe import GEOSFunc
from django.utils import six
### The WKB/WKT Reader/Writer structures and pointers ### ### The WKB/WKT Reader/Writer structures and pointers ###
class WKTReader_st(Structure): pass class WKTReader_st(Structure): pass
class WKTWriter_st(Structure): pass class WKTWriter_st(Structure): pass
@ -118,7 +120,7 @@ class _WKTReader(IOBase):
ptr_type = WKT_READ_PTR ptr_type = WKT_READ_PTR
def read(self, wkt): def read(self, wkt):
if not isinstance(wkt, basestring): raise TypeError if not isinstance(wkt, six.string_types): raise TypeError
return wkt_reader_read(self.ptr, wkt) return wkt_reader_read(self.ptr, wkt)
class _WKBReader(IOBase): class _WKBReader(IOBase):
@ -131,7 +133,7 @@ class _WKBReader(IOBase):
if isinstance(wkb, buffer): if isinstance(wkb, buffer):
wkb_s = str(wkb) wkb_s = str(wkb)
return wkb_reader_read(self.ptr, wkb_s, len(wkb_s)) return wkb_reader_read(self.ptr, wkb_s, len(wkb_s))
elif isinstance(wkb, basestring): elif isinstance(wkb, six.string_types):
return wkb_reader_read_hex(self.ptr, wkb, len(wkb)) return wkb_reader_read_hex(self.ptr, wkb, len(wkb))
else: else:
raise TypeError raise TypeError

View File

@ -8,6 +8,7 @@ from django.contrib.gis.geos.base import gdal, numpy, GEOSBase
from django.contrib.gis.geos.libgeos import GEOS_PREPARE from django.contrib.gis.geos.libgeos import GEOS_PREPARE
from django.contrib.gis.geometry.test_data import TestDataMixin from django.contrib.gis.geometry.test_data import TestDataMixin
from django.utils import six
from django.utils import unittest from django.utils import unittest
@ -1004,7 +1005,7 @@ class GEOSTest(unittest.TestCase, TestDataMixin):
g = GEOSGeometry("POINT(0 0)") g = GEOSGeometry("POINT(0 0)")
self.assertTrue(g.valid) self.assertTrue(g.valid)
self.assertTrue(isinstance(g.valid_reason, basestring)) self.assertTrue(isinstance(g.valid_reason, six.string_types))
self.assertEqual(g.valid_reason, "Valid Geometry") self.assertEqual(g.valid_reason, "Valid Geometry")
print("\nBEGIN - expecting GEOS_NOTICE; safe to ignore.\n") print("\nBEGIN - expecting GEOS_NOTICE; safe to ignore.\n")
@ -1012,7 +1013,7 @@ class GEOSTest(unittest.TestCase, TestDataMixin):
g = GEOSGeometry("LINESTRING(0 0, 0 0)") g = GEOSGeometry("LINESTRING(0 0, 0 0)")
self.assertTrue(not g.valid) self.assertTrue(not g.valid)
self.assertTrue(isinstance(g.valid_reason, basestring)) self.assertTrue(isinstance(g.valid_reason, six.string_types))
self.assertTrue(g.valid_reason.startswith("Too few points in geometry component")) self.assertTrue(g.valid_reason.startswith("Too few points in geometry component"))
print("\nEND - expecting GEOS_NOTICE; safe to ignore.\n") print("\nEND - expecting GEOS_NOTICE; safe to ignore.\n")

View File

@ -1,6 +1,7 @@
import binascii import binascii
import unittest import unittest
from django.contrib.gis.geos import GEOSGeometry, WKTReader, WKTWriter, WKBReader, WKBWriter, geos_version_info from django.contrib.gis.geos import GEOSGeometry, WKTReader, WKTWriter, WKBReader, WKBWriter, geos_version_info
from django.utils import six
class GEOSIOTest(unittest.TestCase): class GEOSIOTest(unittest.TestCase):
@ -17,7 +18,7 @@ class GEOSIOTest(unittest.TestCase):
for geom in (g1, g2): for geom in (g1, g2):
self.assertEqual(ref, geom) self.assertEqual(ref, geom)
# Should only accept basestring objects. # Should only accept six.string_types objects.
self.assertRaises(TypeError, wkt_r.read, 1) self.assertRaises(TypeError, wkt_r.read, 1)
self.assertRaises(TypeError, wkt_r.read, buffer('foo')) self.assertRaises(TypeError, wkt_r.read, buffer('foo'))

View File

@ -1,6 +1,7 @@
from django.contrib.gis.geos import fromstr, Point, LineString, LinearRing, Polygon from django.contrib.gis.geos import fromstr, Point, LineString, LinearRing, Polygon
from django.utils.functional import total_ordering from django.utils.functional import total_ordering
from django.utils.safestring import mark_safe from django.utils.safestring import mark_safe
from django.utils import six
class GEvent(object): class GEvent(object):
@ -98,7 +99,7 @@ class GPolygon(GOverlayBase):
fill_opacity: fill_opacity:
The opacity of the polygon fill. Defaults to 0.4. The opacity of the polygon fill. Defaults to 0.4.
""" """
if isinstance(poly, basestring): poly = fromstr(poly) if isinstance(poly, six.string_types): poly = fromstr(poly)
if isinstance(poly, (tuple, list)): poly = Polygon(poly) if isinstance(poly, (tuple, list)): poly = Polygon(poly)
if not isinstance(poly, Polygon): if not isinstance(poly, Polygon):
raise TypeError('GPolygon may only initialize on GEOS Polygons.') raise TypeError('GPolygon may only initialize on GEOS Polygons.')
@ -148,7 +149,7 @@ class GPolyline(GOverlayBase):
The opacity of the polyline, between 0 and 1. Defaults to 1. The opacity of the polyline, between 0 and 1. Defaults to 1.
""" """
# If a GEOS geometry isn't passed in, try to contsruct one. # If a GEOS geometry isn't passed in, try to contsruct one.
if isinstance(geom, basestring): geom = fromstr(geom) if isinstance(geom, six.string_types): geom = fromstr(geom)
if isinstance(geom, (tuple, list)): geom = Polygon(geom) if isinstance(geom, (tuple, list)): geom = Polygon(geom)
# Generating the lat/lng coordinate pairs. # Generating the lat/lng coordinate pairs.
if isinstance(geom, (LineString, LinearRing)): if isinstance(geom, (LineString, LinearRing)):
@ -278,7 +279,7 @@ class GMarker(GOverlayBase):
Draggable option for GMarker, disabled by default. Draggable option for GMarker, disabled by default.
""" """
# If a GEOS geometry isn't passed in, try to construct one. # If a GEOS geometry isn't passed in, try to construct one.
if isinstance(geom, basestring): geom = fromstr(geom) if isinstance(geom, six.string_types): geom = fromstr(geom)
if isinstance(geom, (tuple, list)): geom = Point(geom) if isinstance(geom, (tuple, list)): geom = Point(geom)
if isinstance(geom, Point): if isinstance(geom, Point):
self.latlng = self.latlng_from_coords(geom.coords) self.latlng = self.latlng_from_coords(geom.coords)

View File

@ -58,7 +58,7 @@ class MeasureBase(object):
def __init__(self, default_unit=None, **kwargs): def __init__(self, default_unit=None, **kwargs):
value, self._default_unit = self.default_units(kwargs) value, self._default_unit = self.default_units(kwargs)
setattr(self, self.STANDARD_UNIT, value) setattr(self, self.STANDARD_UNIT, value)
if default_unit and isinstance(default_unit, basestring): if default_unit and isinstance(default_unit, six.string_types):
self._default_unit = default_unit self._default_unit = default_unit
def _get_standard(self): def _get_standard(self):

View File

@ -17,6 +17,7 @@ from django.contrib.gis.gdal.field import (
OFTDate, OFTDateTime, OFTInteger, OFTReal, OFTString, OFTTime) OFTDate, OFTDateTime, OFTInteger, OFTReal, OFTString, OFTTime)
from django.db import models, transaction from django.db import models, transaction
from django.contrib.localflavor.us.models import USStateField from django.contrib.localflavor.us.models import USStateField
from django.utils import six
# LayerMapping exceptions. # LayerMapping exceptions.
class LayerMapError(Exception): pass class LayerMapError(Exception): pass
@ -74,7 +75,7 @@ class LayerMapping(object):
argument usage. argument usage.
""" """
# Getting the DataSource and the associated Layer. # Getting the DataSource and the associated Layer.
if isinstance(data, basestring): if isinstance(data, six.string_types):
self.ds = DataSource(data) self.ds = DataSource(data)
else: else:
self.ds = data self.ds = data
@ -249,7 +250,7 @@ class LayerMapping(object):
sr = source_srs sr = source_srs
elif isinstance(source_srs, self.spatial_backend.spatial_ref_sys()): elif isinstance(source_srs, self.spatial_backend.spatial_ref_sys()):
sr = source_srs.srs sr = source_srs.srs
elif isinstance(source_srs, (int, basestring)): elif isinstance(source_srs, (int, six.string_types)):
sr = SpatialReference(source_srs) sr = SpatialReference(source_srs)
else: else:
# Otherwise just pulling the SpatialReference from the layer # Otherwise just pulling the SpatialReference from the layer
@ -266,7 +267,7 @@ class LayerMapping(object):
# List of fields to determine uniqueness with # List of fields to determine uniqueness with
for attr in unique: for attr in unique:
if not attr in self.mapping: raise ValueError if not attr in self.mapping: raise ValueError
elif isinstance(unique, basestring): elif isinstance(unique, six.string_types):
# Only a single field passed in. # Only a single field passed in.
if unique not in self.mapping: raise ValueError if unique not in self.mapping: raise ValueError
else: else:
@ -312,7 +313,7 @@ class LayerMapping(object):
will construct and return the uniqueness keyword arguments -- a subset will construct and return the uniqueness keyword arguments -- a subset
of the feature kwargs. of the feature kwargs.
""" """
if isinstance(self.unique, basestring): if isinstance(self.unique, six.string_types):
return {self.unique : kwargs[self.unique]} return {self.unique : kwargs[self.unique]}
else: else:
return dict((fld, kwargs[fld]) for fld in self.unique) return dict((fld, kwargs[fld]) for fld in self.unique)

View File

@ -9,6 +9,7 @@ from future_builtins import zip
# Requires GDAL to use. # Requires GDAL to use.
from django.contrib.gis.gdal import DataSource from django.contrib.gis.gdal import DataSource
from django.contrib.gis.gdal.field import OFTDate, OFTDateTime, OFTInteger, OFTReal, OFTString, OFTTime from django.contrib.gis.gdal.field import OFTDate, OFTDateTime, OFTInteger, OFTReal, OFTString, OFTTime
from django.utils import six
def mapping(data_source, geom_name='geom', layer_key=0, multi_geom=False): def mapping(data_source, geom_name='geom', layer_key=0, multi_geom=False):
""" """
@ -24,7 +25,7 @@ def mapping(data_source, geom_name='geom', layer_key=0, multi_geom=False):
`multi_geom` => Boolean (default: False) - specify as multigeometry. `multi_geom` => Boolean (default: False) - specify as multigeometry.
""" """
if isinstance(data_source, basestring): if isinstance(data_source, six.string_types):
# Instantiating the DataSource from the string. # Instantiating the DataSource from the string.
data_source = DataSource(data_source) data_source = DataSource(data_source)
elif isinstance(data_source, DataSource): elif isinstance(data_source, DataSource):

View File

@ -2,6 +2,8 @@
Utilities for manipulating Geometry WKT. Utilities for manipulating Geometry WKT.
""" """
from django.utils import six
def precision_wkt(geom, prec): def precision_wkt(geom, prec):
""" """
Returns WKT text of the geometry according to the given precision (an Returns WKT text of the geometry according to the given precision (an
@ -19,7 +21,7 @@ def precision_wkt(geom, prec):
""" """
if isinstance(prec, int): if isinstance(prec, int):
num_fmt = '%%.%df' % prec num_fmt = '%%.%df' % prec
elif isinstance(prec, basestring): elif isinstance(prec, six.string_types):
num_fmt = prec num_fmt = prec
else: else:
raise TypeError raise TypeError

View File

@ -5,10 +5,12 @@ from threading import local
from django.core.cache.backends.base import BaseCache, InvalidCacheBackendError from django.core.cache.backends.base import BaseCache, InvalidCacheBackendError
from django.utils import six
class BaseMemcachedCache(BaseCache): class BaseMemcachedCache(BaseCache):
def __init__(self, server, params, library, value_not_found_exception): def __init__(self, server, params, library, value_not_found_exception):
super(BaseMemcachedCache, self).__init__(params) super(BaseMemcachedCache, self).__init__(params)
if isinstance(server, basestring): if isinstance(server, six.string_types):
self._servers = server.split(';') self._servers = server.split(';')
else: else:
self._servers = server self._servers = server

View File

@ -6,6 +6,7 @@ import os
from django.conf import settings from django.conf import settings
from django.core.exceptions import ImproperlyConfigured from django.core.exceptions import ImproperlyConfigured
from django.core.mail.backends.console import EmailBackend as ConsoleEmailBackend from django.core.mail.backends.console import EmailBackend as ConsoleEmailBackend
from django.utils import six
class EmailBackend(ConsoleEmailBackend): class EmailBackend(ConsoleEmailBackend):
def __init__(self, *args, **kwargs): def __init__(self, *args, **kwargs):
@ -15,7 +16,7 @@ class EmailBackend(ConsoleEmailBackend):
else: else:
self.file_path = getattr(settings, 'EMAIL_FILE_PATH',None) self.file_path = getattr(settings, 'EMAIL_FILE_PATH',None)
# Make sure self.file_path is a string. # Make sure self.file_path is a string.
if not isinstance(self.file_path, basestring): if not isinstance(self.file_path, six.string_types):
raise ImproperlyConfigured('Path for saving emails is invalid: %r' % self.file_path) raise ImproperlyConfigured('Path for saving emails is invalid: %r' % self.file_path)
self.file_path = os.path.abspath(self.file_path) self.file_path = os.path.abspath(self.file_path)
# Make sure that self.file_path is an directory if it exists. # Make sure that self.file_path is an directory if it exists.

View File

@ -16,6 +16,7 @@ from io import BytesIO
from django.conf import settings from django.conf import settings
from django.core.mail.utils import DNS_NAME from django.core.mail.utils import DNS_NAME
from django.utils.encoding import smart_str, force_unicode from django.utils.encoding import smart_str, force_unicode
from django.utils import six
# Don't BASE64-encode UTF-8 messages so that we avoid unwanted attention from # Don't BASE64-encode UTF-8 messages so that we avoid unwanted attention from
@ -96,7 +97,7 @@ def forbid_multi_line_headers(name, val, encoding):
def sanitize_address(addr, encoding): def sanitize_address(addr, encoding):
if isinstance(addr, basestring): if isinstance(addr, six.string_types):
addr = parseaddr(force_unicode(addr)) addr = parseaddr(force_unicode(addr))
nm, addr = addr nm, addr = addr
nm = str(Header(nm, encoding)) nm = str(Header(nm, encoding))
@ -180,17 +181,17 @@ class EmailMessage(object):
necessary encoding conversions. necessary encoding conversions.
""" """
if to: if to:
assert not isinstance(to, basestring), '"to" argument must be a list or tuple' assert not isinstance(to, six.string_types), '"to" argument must be a list or tuple'
self.to = list(to) self.to = list(to)
else: else:
self.to = [] self.to = []
if cc: if cc:
assert not isinstance(cc, basestring), '"cc" argument must be a list or tuple' assert not isinstance(cc, six.string_types), '"cc" argument must be a list or tuple'
self.cc = list(cc) self.cc = list(cc)
else: else:
self.cc = [] self.cc = []
if bcc: if bcc:
assert not isinstance(bcc, basestring), '"bcc" argument must be a list or tuple' assert not isinstance(bcc, six.string_types), '"bcc" argument must be a list or tuple'
self.bcc = list(bcc) self.bcc = list(bcc)
else: else:
self.bcc = [] self.bcc = []

View File

@ -3,6 +3,7 @@ import sys
from django.core.management.color import color_style from django.core.management.color import color_style
from django.utils.encoding import smart_str from django.utils.encoding import smart_str
from django.utils.itercompat import is_iterable from django.utils.itercompat import is_iterable
from django.utils import six
class ModelErrorCollection: class ModelErrorCollection:
def __init__(self, outfile=sys.stdout): def __init__(self, outfile=sys.stdout):
@ -93,7 +94,7 @@ def get_validation_errors(outfile, app=None):
if isinstance(f, models.FilePathField) and not (f.allow_files or f.allow_folders): if isinstance(f, models.FilePathField) and not (f.allow_files or f.allow_folders):
e.add(opts, '"%s": FilePathFields must have either allow_files or allow_folders set to True.' % f.name) e.add(opts, '"%s": FilePathFields must have either allow_files or allow_folders set to True.' % f.name)
if f.choices: if f.choices:
if isinstance(f.choices, basestring) or not is_iterable(f.choices): if isinstance(f.choices, six.string_types) or not is_iterable(f.choices):
e.add(opts, '"%s": "choices" should be iterable (e.g., a tuple or list).' % f.name) e.add(opts, '"%s": "choices" should be iterable (e.g., a tuple or list).' % f.name)
else: else:
for c in f.choices: for c in f.choices:
@ -168,7 +169,7 @@ def get_validation_errors(outfile, app=None):
if f.unique: if f.unique:
e.add(opts, "ManyToManyFields cannot be unique. Remove the unique argument on '%s'." % f.name) e.add(opts, "ManyToManyFields cannot be unique. Remove the unique argument on '%s'." % f.name)
if f.rel.through is not None and not isinstance(f.rel.through, basestring): if f.rel.through is not None and not isinstance(f.rel.through, six.string_types):
from_model, to_model = cls, f.rel.to from_model, to_model = cls, f.rel.to
if from_model == to_model and f.rel.symmetrical and not f.rel.through._meta.auto_created: if from_model == to_model and f.rel.symmetrical and not f.rel.through._meta.auto_created:
e.add(opts, "Many-to-many fields with intermediate tables cannot be symmetrical.") e.add(opts, "Many-to-many fields with intermediate tables cannot be symmetrical.")
@ -239,7 +240,7 @@ def get_validation_errors(outfile, app=None):
"to %s and %s" % (f.name, f.rel.through._meta.object_name, "to %s and %s" % (f.name, f.rel.through._meta.object_name,
f.rel.to._meta.object_name, cls._meta.object_name) f.rel.to._meta.object_name, cls._meta.object_name)
) )
elif isinstance(f.rel.through, basestring): elif isinstance(f.rel.through, six.string_types):
e.add(opts, "'%s' specifies an m2m relation through model %s, " e.add(opts, "'%s' specifies an m2m relation through model %s, "
"which has not been installed" % (f.name, f.rel.through) "which has not been installed" % (f.name, f.rel.through)
) )

View File

@ -6,6 +6,7 @@ from io import BytesIO
from django.db import models from django.db import models
from django.utils.encoding import smart_unicode from django.utils.encoding import smart_unicode
from django.utils import six
class SerializerDoesNotExist(KeyError): class SerializerDoesNotExist(KeyError):
"""The requested serializer was not found.""" """The requested serializer was not found."""
@ -123,7 +124,7 @@ class Deserializer(object):
Init this serializer given a stream or a string Init this serializer given a stream or a string
""" """
self.options = options self.options = options
if isinstance(stream_or_string, basestring): if isinstance(stream_or_string, six.string_types):
self.stream = BytesIO(stream_or_string) self.stream = BytesIO(stream_or_string)
else: else:
self.stream = stream_or_string self.stream = stream_or_string

View File

@ -13,6 +13,7 @@ from django.core.serializers.base import DeserializationError
from django.core.serializers.python import Serializer as PythonSerializer from django.core.serializers.python import Serializer as PythonSerializer
from django.core.serializers.python import Deserializer as PythonDeserializer from django.core.serializers.python import Deserializer as PythonDeserializer
from django.utils.encoding import smart_str from django.utils.encoding import smart_str
from django.utils import six
from django.utils.timezone import is_aware from django.utils.timezone import is_aware
class Serializer(PythonSerializer): class Serializer(PythonSerializer):
@ -63,7 +64,7 @@ def Deserializer(stream_or_string, **options):
if isinstance(stream_or_string, bytes): if isinstance(stream_or_string, bytes):
stream_or_string = stream_or_string.decode('utf-8') stream_or_string = stream_or_string.decode('utf-8')
try: try:
if isinstance(stream_or_string, basestring): if isinstance(stream_or_string, six.string_types):
objects = json.loads(stream_or_string) objects = json.loads(stream_or_string)
else: else:
objects = json.load(stream_or_string) objects = json.load(stream_or_string)

View File

@ -13,6 +13,7 @@ from django.core.serializers.base import DeserializationError
from django.core.serializers.python import Serializer as PythonSerializer from django.core.serializers.python import Serializer as PythonSerializer
from django.core.serializers.python import Deserializer as PythonDeserializer from django.core.serializers.python import Deserializer as PythonDeserializer
from django.utils.encoding import smart_str from django.utils.encoding import smart_str
from django.utils import six
class DjangoSafeDumper(yaml.SafeDumper): class DjangoSafeDumper(yaml.SafeDumper):
@ -53,7 +54,7 @@ def Deserializer(stream_or_string, **options):
""" """
if isinstance(stream_or_string, bytes): if isinstance(stream_or_string, bytes):
stream_or_string = stream_or_string.decode('utf-8') stream_or_string = stream_or_string.decode('utf-8')
if isinstance(stream_or_string, basestring): if isinstance(stream_or_string, six.string_types):
stream = StringIO(stream_or_string) stream = StringIO(stream_or_string)
else: else:
stream = stream_or_string stream = stream_or_string

View File

@ -19,6 +19,7 @@ from django.utils.functional import memoize, lazy
from django.utils.importlib import import_module from django.utils.importlib import import_module
from django.utils.module_loading import module_has_submodule from django.utils.module_loading import module_has_submodule
from django.utils.regex_helper import normalize from django.utils.regex_helper import normalize
from django.utils import six
from django.utils.translation import get_language from django.utils.translation import get_language
@ -159,7 +160,7 @@ class LocaleRegexProvider(object):
""" """
language_code = get_language() language_code = get_language()
if language_code not in self._regex_dict: if language_code not in self._regex_dict:
if isinstance(self._regex, basestring): if isinstance(self._regex, six.string_types):
regex = self._regex regex = self._regex
else: else:
regex = force_unicode(self._regex) regex = force_unicode(self._regex)
@ -228,7 +229,7 @@ class RegexURLResolver(LocaleRegexProvider):
LocaleRegexProvider.__init__(self, regex) LocaleRegexProvider.__init__(self, regex)
# urlconf_name is a string representing the module containing URLconfs. # urlconf_name is a string representing the module containing URLconfs.
self.urlconf_name = urlconf_name self.urlconf_name = urlconf_name
if not isinstance(urlconf_name, basestring): if not isinstance(urlconf_name, six.string_types):
self._urlconf_module = self.urlconf_name self._urlconf_module = self.urlconf_name
self.callback = None self.callback = None
self.default_kwargs = default_kwargs or {} self.default_kwargs = default_kwargs or {}
@ -434,7 +435,7 @@ def reverse(viewname, urlconf=None, args=None, kwargs=None, prefix=None, current
if prefix is None: if prefix is None:
prefix = get_script_prefix() prefix = get_script_prefix()
if not isinstance(viewname, basestring): if not isinstance(viewname, six.string_types):
view = viewname view = viewname
else: else:
parts = viewname.split(':') parts = viewname.split(':')

View File

@ -7,6 +7,7 @@ from django.core.exceptions import ValidationError
from django.utils.translation import ugettext_lazy as _ from django.utils.translation import ugettext_lazy as _
from django.utils.encoding import smart_unicode from django.utils.encoding import smart_unicode
from django.utils.ipv6 import is_valid_ipv6_address from django.utils.ipv6 import is_valid_ipv6_address
from django.utils import six
# These values, if given to validate(), will trigger the self.required check. # These values, if given to validate(), will trigger the self.required check.
EMPTY_VALUES = (None, '', [], (), {}) EMPTY_VALUES = (None, '', [], (), {})
@ -25,7 +26,7 @@ class RegexValidator(object):
self.code = code self.code = code
# Compile the regex if it was not passed pre-compiled. # Compile the regex if it was not passed pre-compiled.
if isinstance(self.regex, basestring): if isinstance(self.regex, six.string_types):
self.regex = re.compile(self.regex) self.regex = re.compile(self.regex)
def __call__(self, value): def __call__(self, value):

View File

@ -10,6 +10,7 @@ import decimal
import sys import sys
import warnings import warnings
from django.utils import six
def _setup_environment(environ): def _setup_environment(environ):
import platform import platform
@ -361,7 +362,7 @@ WHEN (new.%(col_name)s IS NULL)
if value is None: if value is None:
return None return None
if isinstance(value, basestring): if isinstance(value, six.string_types):
return datetime.datetime.strptime(value, '%H:%M:%S') return datetime.datetime.strptime(value, '%H:%M:%S')
# Oracle doesn't support tz-aware times # Oracle doesn't support tz-aware times
@ -596,7 +597,7 @@ class OracleParam(object):
if hasattr(param, 'input_size'): if hasattr(param, 'input_size'):
# If parameter has `input_size` attribute, use that. # If parameter has `input_size` attribute, use that.
self.input_size = param.input_size self.input_size = param.input_size
elif isinstance(param, basestring) and len(param) > 4000: elif isinstance(param, six.string_types) and len(param) > 4000:
# Mark any string param greater than 4000 characters as a CLOB. # Mark any string param greater than 4000 characters as a CLOB.
self.input_size = Database.CLOB self.input_size = Database.CLOB
else: else:
@ -824,7 +825,7 @@ def to_unicode(s):
Convert strings to Unicode objects (and return all other data types Convert strings to Unicode objects (and return all other data types
unchanged). unchanged).
""" """
if isinstance(s, basestring): if isinstance(s, six.string_types):
return force_unicode(s) return force_unicode(s)
return s return s

View File

@ -21,6 +21,7 @@ from django.utils import timezone
from django.utils.translation import ugettext_lazy as _ from django.utils.translation import ugettext_lazy as _
from django.utils.encoding import smart_unicode, force_unicode from django.utils.encoding import smart_unicode, force_unicode
from django.utils.ipv6 import clean_ipv6_address from django.utils.ipv6 import clean_ipv6_address
from django.utils import six
class NOT_PROVIDED: class NOT_PROVIDED:
pass pass
@ -625,7 +626,7 @@ class CharField(Field):
return "CharField" return "CharField"
def to_python(self, value): def to_python(self, value):
if isinstance(value, basestring) or value is None: if isinstance(value, six.string_types) or value is None:
return value return value
return smart_unicode(value) return smart_unicode(value)
@ -864,7 +865,7 @@ class DecimalField(Field):
raise exceptions.ValidationError(msg) raise exceptions.ValidationError(msg)
def _format(self, value): def _format(self, value):
if isinstance(value, basestring) or value is None: if isinstance(value, six.string_types) or value is None:
return value return value
else: else:
return self.format_number(value) return self.format_number(value)
@ -1185,7 +1186,7 @@ class TextField(Field):
return "TextField" return "TextField"
def get_prep_value(self, value): def get_prep_value(self, value):
if isinstance(value, basestring) or value is None: if isinstance(value, six.string_types) or value is None:
return value return value
return smart_unicode(value) return smart_unicode(value)

View File

@ -9,6 +9,7 @@ from django.core.files.storage import default_storage
from django.core.files.images import ImageFile from django.core.files.images import ImageFile
from django.db.models import signals from django.db.models import signals
from django.utils.encoding import force_unicode, smart_str from django.utils.encoding import force_unicode, smart_str
from django.utils import six
from django.utils.translation import ugettext_lazy as _ from django.utils.translation import ugettext_lazy as _
class FieldFile(File): class FieldFile(File):
@ -176,7 +177,7 @@ class FileDescriptor(object):
# subclasses might also want to subclass the attribute class]. This # subclasses might also want to subclass the attribute class]. This
# object understands how to convert a path to a file, and also how to # object understands how to convert a path to a file, and also how to
# handle None. # handle None.
if isinstance(file, basestring) or file is None: if isinstance(file, six.string_types) or file is None:
attr = self.field.attr_class(instance, self.field, file) attr = self.field.attr_class(instance, self.field, file)
instance.__dict__[self.field.name] = attr instance.__dict__[self.field.name] = attr

View File

@ -10,6 +10,7 @@ from django.db.models.query import QuerySet
from django.db.models.query_utils import QueryWrapper from django.db.models.query_utils import QueryWrapper
from django.db.models.deletion import CASCADE from django.db.models.deletion import CASCADE
from django.utils.encoding import smart_unicode from django.utils.encoding import smart_unicode
from django.utils import six
from django.utils.translation import ugettext_lazy as _, string_concat from django.utils.translation import ugettext_lazy as _, string_concat
from django.utils.functional import curry, cached_property from django.utils.functional import curry, cached_property
from django.core import exceptions from django.core import exceptions
@ -104,7 +105,7 @@ class RelatedField(object):
} }
other = self.rel.to other = self.rel.to
if isinstance(other, basestring) or other._meta.pk is None: if isinstance(other, six.string_types) or other._meta.pk is None:
def resolve_related_class(field, model, cls): def resolve_related_class(field, model, cls):
field.rel.to = model field.rel.to = model
field.do_related_class(model, cls) field.do_related_class(model, cls)
@ -865,7 +866,7 @@ class ManyToOneRel(object):
try: try:
to._meta to._meta
except AttributeError: # to._meta doesn't exist, so it must be RECURSIVE_RELATIONSHIP_CONSTANT except AttributeError: # to._meta doesn't exist, so it must be RECURSIVE_RELATIONSHIP_CONSTANT
assert isinstance(to, basestring), "'to' must be either a model, a model name or the string %r" % RECURSIVE_RELATIONSHIP_CONSTANT assert isinstance(to, six.string_types), "'to' must be either a model, a model name or the string %r" % RECURSIVE_RELATIONSHIP_CONSTANT
self.to, self.field_name = to, field_name self.to, self.field_name = to, field_name
self.related_name = related_name self.related_name = related_name
if limit_choices_to is None: if limit_choices_to is None:
@ -933,7 +934,7 @@ class ForeignKey(RelatedField, Field):
try: try:
to_name = to._meta.object_name.lower() to_name = to._meta.object_name.lower()
except AttributeError: # to._meta doesn't exist, so it must be RECURSIVE_RELATIONSHIP_CONSTANT except AttributeError: # to._meta doesn't exist, so it must be RECURSIVE_RELATIONSHIP_CONSTANT
assert isinstance(to, basestring), "%s(%r) is invalid. First parameter to ForeignKey must be either a model, a model name, or the string %r" % (self.__class__.__name__, to, RECURSIVE_RELATIONSHIP_CONSTANT) assert isinstance(to, six.string_types), "%s(%r) is invalid. First parameter to ForeignKey must be either a model, a model name, or the string %r" % (self.__class__.__name__, to, RECURSIVE_RELATIONSHIP_CONSTANT)
else: else:
assert not to._meta.abstract, "%s cannot define a relation with abstract class %s" % (self.__class__.__name__, to._meta.object_name) assert not to._meta.abstract, "%s cannot define a relation with abstract class %s" % (self.__class__.__name__, to._meta.object_name)
# For backwards compatibility purposes, we need to *try* and set # For backwards compatibility purposes, we need to *try* and set
@ -1004,7 +1005,7 @@ class ForeignKey(RelatedField, Field):
def contribute_to_class(self, cls, name): def contribute_to_class(self, cls, name):
super(ForeignKey, self).contribute_to_class(cls, name) super(ForeignKey, self).contribute_to_class(cls, name)
setattr(cls, self.name, ReverseSingleRelatedObjectDescriptor(self)) setattr(cls, self.name, ReverseSingleRelatedObjectDescriptor(self))
if isinstance(self.rel.to, basestring): if isinstance(self.rel.to, six.string_types):
target = self.rel.to target = self.rel.to
else: else:
target = self.rel.to._meta.db_table target = self.rel.to._meta.db_table
@ -1022,7 +1023,7 @@ class ForeignKey(RelatedField, Field):
def formfield(self, **kwargs): def formfield(self, **kwargs):
db = kwargs.pop('using', None) db = kwargs.pop('using', None)
if isinstance(self.rel.to, basestring): if isinstance(self.rel.to, six.string_types):
raise ValueError("Cannot create form field for %r yet, because " raise ValueError("Cannot create form field for %r yet, because "
"its related model %r has not been loaded yet" % "its related model %r has not been loaded yet" %
(self.name, self.rel.to)) (self.name, self.rel.to))
@ -1079,13 +1080,13 @@ class OneToOneField(ForeignKey):
def create_many_to_many_intermediary_model(field, klass): def create_many_to_many_intermediary_model(field, klass):
from django.db import models from django.db import models
managed = True managed = True
if isinstance(field.rel.to, basestring) and field.rel.to != RECURSIVE_RELATIONSHIP_CONSTANT: if isinstance(field.rel.to, six.string_types) and field.rel.to != RECURSIVE_RELATIONSHIP_CONSTANT:
to_model = field.rel.to to_model = field.rel.to
to = to_model.split('.')[-1] to = to_model.split('.')[-1]
def set_managed(field, model, cls): def set_managed(field, model, cls):
field.rel.through._meta.managed = model._meta.managed or cls._meta.managed field.rel.through._meta.managed = model._meta.managed or cls._meta.managed
add_lazy_relation(klass, field, to_model, set_managed) add_lazy_relation(klass, field, to_model, set_managed)
elif isinstance(field.rel.to, basestring): elif isinstance(field.rel.to, six.string_types):
to = klass._meta.object_name to = klass._meta.object_name
to_model = klass to_model = klass
managed = klass._meta.managed managed = klass._meta.managed
@ -1124,7 +1125,7 @@ class ManyToManyField(RelatedField, Field):
try: try:
assert not to._meta.abstract, "%s cannot define a relation with abstract class %s" % (self.__class__.__name__, to._meta.object_name) assert not to._meta.abstract, "%s cannot define a relation with abstract class %s" % (self.__class__.__name__, to._meta.object_name)
except AttributeError: # to._meta doesn't exist, so it must be RECURSIVE_RELATIONSHIP_CONSTANT except AttributeError: # to._meta doesn't exist, so it must be RECURSIVE_RELATIONSHIP_CONSTANT
assert isinstance(to, basestring), "%s(%r) is invalid. First parameter to ManyToManyField must be either a model, a model name, or the string %r" % (self.__class__.__name__, to, RECURSIVE_RELATIONSHIP_CONSTANT) assert isinstance(to, six.string_types), "%s(%r) is invalid. First parameter to ManyToManyField must be either a model, a model name, or the string %r" % (self.__class__.__name__, to, RECURSIVE_RELATIONSHIP_CONSTANT)
# Python 2.6 and earlier require dictionary keys to be of str type, # Python 2.6 and earlier require dictionary keys to be of str type,
# not unicode and class names must be ASCII (in Python 2.x), so we # not unicode and class names must be ASCII (in Python 2.x), so we
# forcibly coerce it here (breaks early if there's a problem). # forcibly coerce it here (breaks early if there's a problem).
@ -1232,12 +1233,12 @@ class ManyToManyField(RelatedField, Field):
# Populate some necessary rel arguments so that cross-app relations # Populate some necessary rel arguments so that cross-app relations
# work correctly. # work correctly.
if isinstance(self.rel.through, basestring): if isinstance(self.rel.through, six.string_types):
def resolve_through_model(field, model, cls): def resolve_through_model(field, model, cls):
field.rel.through = model field.rel.through = model
add_lazy_relation(cls, self, self.rel.through, resolve_through_model) add_lazy_relation(cls, self, self.rel.through, resolve_through_model)
if isinstance(self.rel.to, basestring): if isinstance(self.rel.to, six.string_types):
target = self.rel.to target = self.rel.to
else: else:
target = self.rel.to._meta.db_table target = self.rel.to._meta.db_table

View File

@ -10,6 +10,7 @@ from django.db.models.loading import get_models, app_cache_ready
from django.utils.translation import activate, deactivate_all, get_language, string_concat from django.utils.translation import activate, deactivate_all, get_language, string_concat
from django.utils.encoding import force_unicode, smart_str from django.utils.encoding import force_unicode, smart_str
from django.utils.datastructures import SortedDict from django.utils.datastructures import SortedDict
from django.utils import six
# Calculate the verbose_name by converting from InitialCaps to "lowercase with spaces". # Calculate the verbose_name by converting from InitialCaps to "lowercase with spaces".
get_verbose_name = lambda class_name: re.sub('(((?<=[a-z])[A-Z])|([A-Z](?![A-Z]|$)))', ' \\1', class_name).lower().strip() get_verbose_name = lambda class_name: re.sub('(((?<=[a-z])[A-Z])|([A-Z](?![A-Z]|$)))', ' \\1', class_name).lower().strip()
@ -400,7 +401,7 @@ class Options(object):
proxy_cache = cache.copy() proxy_cache = cache.copy()
for klass in get_models(include_auto_created=True, only_installed=False): for klass in get_models(include_auto_created=True, only_installed=False):
for f in klass._meta.local_fields: for f in klass._meta.local_fields:
if f.rel and not isinstance(f.rel.to, basestring): if f.rel and not isinstance(f.rel.to, six.string_types):
if self == f.rel.to._meta: if self == f.rel.to._meta:
cache[RelatedObject(f.rel.to, klass, f)] = None cache[RelatedObject(f.rel.to, klass, f)] = None
proxy_cache[RelatedObject(f.rel.to, klass, f)] = None proxy_cache[RelatedObject(f.rel.to, klass, f)] = None
@ -442,7 +443,7 @@ class Options(object):
cache[obj] = model cache[obj] = model
for klass in get_models(only_installed=False): for klass in get_models(only_installed=False):
for f in klass._meta.local_many_to_many: for f in klass._meta.local_many_to_many:
if f.rel and not isinstance(f.rel.to, basestring) and self == f.rel.to._meta: if f.rel and not isinstance(f.rel.to, six.string_types) and self == f.rel.to._meta:
cache[RelatedObject(f.rel.to, klass, f)] = None cache[RelatedObject(f.rel.to, klass, f)] = None
if app_cache_ready(): if app_cache_ready():
self._related_many_to_many_cache = cache self._related_many_to_many_cache = cache

View File

@ -4,6 +4,7 @@ from threading import local
from django.conf import settings from django.conf import settings
from django.core.exceptions import ImproperlyConfigured from django.core.exceptions import ImproperlyConfigured
from django.utils.importlib import import_module from django.utils.importlib import import_module
from django.utils import six
DEFAULT_DB_ALIAS = 'default' DEFAULT_DB_ALIAS = 'default'
@ -108,7 +109,7 @@ class ConnectionRouter(object):
def __init__(self, routers): def __init__(self, routers):
self.routers = [] self.routers = []
for r in routers: for r in routers:
if isinstance(r, basestring): if isinstance(r, six.string_types):
try: try:
module_name, klass_name = r.rsplit('.', 1) module_name, klass_name = r.rsplit('.', 1)
module = import_module(module_name) module = import_module(module_name)

View File

@ -11,6 +11,7 @@ from django.utils import datetime_safe
from django.utils.dates import MONTHS from django.utils.dates import MONTHS
from django.utils.safestring import mark_safe from django.utils.safestring import mark_safe
from django.utils.formats import get_format from django.utils.formats import get_format
from django.utils import six
from django.conf import settings from django.conf import settings
__all__ = ('SelectDateWidget',) __all__ = ('SelectDateWidget',)
@ -64,7 +65,7 @@ class SelectDateWidget(Widget):
year_val, month_val, day_val = value.year, value.month, value.day year_val, month_val, day_val = value.year, value.month, value.day
except AttributeError: except AttributeError:
year_val = month_val = day_val = None year_val = month_val = day_val = None
if isinstance(value, basestring): if isinstance(value, six.string_types):
if settings.USE_L10N: if settings.USE_L10N:
try: try:
input_format = get_format('DATE_INPUT_FORMATS')[0] input_format = get_format('DATE_INPUT_FORMATS')[0]

View File

@ -22,6 +22,7 @@ from django.forms.widgets import (TextInput, PasswordInput, HiddenInput,
from django.utils import formats from django.utils import formats
from django.utils.encoding import smart_unicode, force_unicode from django.utils.encoding import smart_unicode, force_unicode
from django.utils.ipv6 import clean_ipv6_address from django.utils.ipv6 import clean_ipv6_address
from django.utils import six
from django.utils.translation import ugettext_lazy as _ from django.utils.translation import ugettext_lazy as _
# Provide this import for backwards compatibility. # Provide this import for backwards compatibility.
@ -445,7 +446,7 @@ class RegexField(CharField):
return self._regex return self._regex
def _set_regex(self, regex): def _set_regex(self, regex):
if isinstance(regex, basestring): if isinstance(regex, six.string_types):
regex = re.compile(regex, re.UNICODE) regex = re.compile(regex, re.UNICODE)
self._regex = regex self._regex = regex
if hasattr(self, '_regex_validator') and self._regex_validator in self.validators: if hasattr(self, '_regex_validator') and self._regex_validator in self.validators:
@ -633,7 +634,7 @@ class BooleanField(Field):
# will submit for False. Also check for '0', since this is what # will submit for False. Also check for '0', since this is what
# RadioSelect will provide. Because bool("True") == bool('1') == True, # RadioSelect will provide. Because bool("True") == bool('1') == True,
# we don't need to handle that explicitly. # we don't need to handle that explicitly.
if isinstance(value, basestring) and value.lower() in ('false', '0'): if isinstance(value, six.string_types) and value.lower() in ('false', '0'):
value = False value = False
else: else:
value = bool(value) value = bool(value)

View File

@ -16,6 +16,7 @@ from django.utils.html import conditional_escape, format_html, format_html_join
from django.utils.translation import ugettext, ugettext_lazy from django.utils.translation import ugettext, ugettext_lazy
from django.utils.encoding import StrAndUnicode, force_unicode from django.utils.encoding import StrAndUnicode, force_unicode
from django.utils.safestring import mark_safe from django.utils.safestring import mark_safe
from django.utils import six
from django.utils import datetime_safe, formats from django.utils import datetime_safe, formats
from django.utils import six from django.utils import six
@ -522,7 +523,7 @@ class CheckboxInput(Widget):
value = data.get(name) value = data.get(name)
# Translate true and false strings to boolean values. # Translate true and false strings to boolean values.
values = {'true': True, 'false': False} values = {'true': True, 'false': False}
if isinstance(value, basestring): if isinstance(value, six.string_types):
value = values.get(value.lower(), value) value = values.get(value.lower(), value)
return value return value

View File

@ -18,6 +18,7 @@ from django.utils.safestring import (SafeData, EscapeData, mark_safe,
from django.utils.formats import localize from django.utils.formats import localize
from django.utils.html import escape from django.utils.html import escape
from django.utils.module_loading import module_has_submodule from django.utils.module_loading import module_has_submodule
from django.utils import six
from django.utils.timezone import template_localtime from django.utils.timezone import template_localtime
@ -1188,7 +1189,7 @@ class Library(object):
from django.template.loader import get_template, select_template from django.template.loader import get_template, select_template
if isinstance(file_name, Template): if isinstance(file_name, Template):
t = file_name t = file_name
elif not isinstance(file_name, basestring) and is_iterable(file_name): elif not isinstance(file_name, six.string_types) and is_iterable(file_name):
t = select_template(file_name) t = select_template(file_name)
else: else:
t = get_template(file_name) t = get_template(file_name)

View File

@ -29,6 +29,7 @@ from django.core.exceptions import ImproperlyConfigured
from django.template.base import Origin, Template, Context, TemplateDoesNotExist, add_to_builtins from django.template.base import Origin, Template, Context, TemplateDoesNotExist, add_to_builtins
from django.utils.importlib import import_module from django.utils.importlib import import_module
from django.conf import settings from django.conf import settings
from django.utils import six
template_source_loaders = None template_source_loaders = None
@ -89,7 +90,7 @@ def find_template_loader(loader):
loader, args = loader[0], loader[1:] loader, args = loader[0], loader[1:]
else: else:
args = [] args = []
if isinstance(loader, basestring): if isinstance(loader, six.string_types):
module, attr = loader.rsplit('.', 1) module, attr = loader.rsplit('.', 1)
try: try:
mod = import_module(module) mod = import_module(module)

View File

@ -1,5 +1,6 @@
from django.http import HttpResponse from django.http import HttpResponse
from django.template import loader, Context, RequestContext from django.template import loader, Context, RequestContext
from django.utils import six
class ContentNotRenderedError(Exception): class ContentNotRenderedError(Exception):
@ -53,7 +54,7 @@ class SimpleTemplateResponse(HttpResponse):
"Accepts a template object, path-to-template or list of paths" "Accepts a template object, path-to-template or list of paths"
if isinstance(template, (list, tuple)): if isinstance(template, (list, tuple)):
return loader.select_template(template) return loader.select_template(template)
elif isinstance(template, basestring): elif isinstance(template, six.string_types):
return loader.get_template(template) return loader.get_template(template)
else: else:
return template return template

View File

@ -5,6 +5,7 @@ from django.template import (Node, Variable, TemplateSyntaxError,
TokenParser, Library, TOKEN_TEXT, TOKEN_VAR) TokenParser, Library, TOKEN_TEXT, TOKEN_VAR)
from django.template.base import _render_value_in_context from django.template.base import _render_value_in_context
from django.template.defaulttags import token_kwargs from django.template.defaulttags import token_kwargs
from django.utils import six
from django.utils import translation from django.utils import translation
@ -76,7 +77,7 @@ class TranslateNode(Node):
self.asvar = asvar self.asvar = asvar
self.message_context = message_context self.message_context = message_context
self.filter_expression = filter_expression self.filter_expression = filter_expression
if isinstance(self.filter_expression.var, basestring): if isinstance(self.filter_expression.var, six.string_types):
self.filter_expression.var = Variable("'%s'" % self.filter_expression.var = Variable("'%s'" %
self.filter_expression.var) self.filter_expression.var)

View File

@ -7,6 +7,7 @@ except ImportError:
from django.template import Node from django.template import Node
from django.template import TemplateSyntaxError, Library from django.template import TemplateSyntaxError, Library
from django.utils import six
from django.utils import timezone from django.utils import timezone
register = Library() register = Library()
@ -64,7 +65,7 @@ def do_timezone(value, arg):
# Obtain a tzinfo instance # Obtain a tzinfo instance
if isinstance(arg, tzinfo): if isinstance(arg, tzinfo):
tz = arg tz = arg
elif isinstance(arg, basestring) and pytz is not None: elif isinstance(arg, six.string_types) and pytz is not None:
try: try:
tz = pytz.timezone(arg) tz = pytz.timezone(arg)
except pytz.UnknownTimeZoneError: except pytz.UnknownTimeZoneError:

View File

@ -480,7 +480,7 @@ class DocTest:
Create a new DocTest containing the given examples. The Create a new DocTest containing the given examples. The
DocTest's globals are initialized with a copy of `globs`. DocTest's globals are initialized with a copy of `globs`.
""" """
assert not isinstance(examples, basestring), \ assert not isinstance(examples, six.string_types), \
"DocTest no longer accepts str; use DocTestParser instead" "DocTest no longer accepts str; use DocTestParser instead"
self.examples = examples self.examples = examples
self.docstring = docstring self.docstring = docstring
@ -906,13 +906,13 @@ class DocTestFinder:
# Look for tests in a module's __test__ dictionary. # Look for tests in a module's __test__ dictionary.
if inspect.ismodule(obj) and self._recurse: if inspect.ismodule(obj) and self._recurse:
for valname, val in getattr(obj, '__test__', {}).items(): for valname, val in getattr(obj, '__test__', {}).items():
if not isinstance(valname, basestring): if not isinstance(valname, six.string_types):
raise ValueError("DocTestFinder.find: __test__ keys " raise ValueError("DocTestFinder.find: __test__ keys "
"must be strings: %r" % "must be strings: %r" %
(type(valname),)) (type(valname),))
if not (inspect.isfunction(val) or inspect.isclass(val) or if not (inspect.isfunction(val) or inspect.isclass(val) or
inspect.ismethod(val) or inspect.ismodule(val) or inspect.ismethod(val) or inspect.ismodule(val) or
isinstance(val, basestring)): isinstance(val, six.string_types)):
raise ValueError("DocTestFinder.find: __test__ values " raise ValueError("DocTestFinder.find: __test__ values "
"must be strings, functions, methods, " "must be strings, functions, methods, "
"classes, or modules: %r" % "classes, or modules: %r" %
@ -945,7 +945,7 @@ class DocTestFinder:
""" """
# Extract the object's docstring. If it doesn't have one, # Extract the object's docstring. If it doesn't have one,
# then return None (no test for this object). # then return None (no test for this object).
if isinstance(obj, basestring): if isinstance(obj, six.string_types):
docstring = obj docstring = obj
else: else:
try: try:
@ -953,7 +953,7 @@ class DocTestFinder:
docstring = '' docstring = ''
else: else:
docstring = obj.__doc__ docstring = obj.__doc__
if not isinstance(docstring, basestring): if not isinstance(docstring, six.string_types):
docstring = str(docstring) docstring = str(docstring)
except (TypeError, AttributeError): except (TypeError, AttributeError):
docstring = '' docstring = ''

View File

@ -116,7 +116,7 @@ def encode_multipart(boundary, data):
for (key, value) in data.items(): for (key, value) in data.items():
if is_file(value): if is_file(value):
lines.extend(encode_file(boundary, key, value)) lines.extend(encode_file(boundary, key, value))
elif not isinstance(value, basestring) and is_iterable(value): elif not isinstance(value, six.string_types) and is_iterable(value):
for item in value: for item in value:
if is_file(item): if is_file(item):
lines.extend(encode_file(boundary, key, item)) lines.extend(encode_file(boundary, key, item))

View File

@ -8,6 +8,7 @@ import re
from HTMLParser import HTMLParseError from HTMLParser import HTMLParseError
from django.utils.encoding import force_unicode from django.utils.encoding import force_unicode
from django.utils.html_parser import HTMLParser from django.utils.html_parser import HTMLParser
from django.utils import six
WHITESPACE = re.compile('\s+') WHITESPACE = re.compile('\s+')
@ -24,11 +25,11 @@ class Element(object):
self.children = [] self.children = []
def append(self, element): def append(self, element):
if isinstance(element, basestring): if isinstance(element, six.string_types):
element = force_unicode(element) element = force_unicode(element)
element = normalize_whitespace(element) element = normalize_whitespace(element)
if self.children: if self.children:
if isinstance(self.children[-1], basestring): if isinstance(self.children[-1], six.string_types):
self.children[-1] += element self.children[-1] += element
self.children[-1] = normalize_whitespace(self.children[-1]) self.children[-1] = normalize_whitespace(self.children[-1])
return return
@ -36,7 +37,7 @@ class Element(object):
# removing last children if it is only whitespace # removing last children if it is only whitespace
# this can result in incorrect dom representations since # this can result in incorrect dom representations since
# whitespace between inline tags like <span> is significant # whitespace between inline tags like <span> is significant
if isinstance(self.children[-1], basestring): if isinstance(self.children[-1], six.string_types):
if self.children[-1].isspace(): if self.children[-1].isspace():
self.children.pop() self.children.pop()
if element: if element:
@ -45,7 +46,7 @@ class Element(object):
def finalize(self): def finalize(self):
def rstrip_last_element(children): def rstrip_last_element(children):
if children: if children:
if isinstance(children[-1], basestring): if isinstance(children[-1], six.string_types):
children[-1] = children[-1].rstrip() children[-1] = children[-1].rstrip()
if not children[-1]: if not children[-1]:
children.pop() children.pop()
@ -54,7 +55,7 @@ class Element(object):
rstrip_last_element(self.children) rstrip_last_element(self.children)
for i, child in enumerate(self.children): for i, child in enumerate(self.children):
if isinstance(child, basestring): if isinstance(child, six.string_types):
self.children[i] = child.strip() self.children[i] = child.strip()
elif hasattr(child, 'finalize'): elif hasattr(child, 'finalize'):
child.finalize() child.finalize()
@ -87,15 +88,15 @@ class Element(object):
return not self.__eq__(element) return not self.__eq__(element)
def _count(self, element, count=True): def _count(self, element, count=True):
if not isinstance(element, basestring): if not isinstance(element, six.string_types):
if self == element: if self == element:
return 1 return 1
i = 0 i = 0
for child in self.children: for child in self.children:
# child is text content and element is also text content, then # child is text content and element is also text content, then
# make a simple "text" in "text" # make a simple "text" in "text"
if isinstance(child, basestring): if isinstance(child, six.string_types):
if isinstance(element, basestring): if isinstance(element, six.string_types):
if count: if count:
i += child.count(element) i += child.count(element)
elif element in child: elif element in child:
@ -219,6 +220,6 @@ def parse_html(html):
document.finalize() document.finalize()
# Removing ROOT element if it's not necessary # Removing ROOT element if it's not necessary
if len(document.children) == 1: if len(document.children) == 1:
if not isinstance(document.children[0], basestring): if not isinstance(document.children[0], six.string_types):
document = document.children[0] document = document.children[0]
return document return document

View File

@ -6,6 +6,7 @@ from django.template import Template, loader, TemplateDoesNotExist
from django.template.loaders import cached from django.template.loaders import cached
from django.utils.translation import deactivate from django.utils.translation import deactivate
from django.utils.functional import wraps from django.utils.functional import wraps
from django.utils import six
__all__ = ( __all__ = (
@ -35,7 +36,7 @@ class ContextList(list):
in a list of context objects. in a list of context objects.
""" """
def __getitem__(self, key): def __getitem__(self, key):
if isinstance(key, basestring): if isinstance(key, six.string_types):
for subcontext in self: for subcontext in self:
if key in subcontext: if key in subcontext:
return subcontext[key] return subcontext[key]

View File

@ -27,6 +27,8 @@ import sys
import tarfile import tarfile
import zipfile import zipfile
from django.utils import six
class ArchiveException(Exception): class ArchiveException(Exception):
""" """
@ -58,7 +60,7 @@ class Archive(object):
@staticmethod @staticmethod
def _archive_cls(file): def _archive_cls(file):
cls = None cls = None
if isinstance(file, basestring): if isinstance(file, six.string_types):
filename = file filename = file
else: else:
try: try:

View File

@ -4,6 +4,8 @@ Common checksum routines (used in multiple localflavor/ cases, for example).
__all__ = ['luhn',] __all__ = ['luhn',]
from django.utils import six
LUHN_ODD_LOOKUP = (0, 2, 4, 6, 8, 1, 3, 5, 7, 9) # sum_of_digits(index * 2) LUHN_ODD_LOOKUP = (0, 2, 4, 6, 8, 1, 3, 5, 7, 9) # sum_of_digits(index * 2)
def luhn(candidate): def luhn(candidate):
@ -12,7 +14,7 @@ def luhn(candidate):
algorithm (used in validation of, for example, credit cards). algorithm (used in validation of, for example, credit cards).
Both numeric and string candidates are accepted. Both numeric and string candidates are accepted.
""" """
if not isinstance(candidate, basestring): if not isinstance(candidate, six.string_types):
candidate = str(candidate) candidate = str(candidate)
try: try:
evens = sum([int(c) for c in candidate[-1::-2]]) evens = sum([int(c) for c in candidate[-1::-2]])

View File

@ -23,6 +23,8 @@ import re
import sys import sys
import types import types
from django.utils import six
IDENTIFIER = re.compile('^[a-z_][a-z0-9_]*$', re.I) IDENTIFIER = re.compile('^[a-z_][a-z0-9_]*$', re.I)
def valid_ident(s): def valid_ident(s):
@ -231,7 +233,7 @@ class BaseConfigurator(object):
isinstance(value, tuple): isinstance(value, tuple):
value = ConvertingTuple(value) value = ConvertingTuple(value)
value.configurator = self value.configurator = self
elif isinstance(value, basestring): # str for py3k elif isinstance(value, six.string_types): # str for py3k
m = self.CONVERT_PATTERN.match(value) m = self.CONVERT_PATTERN.match(value)
if m: if m:
d = m.groupdict() d = m.groupdict()

View File

@ -64,7 +64,7 @@ def force_unicode(s, encoding='utf-8', strings_only=False, errors='strict'):
if strings_only and is_protected_type(s): if strings_only and is_protected_type(s):
return s return s
try: try:
if not isinstance(s, basestring,): if not isinstance(s, six.string_types,):
if hasattr(s, '__unicode__'): if hasattr(s, '__unicode__'):
s = unicode(s) s = unicode(s)
else: else:
@ -109,7 +109,7 @@ def smart_str(s, encoding='utf-8', strings_only=False, errors='strict'):
return s return s
if isinstance(s, Promise): if isinstance(s, Promise):
return unicode(s).encode(encoding, errors) return unicode(s).encode(encoding, errors)
elif not isinstance(s, basestring): elif not isinstance(s, six.string_types):
try: try:
return str(s) return str(s)
except UnicodeEncodeError: except UnicodeEncodeError:

View File

@ -178,7 +178,7 @@ def sanitize_separators(value):
""" """
if settings.USE_L10N: if settings.USE_L10N:
decimal_separator = get_format('DECIMAL_SEPARATOR') decimal_separator = get_format('DECIMAL_SEPARATOR')
if isinstance(value, basestring): if isinstance(value, six.string_types):
parts = [] parts = []
if decimal_separator in value: if decimal_separator in value:
value, decimals = value.split(decimal_separator, 1) value, decimals = value.split(decimal_separator, 1)

View File

@ -7,6 +7,8 @@ should be good enough for a large class of URLS, however.
""" """
from __future__ import unicode_literals from __future__ import unicode_literals
from django.utils import six
# Mapping of an escape character to a representative of that class. So, e.g., # Mapping of an escape character to a representative of that class. So, e.g.,
# "\w" is replaced by "x" in a reverse URL. A value of None means to ignore # "\w" is replaced by "x" in a reverse URL. A value of None means to ignore
# this sequence. Any missing key is mapped to itself. # this sequence. Any missing key is mapped to itself.
@ -302,7 +304,7 @@ def flatten_result(source):
result_args = [[]] result_args = [[]]
pos = last = 0 pos = last = 0
for pos, elt in enumerate(source): for pos, elt in enumerate(source):
if isinstance(elt, basestring): if isinstance(elt, six.string_types):
continue continue
piece = ''.join(source[last:pos]) piece = ''.join(source[last:pos])
if isinstance(elt, Group): if isinstance(elt, Group):

View File

@ -13,6 +13,7 @@ except ImportError:
pytz = None pytz = None
from django.conf import settings from django.conf import settings
from django.utils import six
__all__ = [ __all__ = [
'utc', 'get_default_timezone', 'get_current_timezone', 'utc', 'get_default_timezone', 'get_current_timezone',
@ -107,7 +108,7 @@ def get_default_timezone():
""" """
global _localtime global _localtime
if _localtime is None: if _localtime is None:
if isinstance(settings.TIME_ZONE, basestring) and pytz is not None: if isinstance(settings.TIME_ZONE, six.string_types) and pytz is not None:
_localtime = pytz.timezone(settings.TIME_ZONE) _localtime = pytz.timezone(settings.TIME_ZONE)
else: else:
_localtime = LocalTimezone() _localtime = LocalTimezone()
@ -160,7 +161,7 @@ def activate(timezone):
""" """
if isinstance(timezone, tzinfo): if isinstance(timezone, tzinfo):
_active.value = timezone _active.value = timezone
elif isinstance(timezone, basestring) and pytz is not None: elif isinstance(timezone, six.string_types) and pytz is not None:
_active.value = pytz.timezone(timezone) _active.value = pytz.timezone(timezone)
else: else:
raise ValueError("Invalid timezone: %r" % timezone) raise ValueError("Invalid timezone: %r" % timezone)

View File

@ -15,6 +15,7 @@ from django.template.defaultfilters import force_escape, pprint
from django.utils.html import escape from django.utils.html import escape
from django.utils.importlib import import_module from django.utils.importlib import import_module
from django.utils.encoding import smart_unicode, smart_str from django.utils.encoding import smart_unicode, smart_str
from django.utils import six
HIDDEN_SETTINGS = re.compile('API|TOKEN|KEY|SECRET|PASS|PROFANITIES_LIST|SIGNATURE') HIDDEN_SETTINGS = re.compile('API|TOKEN|KEY|SECRET|PASS|PROFANITIES_LIST|SIGNATURE')
@ -214,7 +215,7 @@ class ExceptionReporter(object):
self.loader_debug_info = None self.loader_debug_info = None
# Handle deprecated string exceptions # Handle deprecated string exceptions
if isinstance(self.exc_type, basestring): if isinstance(self.exc_type, six.string_types):
self.exc_value = Exception('Deprecated String Exception: %r' % self.exc_type) self.exc_value = Exception('Deprecated String Exception: %r' % self.exc_type)
self.exc_type = type(self.exc_value) self.exc_type = type(self.exc_value)

View File

@ -8,6 +8,7 @@ from django.utils.translation import check_for_language, activate, to_locale, ge
from django.utils.text import javascript_quote from django.utils.text import javascript_quote
from django.utils.encoding import smart_unicode from django.utils.encoding import smart_unicode
from django.utils.formats import get_format_modules, get_format from django.utils.formats import get_format_modules, get_format
from django.utils import six
def set_language(request): def set_language(request):
""" """
@ -52,7 +53,7 @@ def get_formats():
result[attr] = get_format(attr) result[attr] = get_format(attr)
src = [] src = []
for k, v in result.items(): for k, v in result.items():
if isinstance(v, (basestring, int)): if isinstance(v, (six.string_types, int)):
src.append("formats['%s'] = '%s';\n" % (javascript_quote(k), javascript_quote(smart_unicode(v)))) src.append("formats['%s'] = '%s';\n" % (javascript_quote(k), javascript_quote(smart_unicode(v))))
elif isinstance(v, (tuple, list)): elif isinstance(v, (tuple, list)):
v = [javascript_quote(smart_unicode(value)) for value in v] v = [javascript_quote(smart_unicode(value)) for value in v]
@ -184,7 +185,7 @@ def javascript_catalog(request, domain='djangojs', packages=None):
activate(request.GET['language']) activate(request.GET['language'])
if packages is None: if packages is None:
packages = ['django.conf'] packages = ['django.conf']
if isinstance(packages, basestring): if isinstance(packages, six.string_types):
packages = packages.split('+') packages = packages.split('+')
packages = [p for p in packages if p == 'django.conf' or p in settings.INSTALLED_APPS] packages = [p for p in packages if p == 'django.conf' or p in settings.INSTALLED_APPS]
default_locale = to_locale(settings.LANGUAGE_CODE) default_locale = to_locale(settings.LANGUAGE_CODE)
@ -258,7 +259,7 @@ def javascript_catalog(request, domain='djangojs', packages=None):
for k, v in t.items(): for k, v in t.items():
if k == '': if k == '':
continue continue
if isinstance(k, basestring): if isinstance(k, six.string_types):
csrc.append("catalog['%s'] = '%s';\n" % (javascript_quote(k), javascript_quote(v))) csrc.append("catalog['%s'] = '%s';\n" % (javascript_quote(k), javascript_quote(v)))
elif isinstance(k, tuple): elif isinstance(k, tuple):
if k[0] not in pdict: if k[0] not in pdict:

View File

@ -4,6 +4,7 @@ import json
from django.db import models from django.db import models
from django.utils.encoding import force_unicode from django.utils.encoding import force_unicode
from django.utils import six
class Small(object): class Small(object):
@ -66,7 +67,7 @@ class JSONField(models.TextField):
if not value: if not value:
return None return None
if isinstance(value, basestring): if isinstance(value, six.string_types):
value = json.loads(value) value = json.loads(value)
return value return value

View File

@ -10,6 +10,7 @@ from django.conf import settings
from django.core import serializers from django.core import serializers
from django.db import transaction, connection from django.db import transaction, connection
from django.test import TestCase, TransactionTestCase, Approximate from django.test import TestCase, TransactionTestCase, Approximate
from django.utils import six
from django.utils import unittest from django.utils import unittest
from .models import (Category, Author, Article, AuthorProfile, Actor, Movie, from .models import (Category, Author, Article, AuthorProfile, Actor, Movie,
@ -461,7 +462,7 @@ else:
# yaml.safe_load will return non-string objects for some # yaml.safe_load will return non-string objects for some
# of the fields we are interested in, this ensures that # of the fields we are interested in, this ensures that
# everything comes back as a string # everything comes back as a string
if isinstance(field_value, basestring): if isinstance(field_value, six.string_types):
ret_list.append(field_value) ret_list.append(field_value)
else: else:
ret_list.append(str(field_value)) ret_list.append(str(field_value))

View File

@ -35,10 +35,11 @@ from decimal import Decimal
from django.core.files.uploadedfile import SimpleUploadedFile from django.core.files.uploadedfile import SimpleUploadedFile
from django.forms import * from django.forms import *
from django.test import SimpleTestCase from django.test import SimpleTestCase
from django.utils import six
def fix_os_paths(x): def fix_os_paths(x):
if isinstance(x, basestring): if isinstance(x, six.string_types):
return x.replace('\\', '/') return x.replace('\\', '/')
elif isinstance(x, tuple): elif isinstance(x, tuple):
return tuple(fix_os_paths(list(x))) return tuple(fix_os_paths(list(x)))

View File

@ -2,13 +2,15 @@ import os
import re import re
from subprocess import Popen, PIPE from subprocess import Popen, PIPE
from django.utils import six
can_run_extraction_tests = False can_run_extraction_tests = False
can_run_compilation_tests = False can_run_compilation_tests = False
def find_command(cmd, path=None, pathext=None): def find_command(cmd, path=None, pathext=None):
if path is None: if path is None:
path = os.environ.get('PATH', []).split(os.pathsep) path = os.environ.get('PATH', []).split(os.pathsep)
if isinstance(path, basestring): if isinstance(path, six.string_types):
path = [path] path = [path]
# check if there are funny path extensions for executables, e.g. Windows # check if there are funny path extensions for executables, e.g. Windows
if pathext is None: if pathext is None:

View File

@ -20,6 +20,7 @@ from django.test.utils import override_settings
from django.utils.encoding import smart_unicode from django.utils.encoding import smart_unicode
from django.utils.functional import empty from django.utils.functional import empty
from django.utils._os import rmtree_errorhandler from django.utils._os import rmtree_errorhandler
from django.utils import six
from django.contrib.staticfiles import finders, storage from django.contrib.staticfiles import finders, storage
@ -83,7 +84,7 @@ class BaseStaticFilesTestCase(object):
self.assertRaises(IOError, self._get_file, filepath) self.assertRaises(IOError, self._get_file, filepath)
def render_template(self, template, **kwargs): def render_template(self, template, **kwargs):
if isinstance(template, basestring): if isinstance(template, six.string_types):
template = loader.get_template_from_string(template) template = loader.get_template_from_string(template)
return template.render(Context(kwargs)).strip() return template.render(Context(kwargs)).strip()