mirror of
https://github.com/django/django.git
synced 2025-01-27 02:29:55 +00:00
[py3] Switched to Python 3-compatible imports.
xrange/range will be dealt with in a separate commit due to the huge number of changes.
This commit is contained in:
parent
0d914d08a0
commit
ca07fda2ef
@ -1,8 +1,8 @@
|
||||
from django.test import TestCase
|
||||
from django.utils.unittest import skipUnless
|
||||
from django.contrib.auth.models import User, AnonymousUser
|
||||
from django.core.management import call_command
|
||||
from StringIO import StringIO
|
||||
from django.test import TestCase
|
||||
from django.utils.six import StringIO
|
||||
from django.utils.unittest import skipUnless
|
||||
|
||||
try:
|
||||
import crypt as crypt_module
|
||||
|
@ -1,11 +1,10 @@
|
||||
from __future__ import unicode_literals
|
||||
|
||||
from StringIO import StringIO
|
||||
|
||||
from django.contrib.auth import models, management
|
||||
from django.contrib.auth.management.commands import changepassword
|
||||
from django.core.management.base import CommandError
|
||||
from django.test import TestCase
|
||||
from django.utils.six import StringIO
|
||||
|
||||
|
||||
class GetDefaultUsernameTestCase(TestCase):
|
||||
|
@ -1,4 +1,4 @@
|
||||
from future_builtins import zip
|
||||
from django.utils.six.moves import zip
|
||||
|
||||
from django.db.backends.util import truncate_name, typecast_timestamp
|
||||
from django.db.models.sql import compiler
|
||||
|
@ -1,6 +1,6 @@
|
||||
from binascii import b2a_hex
|
||||
try:
|
||||
import cPickle as pickle
|
||||
from django.utils.six.moves import cPickle as pickle
|
||||
except ImportError:
|
||||
import pickle
|
||||
|
||||
|
@ -952,7 +952,8 @@ class GEOSTest(unittest.TestCase, TestDataMixin):
|
||||
def test_pickle(self):
|
||||
"Testing pickling and unpickling support."
|
||||
# Using both pickle and cPickle -- just 'cause.
|
||||
import pickle, cPickle
|
||||
from django.utils.six.moves import cPickle
|
||||
import pickle
|
||||
|
||||
# Creating a list of test geometries for pickling,
|
||||
# and setting the SRID on some of them.
|
||||
|
@ -5,7 +5,7 @@ models for GeoDjango and/or mapping dictionaries for use with the
|
||||
|
||||
Author: Travis Pinney, Dane Springmeyer, & Justin Bronn
|
||||
"""
|
||||
from future_builtins import zip
|
||||
from django.utils.six.moves import zip
|
||||
# Requires GDAL to use.
|
||||
from django.contrib.gis.gdal import DataSource
|
||||
from django.contrib.gis.gdal.field import OFTDate, OFTDateTime, OFTInteger, OFTReal, OFTString, OFTTime
|
||||
|
@ -2,7 +2,7 @@ import base64
|
||||
import time
|
||||
from datetime import datetime, timedelta
|
||||
try:
|
||||
import cPickle as pickle
|
||||
from django.utils.six.moves import cPickle as pickle
|
||||
except ImportError:
|
||||
import pickle
|
||||
|
||||
|
@ -1,5 +1,5 @@
|
||||
try:
|
||||
import cPickle as pickle
|
||||
from django.utils.six.moves import cPickle as pickle
|
||||
except ImportError:
|
||||
import pickle
|
||||
|
||||
|
2
django/core/cache/backends/db.py
vendored
2
django/core/cache/backends/db.py
vendored
@ -4,7 +4,7 @@ import time
|
||||
from datetime import datetime
|
||||
|
||||
try:
|
||||
import cPickle as pickle
|
||||
from django.utils.six.moves import cPickle as pickle
|
||||
except ImportError:
|
||||
import pickle
|
||||
|
||||
|
2
django/core/cache/backends/filebased.py
vendored
2
django/core/cache/backends/filebased.py
vendored
@ -5,7 +5,7 @@ import os
|
||||
import shutil
|
||||
import time
|
||||
try:
|
||||
import cPickle as pickle
|
||||
from django.utils.six.moves import cPickle as pickle
|
||||
except ImportError:
|
||||
import pickle
|
||||
|
||||
|
2
django/core/cache/backends/locmem.py
vendored
2
django/core/cache/backends/locmem.py
vendored
@ -2,7 +2,7 @@
|
||||
|
||||
import time
|
||||
try:
|
||||
import cPickle as pickle
|
||||
from django.utils.six.moves import cPickle as pickle
|
||||
except ImportError:
|
||||
import pickle
|
||||
|
||||
|
@ -16,7 +16,7 @@ try:
|
||||
except ImportError: # Python 2
|
||||
from urllib import unquote
|
||||
from urlparse import urljoin
|
||||
from SocketServer import ThreadingMixIn
|
||||
from django.utils.six.moves import socketserver
|
||||
from wsgiref import simple_server
|
||||
from wsgiref.util import FileWrapper # for backwards compatibility
|
||||
|
||||
@ -200,7 +200,7 @@ class WSGIRequestHandler(simple_server.WSGIRequestHandler, object):
|
||||
def run(addr, port, wsgi_handler, ipv6=False, threading=False):
|
||||
server_address = (addr, port)
|
||||
if threading:
|
||||
httpd_cls = type('WSGIServer', (ThreadingMixIn, WSGIServer), {})
|
||||
httpd_cls = type('WSGIServer', (socketserver.ThreadingMixIn, WSGIServer), {})
|
||||
else:
|
||||
httpd_cls = WSGIServer
|
||||
httpd = httpd_cls(server_address, WSGIRequestHandler, ipv6=ipv6)
|
||||
|
@ -3,7 +3,7 @@ from django.db.utils import DatabaseError
|
||||
try:
|
||||
import thread
|
||||
except ImportError:
|
||||
import dummy_thread as thread
|
||||
from django.utils.six.moves import _dummy_thread as thread
|
||||
from contextlib import contextmanager
|
||||
|
||||
from django.conf import settings
|
||||
|
@ -3,7 +3,7 @@ from __future__ import unicode_literals
|
||||
import copy
|
||||
import sys
|
||||
from functools import update_wrapper
|
||||
from future_builtins import zip
|
||||
from django.utils.six.moves import zip
|
||||
|
||||
import django.db.models.manager # Imported to register signal handler.
|
||||
from django.conf import settings
|
||||
|
@ -1,4 +1,4 @@
|
||||
from future_builtins import zip
|
||||
from django.utils.six.moves import zip
|
||||
|
||||
from django.core.exceptions import FieldError
|
||||
from django.db import transaction
|
||||
|
@ -16,23 +16,23 @@ except ImportError: # Python 2
|
||||
from urllib import quote, urlencode
|
||||
from urlparse import parse_qsl, urljoin
|
||||
|
||||
import Cookie
|
||||
from django.utils.six.moves import http_cookies
|
||||
# Some versions of Python 2.7 and later won't need this encoding bug fix:
|
||||
_cookie_encodes_correctly = Cookie.SimpleCookie().value_encode(';') == (';', '"\\073"')
|
||||
_cookie_encodes_correctly = http_cookies.SimpleCookie().value_encode(';') == (';', '"\\073"')
|
||||
# See ticket #13007, http://bugs.python.org/issue2193 and http://trac.edgewall.org/ticket/2256
|
||||
_tc = Cookie.SimpleCookie()
|
||||
_tc = http_cookies.SimpleCookie()
|
||||
try:
|
||||
_tc.load(b'foo:bar=1')
|
||||
_cookie_allows_colon_in_names = True
|
||||
except Cookie.CookieError:
|
||||
except http_cookies.CookieError:
|
||||
_cookie_allows_colon_in_names = False
|
||||
|
||||
if _cookie_encodes_correctly and _cookie_allows_colon_in_names:
|
||||
SimpleCookie = Cookie.SimpleCookie
|
||||
SimpleCookie = http_cookies.SimpleCookie
|
||||
else:
|
||||
Morsel = Cookie.Morsel
|
||||
Morsel = http_cookies.Morsel
|
||||
|
||||
class SimpleCookie(Cookie.SimpleCookie):
|
||||
class SimpleCookie(http_cookies.SimpleCookie):
|
||||
if not _cookie_encodes_correctly:
|
||||
def value_encode(self, val):
|
||||
# Some browsers do not support quoted-string from RFC 2109,
|
||||
@ -73,9 +73,9 @@ else:
|
||||
M = self.get(key, Morsel())
|
||||
M.set(key, real_value, coded_value)
|
||||
dict.__setitem__(self, key, M)
|
||||
except Cookie.CookieError:
|
||||
except http_cookies.CookieError:
|
||||
self.bad_cookies.add(key)
|
||||
dict.__setitem__(self, key, Cookie.Morsel())
|
||||
dict.__setitem__(self, key, http_cookies.Morsel())
|
||||
|
||||
|
||||
from django.conf import settings
|
||||
@ -495,11 +495,11 @@ class QueryDict(MultiValueDict):
|
||||
def parse_cookie(cookie):
|
||||
if cookie == '':
|
||||
return {}
|
||||
if not isinstance(cookie, Cookie.BaseCookie):
|
||||
if not isinstance(cookie, http_cookies.BaseCookie):
|
||||
try:
|
||||
c = SimpleCookie()
|
||||
c.load(cookie)
|
||||
except Cookie.CookieError:
|
||||
except http_cookies.CookieError:
|
||||
# Invalid cookie
|
||||
return {}
|
||||
else:
|
||||
|
@ -103,9 +103,9 @@ import __future__
|
||||
import sys, traceback, inspect, linecache, os, re
|
||||
import unittest, difflib, pdb, tempfile
|
||||
import warnings
|
||||
from StringIO import StringIO
|
||||
|
||||
from django.utils import six
|
||||
from django.utils.six import StringIO
|
||||
|
||||
if sys.platform.startswith('java'):
|
||||
# On Jython, isclass() reports some modules as classes. Patch it.
|
||||
|
@ -5,9 +5,8 @@ Comparing two html documents.
|
||||
from __future__ import unicode_literals
|
||||
|
||||
import re
|
||||
from HTMLParser import HTMLParseError
|
||||
from django.utils.encoding import force_unicode
|
||||
from django.utils.html_parser import HTMLParser
|
||||
from django.utils.html_parser import HTMLParser, HTMLParseError
|
||||
from django.utils import six
|
||||
|
||||
|
||||
|
@ -33,7 +33,7 @@ import os, sys, time, signal
|
||||
try:
|
||||
import thread
|
||||
except ImportError:
|
||||
import dummy_thread as thread
|
||||
from django.utils.six.moves import _dummy_thread as thread
|
||||
|
||||
# This import does nothing, but it's necessary to avoid some race conditions
|
||||
# in the threading module. See http://code.djangoproject.com/ticket/2330 .
|
||||
|
@ -1,26 +1,28 @@
|
||||
import HTMLParser as _HTMLParser
|
||||
from django.utils.six.moves import html_parser as _html_parser
|
||||
import re
|
||||
|
||||
tagfind = re.compile('([a-zA-Z][-.a-zA-Z0-9:_]*)(?:\s|/(?!>))*')
|
||||
|
||||
class HTMLParser(_HTMLParser.HTMLParser):
|
||||
HTMLParseError = _html_parser.HTMLParseError
|
||||
|
||||
class HTMLParser(_html_parser.HTMLParser):
|
||||
"""
|
||||
Patched version of stdlib's HTMLParser with patch from:
|
||||
http://bugs.python.org/issue670664
|
||||
"""
|
||||
def __init__(self):
|
||||
_HTMLParser.HTMLParser.__init__(self)
|
||||
_html_parser.HTMLParser.__init__(self)
|
||||
self.cdata_tag = None
|
||||
|
||||
def set_cdata_mode(self, tag):
|
||||
try:
|
||||
self.interesting = _HTMLParser.interesting_cdata
|
||||
self.interesting = _html_parser.interesting_cdata
|
||||
except AttributeError:
|
||||
self.interesting = re.compile(r'</\s*%s\s*>' % tag.lower(), re.I)
|
||||
self.cdata_tag = tag.lower()
|
||||
|
||||
def clear_cdata_mode(self):
|
||||
self.interesting = _HTMLParser.interesting_normal
|
||||
self.interesting = _html_parser.interesting_normal
|
||||
self.cdata_tag = None
|
||||
|
||||
# Internal -- handle starttag, return end or -1 if not terminated
|
||||
@ -40,7 +42,7 @@ class HTMLParser(_HTMLParser.HTMLParser):
|
||||
self.lasttag = tag = match.group(1).lower()
|
||||
|
||||
while k < endpos:
|
||||
m = _HTMLParser.attrfind.match(rawdata, k)
|
||||
m = _html_parser.attrfind.match(rawdata, k)
|
||||
if not m:
|
||||
break
|
||||
attrname, rest, attrvalue = m.group(1, 2, 3)
|
||||
@ -78,11 +80,11 @@ class HTMLParser(_HTMLParser.HTMLParser):
|
||||
def parse_endtag(self, i):
|
||||
rawdata = self.rawdata
|
||||
assert rawdata[i:i + 2] == "</", "unexpected call to parse_endtag"
|
||||
match = _HTMLParser.endendtag.search(rawdata, i + 1) # >
|
||||
match = _html_parser.endendtag.search(rawdata, i + 1) # >
|
||||
if not match:
|
||||
return -1
|
||||
j = match.end()
|
||||
match = _HTMLParser.endtagfind.match(rawdata, i) # </ + tag + >
|
||||
match = _html_parser.endtagfind.match(rawdata, i) # </ + tag + >
|
||||
if not match:
|
||||
if self.cdata_tag is not None: # *** add ***
|
||||
self.handle_data(rawdata[i:j]) # *** add ***
|
||||
|
@ -4,7 +4,7 @@ Where possible, we try to use the system-native version and only fall back to
|
||||
these implementations if necessary.
|
||||
"""
|
||||
|
||||
import __builtin__
|
||||
from django.utils.six.moves import builtins
|
||||
import itertools
|
||||
import warnings
|
||||
|
||||
@ -25,9 +25,9 @@ def product(*args, **kwds):
|
||||
def all(iterable):
|
||||
warnings.warn("django.utils.itercompat.all is deprecated; use the native version instead",
|
||||
DeprecationWarning)
|
||||
return __builtin__.all(iterable)
|
||||
return builtins.all(iterable)
|
||||
|
||||
def any(iterable):
|
||||
warnings.warn("django.utils.itercompat.any is deprecated; use the native version instead",
|
||||
DeprecationWarning)
|
||||
return __builtin__.any(iterable)
|
||||
return builtins.any(iterable)
|
||||
|
@ -351,3 +351,8 @@ _add_doc(reraise, """Reraise an exception.""")
|
||||
def with_metaclass(meta, base=object):
|
||||
"""Create a base class with a metaclass."""
|
||||
return meta("NewBase", (base,), {})
|
||||
|
||||
|
||||
### Additional customizations for Django ###
|
||||
|
||||
add_move(MovedModule("_dummy_thread", "dummy_thread"))
|
||||
|
@ -4,7 +4,7 @@ import re
|
||||
import unicodedata
|
||||
import warnings
|
||||
from gzip import GzipFile
|
||||
from htmlentitydefs import name2codepoint
|
||||
from django.utils.six.moves import html_entities
|
||||
from io import BytesIO
|
||||
|
||||
from django.utils.encoding import force_unicode
|
||||
@ -349,7 +349,7 @@ def _replace_entity(match):
|
||||
return match.group(0)
|
||||
else:
|
||||
try:
|
||||
return unichr(name2codepoint[text])
|
||||
return unichr(html_entities.name2codepoint[text])
|
||||
except (ValueError, KeyError):
|
||||
return match.group(0)
|
||||
|
||||
|
@ -6,11 +6,11 @@ import os
|
||||
import re
|
||||
import sys
|
||||
import gettext as gettext_module
|
||||
from io import StringIO
|
||||
from threading import local
|
||||
|
||||
from django.utils.importlib import import_module
|
||||
from django.utils.safestring import mark_safe, SafeData
|
||||
from django.utils.six import StringIO
|
||||
|
||||
|
||||
# Translations are cached in a dictionary for every language+app tuple.
|
||||
|
Loading…
x
Reference in New Issue
Block a user