Removed compatibility with Python 3.2.
This commit is contained in:
parent
4e65f195e1
commit
fed25f1105
|
@ -104,12 +104,7 @@ def sanitize_address(addr, encoding):
|
||||||
if isinstance(addr, six.string_types):
|
if isinstance(addr, six.string_types):
|
||||||
addr = parseaddr(force_text(addr))
|
addr = parseaddr(force_text(addr))
|
||||||
nm, addr = addr
|
nm, addr = addr
|
||||||
# This try-except clause is needed on Python 3 < 3.2.4
|
nm = Header(nm, encoding).encode()
|
||||||
# http://bugs.python.org/issue14291
|
|
||||||
try:
|
|
||||||
nm = Header(nm, encoding).encode()
|
|
||||||
except UnicodeEncodeError:
|
|
||||||
nm = Header(nm, 'utf-8').encode()
|
|
||||||
try:
|
try:
|
||||||
addr.encode('ascii')
|
addr.encode('ascii')
|
||||||
except UnicodeEncodeError: # IDN
|
except UnicodeEncodeError: # IDN
|
||||||
|
|
|
@ -25,8 +25,6 @@ def find_commands(management_dir):
|
||||||
Returns an empty list if no commands are defined.
|
Returns an empty list if no commands are defined.
|
||||||
"""
|
"""
|
||||||
command_dir = os.path.join(management_dir, 'commands')
|
command_dir = os.path.join(management_dir, 'commands')
|
||||||
# Workaround for a Python 3.2 bug with pkgutil.iter_modules
|
|
||||||
sys.path_importer_cache.pop(command_dir, None)
|
|
||||||
return [name for _, name, is_pkg in pkgutil.iter_modules([command_dir])
|
return [name for _, name, is_pkg in pkgutil.iter_modules([command_dir])
|
||||||
if not is_pkg and not name.startswith('_')]
|
if not is_pkg and not name.startswith('_')]
|
||||||
|
|
||||||
|
|
|
@ -3,7 +3,6 @@
|
||||||
from __future__ import unicode_literals
|
from __future__ import unicode_literals
|
||||||
|
|
||||||
import re
|
import re
|
||||||
import sys
|
|
||||||
import warnings
|
import warnings
|
||||||
|
|
||||||
from django.utils.deprecation import RemovedInDjango20Warning
|
from django.utils.deprecation import RemovedInDjango20Warning
|
||||||
|
@ -135,12 +134,7 @@ linebreaks = allow_lazy(linebreaks, six.text_type)
|
||||||
|
|
||||||
class MLStripper(HTMLParser):
|
class MLStripper(HTMLParser):
|
||||||
def __init__(self):
|
def __init__(self):
|
||||||
# The strict parameter was added in Python 3.2 with a default of True.
|
HTMLParser.__init__(self)
|
||||||
# The default changed to False in Python 3.3 and was deprecated.
|
|
||||||
if sys.version_info[:2] == (3, 2):
|
|
||||||
HTMLParser.__init__(self, strict=False)
|
|
||||||
else:
|
|
||||||
HTMLParser.__init__(self)
|
|
||||||
self.reset()
|
self.reset()
|
||||||
self.fed = []
|
self.fed = []
|
||||||
|
|
||||||
|
@ -168,9 +162,7 @@ def _strip_once(value):
|
||||||
return value
|
return value
|
||||||
try:
|
try:
|
||||||
s.close()
|
s.close()
|
||||||
except (HTMLParseError, UnboundLocalError):
|
except HTMLParseError:
|
||||||
# UnboundLocalError because of http://bugs.python.org/issue17802
|
|
||||||
# on Python 3.2, triggered by strict=False mode of HTMLParser
|
|
||||||
return s.get_data() + s.rawdata
|
return s.get_data() + s.rawdata
|
||||||
else:
|
else:
|
||||||
return s.get_data()
|
return s.get_data()
|
||||||
|
|
|
@ -4,10 +4,7 @@ import sys
|
||||||
|
|
||||||
current_version = sys.version_info
|
current_version = sys.version_info
|
||||||
|
|
||||||
use_workaround = (
|
use_workaround = current_version < (2, 7, 3)
|
||||||
(current_version < (2, 7, 3)) or
|
|
||||||
(current_version >= (3, 0) and current_version < (3, 2, 3))
|
|
||||||
)
|
|
||||||
|
|
||||||
try:
|
try:
|
||||||
HTMLParseError = _html_parser.HTMLParseError
|
HTMLParseError = _html_parser.HTMLParseError
|
||||||
|
|
|
@ -16,7 +16,7 @@ How do I get started?
|
||||||
What are Django's prerequisites?
|
What are Django's prerequisites?
|
||||||
--------------------------------
|
--------------------------------
|
||||||
|
|
||||||
Django requires Python, specifically Python 2.7 or 3.2 and above. Other Python
|
Django requires Python, specifically Python 2.7 or 3.3 and above. Other Python
|
||||||
libraries may be required for some uses, but you'll receive an error about it
|
libraries may be required for some uses, but you'll receive an error about it
|
||||||
as they're needed.
|
as they're needed.
|
||||||
|
|
||||||
|
|
|
@ -9,9 +9,9 @@ that'll work while you walk through the introduction.
|
||||||
Install Python
|
Install Python
|
||||||
--------------
|
--------------
|
||||||
|
|
||||||
Being a Python Web framework, Django requires Python. It works with Python 2.7,
|
Being a Python Web framework, Django requires Python. It works with Python 2.7
|
||||||
3.2, 3.3, or 3.4. All these versions of Python include a lightweight database
|
3.3+. All these versions of Python include a lightweight database called
|
||||||
called SQLite_ so you won't need to set up a database just yet.
|
SQLite_ so you won't need to set up a database just yet.
|
||||||
|
|
||||||
.. _sqlite: http://sqlite.org/
|
.. _sqlite: http://sqlite.org/
|
||||||
|
|
||||||
|
|
|
@ -22,7 +22,7 @@ tell Django is installed and which version by running the following command:
|
||||||
If Django is installed, you should see the version of your installation. If it
|
If Django is installed, you should see the version of your installation. If it
|
||||||
isn't, you'll get an error telling "No module named django".
|
isn't, you'll get an error telling "No module named django".
|
||||||
|
|
||||||
This tutorial is written for Django |version| and Python 3.2 or later. If the
|
This tutorial is written for Django |version| and Python 3.3 or later. If the
|
||||||
Django version doesn't match, you can refer to the tutorial for your version
|
Django version doesn't match, you can refer to the tutorial for your version
|
||||||
of Django by using the version switcher at the bottom right corner of this
|
of Django by using the version switcher at the bottom right corner of this
|
||||||
page, or update Django to the newest version. If you are still using Python
|
page, or update Django to the newest version. If you are still using Python
|
||||||
|
|
|
@ -7,8 +7,8 @@ This document will get you up and running with Django.
|
||||||
Install Python
|
Install Python
|
||||||
==============
|
==============
|
||||||
|
|
||||||
Being a Python Web framework, Django requires Python. It works with Python 2.7,
|
Being a Python Web framework, Django requires Python. It works with Python 2.7
|
||||||
3.2 or 3.3.
|
or 3.3+.
|
||||||
|
|
||||||
Get the latest version of Python at https://www.python.org/download/ or with
|
Get the latest version of Python at https://www.python.org/download/ or with
|
||||||
your operating system's package manager.
|
your operating system's package manager.
|
||||||
|
|
1
setup.py
1
setup.py
|
@ -62,7 +62,6 @@ setup(
|
||||||
'Programming Language :: Python :: 2',
|
'Programming Language :: Python :: 2',
|
||||||
'Programming Language :: Python :: 2.7',
|
'Programming Language :: Python :: 2.7',
|
||||||
'Programming Language :: Python :: 3',
|
'Programming Language :: Python :: 3',
|
||||||
'Programming Language :: Python :: 3.2',
|
|
||||||
'Programming Language :: Python :: 3.3',
|
'Programming Language :: Python :: 3.3',
|
||||||
'Programming Language :: Python :: 3.4',
|
'Programming Language :: Python :: 3.4',
|
||||||
'Topic :: Internet :: WWW/HTTP',
|
'Topic :: Internet :: WWW/HTTP',
|
||||||
|
|
|
@ -1,8 +1,6 @@
|
||||||
bcrypt
|
bcrypt
|
||||||
docutils
|
docutils
|
||||||
jinja2
|
jinja2
|
||||||
# move to py2.txt when dropping Python 3.2
|
|
||||||
mock
|
|
||||||
numpy
|
numpy
|
||||||
Pillow
|
Pillow
|
||||||
PyYAML
|
PyYAML
|
||||||
|
|
|
@ -1,2 +1,3 @@
|
||||||
-r base.txt
|
-r base.txt
|
||||||
python-memcached
|
python-memcached
|
||||||
|
mock
|
||||||
|
|
|
@ -2,22 +2,15 @@
|
||||||
# silence an ImportWarning warning on Python 2.
|
# silence an ImportWarning warning on Python 2.
|
||||||
from __future__ import absolute_import
|
from __future__ import absolute_import
|
||||||
|
|
||||||
import sys
|
|
||||||
|
|
||||||
from unittest import skipIf
|
from unittest import skipIf
|
||||||
|
|
||||||
# Jinja2 doesn't run on Python 3.2 because it uses u-prefixed unicode strings.
|
try:
|
||||||
if sys.version_info[:2] == (2, 7) or sys.version_info[:2] >= (3, 3):
|
import jinja2
|
||||||
try:
|
except ImportError:
|
||||||
import jinja2
|
|
||||||
except ImportError:
|
|
||||||
jinja2 = None
|
|
||||||
Jinja2 = None
|
|
||||||
else:
|
|
||||||
from django.template.backends.jinja2 import Jinja2
|
|
||||||
else:
|
|
||||||
jinja2 = None
|
jinja2 = None
|
||||||
Jinja2 = None
|
Jinja2 = None
|
||||||
|
else:
|
||||||
|
from django.template.backends.jinja2 import Jinja2
|
||||||
|
|
||||||
from .test_dummy import TemplateStringsTests
|
from .test_dummy import TemplateStringsTests
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue