Fixed #16988 - Clean up the deprecation timeline for language consistency. Thanks ptone.
git-svn-id: http://code.djangoproject.com/svn/django/trunk@16932 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
parent
b763412aa4
commit
9279dce1fe
|
@ -2,37 +2,42 @@
|
||||||
Django Deprecation Timeline
|
Django Deprecation Timeline
|
||||||
===========================
|
===========================
|
||||||
|
|
||||||
This document outlines when various pieces of Django will be removed, following
|
This document outlines when various pieces of Django will be removed or altered
|
||||||
their deprecation, as per the :ref:`deprecation policy
|
in a backward incompatible way, following their deprecation, as per the
|
||||||
<internal-release-deprecation-policy>`.
|
:ref:`deprecation policy <internal-release-deprecation-policy>`. More details
|
||||||
|
about each item can often be found in the release notes of two versions prior.
|
||||||
|
|
||||||
1.3
|
1.3
|
||||||
---
|
---
|
||||||
|
|
||||||
* ``AdminSite.root()``. This release will remove the old method for
|
See the :doc:`Django 1.1 release notes</releases/1.1>` for more details on
|
||||||
hooking up admin URLs. This has been deprecated since the 1.1
|
these changes.
|
||||||
release.
|
|
||||||
|
* ``AdminSite.root()``. This method of hooking up the admin URLs will be
|
||||||
|
removed in favor of including ``admin.site.urls``.
|
||||||
|
|
||||||
* Authentication backends need to define the boolean attributes
|
* Authentication backends need to define the boolean attributes
|
||||||
``supports_object_permissions`` and ``supports_anonymous_user``.
|
``supports_object_permissions`` and ``supports_anonymous_user`` until
|
||||||
The old backend style is deprecated since the 1.2 release.
|
version 1.4, at which point it will be assumed that all backends will
|
||||||
|
support these options.
|
||||||
* The :mod:`django.contrib.gis.db.backend` module, including the
|
|
||||||
``SpatialBackend`` interface, is deprecated since the 1.2 release.
|
|
||||||
|
|
||||||
1.4
|
1.4
|
||||||
---
|
---
|
||||||
|
|
||||||
* ``CsrfResponseMiddleware``. This has been deprecated since the 1.2
|
See the :doc:`Django 1.2 release notes</releases/1.2>` for more details on
|
||||||
release, in favor of the template tag method for inserting the CSRF
|
these changes.
|
||||||
token. ``CsrfMiddleware``, which combines ``CsrfResponseMiddleware``
|
|
||||||
and ``CsrfViewMiddleware``, is also deprecated.
|
* ``CsrfResponseMiddleware`` and ``CsrfMiddleware`` will be removed. Use
|
||||||
|
the {% csrf_token %} template tag inside forms to enable CSRF
|
||||||
|
protection. ``CsrfViewMiddleware`` remains and is enabled by default.
|
||||||
|
|
||||||
* The old imports for CSRF functionality (``django.contrib.csrf.*``),
|
* The old imports for CSRF functionality (``django.contrib.csrf.*``),
|
||||||
which moved to core in 1.2, will be removed.
|
which moved to core in 1.2, will be removed.
|
||||||
|
|
||||||
* ``SMTPConnection``. The 1.2 release deprecated the ``SMTPConnection``
|
* The :mod:`django.contrib.gis.db.backend` module will be removed in favor
|
||||||
class in favor of a generic E-mail backend API.
|
of the specific backends.
|
||||||
|
|
||||||
|
* ``SMTPConnection`` will be removed in favor of a generic E-mail backend API.
|
||||||
|
|
||||||
* The many to many SQL generation functions on the database backends
|
* The many to many SQL generation functions on the database backends
|
||||||
will be removed.
|
will be removed.
|
||||||
|
@ -45,46 +50,40 @@ their deprecation, as per the :ref:`deprecation policy
|
||||||
removed.
|
removed.
|
||||||
|
|
||||||
* The ``get_db_prep_save``, ``get_db_prep_value`` and
|
* The ``get_db_prep_save``, ``get_db_prep_value`` and
|
||||||
``get_db_prep_lookup`` methods on Field were modified in 1.2
|
``get_db_prep_lookup`` methods will have to support multiple databases.
|
||||||
to support multiple databases. In 1.4, the support functions
|
|
||||||
that allow methods with the old prototype to continue
|
|
||||||
working will be removed.
|
|
||||||
|
|
||||||
* The ``Message`` model (in ``django.contrib.auth``), its related
|
* The ``Message`` model (in ``django.contrib.auth``), its related
|
||||||
manager in the ``User`` model (``user.message_set``), and the
|
manager in the ``User`` model (``user.message_set``), and the
|
||||||
associated methods (``user.message_set.create()`` and
|
associated methods (``user.message_set.create()`` and
|
||||||
``user.get_and_delete_messages()``), which have
|
``user.get_and_delete_messages()``), will be removed. The
|
||||||
been deprecated since the 1.2 release, will be removed. The
|
|
||||||
:doc:`messages framework </ref/contrib/messages>` should be used
|
:doc:`messages framework </ref/contrib/messages>` should be used
|
||||||
instead. The related ``messages`` variable returned by the
|
instead. The related ``messages`` variable returned by the
|
||||||
auth context processor will also be removed. Note that this
|
auth context processor will also be removed. Note that this
|
||||||
means that the admin application depends on the messages
|
means that the admin application will depend on the messages
|
||||||
context processor.
|
context processor.
|
||||||
|
|
||||||
* Authentication backends need to support the ``obj`` parameter for
|
* Authentication backends will need to support the ``obj`` parameter for
|
||||||
permission checking. The ``supports_object_permissions`` variable
|
permission checking. The ``supports_object_permissions`` attribute
|
||||||
is not checked any longer and can be removed.
|
will no longer be checked and can be removed from custom backends.
|
||||||
|
|
||||||
* Authentication backends need to support the ``AnonymousUser``
|
* Authentication backends will need to support the ``AnonymousUser`` class
|
||||||
being passed to all methods dealing with permissions.
|
being passed to all methods dealing with permissions. The
|
||||||
The ``supports_anonymous_user`` variable is not checked any
|
``supports_anonymous_user`` variable will no longer be checked and can be
|
||||||
longer and can be removed.
|
removed from custom backends.
|
||||||
|
|
||||||
* The ability to specify a callable template loader rather than a
|
* The ability to specify a callable template loader rather than a
|
||||||
``Loader`` class will be removed, as will the ``load_template_source``
|
``Loader`` class will be removed, as will the ``load_template_source``
|
||||||
functions that are included with the built in template loaders for
|
functions that are included with the built in template loaders for
|
||||||
backwards compatibility. These have been deprecated since the 1.2
|
backwards compatibility.
|
||||||
release.
|
|
||||||
|
|
||||||
* ``django.utils.translation.get_date_formats()`` and
|
* ``django.utils.translation.get_date_formats()`` and
|
||||||
``django.utils.translation.get_partial_date_formats()``. These
|
``django.utils.translation.get_partial_date_formats()``. These functions
|
||||||
functions are replaced by the new locale aware formatting; use
|
will be removed; use the locale-aware
|
||||||
``django.utils.formats.get_format()`` to get the appropriate
|
``django.utils.formats.get_format()`` to get the appropriate formats.
|
||||||
formats.
|
|
||||||
|
|
||||||
* In ``django.forms.fields``: ``DEFAULT_DATE_INPUT_FORMATS``,
|
* In ``django.forms.fields``, the constants: ``DEFAULT_DATE_INPUT_FORMATS``,
|
||||||
``DEFAULT_TIME_INPUT_FORMATS`` and
|
``DEFAULT_TIME_INPUT_FORMATS`` and
|
||||||
``DEFAULT_DATETIME_INPUT_FORMATS``. Use
|
``DEFAULT_DATETIME_INPUT_FORMATS`` will be removed. Use
|
||||||
``django.utils.formats.get_format()`` to get the appropriate
|
``django.utils.formats.get_format()`` to get the appropriate
|
||||||
formats.
|
formats.
|
||||||
|
|
||||||
|
@ -92,22 +91,22 @@ their deprecation, as per the :ref:`deprecation policy
|
||||||
along with the ``django.test.simple.run_tests()`` test runner.
|
along with the ``django.test.simple.run_tests()`` test runner.
|
||||||
|
|
||||||
* The ``views.feed()`` view and ``feeds.Feed`` class in
|
* The ``views.feed()`` view and ``feeds.Feed`` class in
|
||||||
``django.contrib.syndication`` have been deprecated since the 1.2
|
``django.contrib.syndication`` will be removed. The class-based view
|
||||||
release. The class-based view ``views.Feed`` should be used instead.
|
``views.Feed`` should be used instead.
|
||||||
|
|
||||||
* ``django.core.context_processors.auth``. This release will
|
* ``django.core.context_processors.auth``. This release will
|
||||||
remove the old method in favor of the new method in
|
remove the old method in favor of the new method in
|
||||||
``django.contrib.auth.context_processors.auth``. This has been
|
``django.contrib.auth.context_processors.auth``.
|
||||||
deprecated since the 1.2 release.
|
|
||||||
|
|
||||||
* The ``postgresql`` database backend has been deprecated in favor of
|
* The ``postgresql`` database backend will be removed, use the
|
||||||
the ``postgresql_psycopg2`` backend.
|
``postgresql_psycopg2`` backend instead.
|
||||||
|
|
||||||
* The ``no`` language code has been deprecated in favor of the ``nb``
|
* The ``no`` language code will be removed and has been replaced by the
|
||||||
language code.
|
``nb`` language code.
|
||||||
|
|
||||||
* Authentication backends need to define the boolean attribute
|
* Authentication backends will need to define the boolean attribute
|
||||||
``supports_inactive_user``.
|
``supports_inactive_user`` until version 1.5 when it will be assumed that
|
||||||
|
all backends will handle inactive users.
|
||||||
|
|
||||||
* ``django.db.models.fields.XMLField`` will be removed. This was
|
* ``django.db.models.fields.XMLField`` will be removed. This was
|
||||||
deprecated as part of the 1.3 release. An accelerated deprecation
|
deprecated as part of the 1.3 release. An accelerated deprecation
|
||||||
|
@ -119,50 +118,47 @@ their deprecation, as per the :ref:`deprecation policy
|
||||||
1.5
|
1.5
|
||||||
---
|
---
|
||||||
|
|
||||||
* The ``mod_python`` request handler has been deprecated since the 1.3
|
See the :doc:`Django 1.3 release notes</releases/1.3>` for more details on
|
||||||
release. The ``mod_wsgi`` handler should be used instead.
|
these changes.
|
||||||
|
|
||||||
|
* The ``mod_python`` request handler will be removed. The ``mod_wsgi``
|
||||||
|
handler should be used instead.
|
||||||
|
|
||||||
* The ``template`` attribute on :class:`~django.test.client.Response`
|
* The ``template`` attribute on :class:`~django.test.client.Response`
|
||||||
objects returned by the :ref:`test client <test-client>` has been
|
objects returned by the :ref:`test client <test-client>` will be removed.
|
||||||
deprecated since the 1.3 release. The
|
The :attr:`~django.test.client.Response.templates` attribute should be
|
||||||
:attr:`~django.test.client.Response.templates` attribute should be
|
|
||||||
used instead.
|
used instead.
|
||||||
|
|
||||||
* The features of the :class:`django.test.simple.DjangoTestRunner`
|
* The :class:`~django.test.simple.DjangoTestRunner` will be removed.
|
||||||
(including fail-fast and Ctrl-C test termination) can now be provided
|
Instead use a unittest-native class. The features of the
|
||||||
by the unittest-native :class:`TextTestRunner`. The
|
:class:`django.test.simple.DjangoTestRunner` (including fail-fast and
|
||||||
:class:`~django.test.simple.DjangoTestRunner` will be removed in
|
Ctrl-C test termination) can currently be provided by the unittest-native
|
||||||
favor of using the unittest-native class.
|
:class:`TextTestRunner`.
|
||||||
|
|
||||||
* The undocumented function
|
* The undocumented function
|
||||||
:func:`django.contrib.formtools.utils.security_hash`
|
:func:`django.contrib.formtools.utils.security_hash` will be removed,
|
||||||
is deprecated, in favor of :func:`django.contrib.formtools.utils.form_hmac`
|
instead use :func:`django.contrib.formtools.utils.form_hmac`
|
||||||
|
|
||||||
* The function-based generic views have been deprecated in
|
* The function-based generic view modules will be removed in favor of their
|
||||||
favor of their class-based cousins. The following modules
|
class-based equivalents, outlined :doc:`here
|
||||||
will be removed:
|
</topics/generic-views-migration>`:
|
||||||
|
|
||||||
* :mod:`django.views.generic.create_update`
|
* The :class:`~django.core.servers.basehttp.AdminMediaHandler` will be
|
||||||
* :mod:`django.views.generic.date_based`
|
removed. In its place use
|
||||||
* :mod:`django.views.generic.list_detail`
|
|
||||||
* :mod:`django.views.generic.simple`
|
|
||||||
|
|
||||||
* The :class:`~django.core.servers.basehttp.AdminMediaHandler` has
|
|
||||||
been deprecated in favor of the
|
|
||||||
:class:`~django.contrib.staticfiles.handlers.StaticFilesHandler`.
|
:class:`~django.contrib.staticfiles.handlers.StaticFilesHandler`.
|
||||||
|
|
||||||
* The :ttag:`url` and :ttag:`ssi` template tags will be
|
* The :ttag:`url` and :ttag:`ssi` template tags will be
|
||||||
modified so that the first argument to each tag is a
|
modified so that the first argument to each tag is a
|
||||||
template variable, not an implied string. The new-style
|
template variable, not an implied string. Until then, the new-style
|
||||||
behavior is provided in the ``future`` template tag library.
|
behavior is provided in the ``future`` template tag library.
|
||||||
|
|
||||||
* The :djadmin:`reset` and :djadmin:`sqlreset` management commands
|
* The :djadmin:`reset` and :djadmin:`sqlreset` management commands
|
||||||
are deprecated.
|
will be removed.
|
||||||
|
|
||||||
* Authentication backends need to support a inactive user
|
* Authentication backends will need to support an inactive user
|
||||||
being passed to all methods dealing with permissions.
|
being passed to all methods dealing with permissions.
|
||||||
The ``supports_inactive_user`` variable is not checked any
|
The ``supports_inactive_user`` attribute will no longer be checked
|
||||||
longer and can be removed.
|
and can be removed from custom backends.
|
||||||
|
|
||||||
* :meth:`~django.contrib.gis.geos.GEOSGeometry.transform` will raise
|
* :meth:`~django.contrib.gis.geos.GEOSGeometry.transform` will raise
|
||||||
a :class:`~django.contrib.gis.geos.GEOSException` when called
|
a :class:`~django.contrib.gis.geos.GEOSException` when called
|
||||||
|
@ -172,27 +168,31 @@ their deprecation, as per the :ref:`deprecation policy
|
||||||
:class:`~django.http.SimpleCookie`.
|
:class:`~django.http.SimpleCookie`.
|
||||||
|
|
||||||
* :class:`django.core.context_processors.PermWrapper` and
|
* :class:`django.core.context_processors.PermWrapper` and
|
||||||
:class:`django.core.context_processors.PermLookupDict`
|
:class:`django.core.context_processors.PermLookupDict` will be removed in
|
||||||
will be moved to :class:`django.contrib.auth.context_processors.PermWrapper`
|
favor of the corresponding
|
||||||
and :class:`django.contrib.auth.context_processors.PermLookupDict`,
|
:class:`django.contrib.auth.context_processors.PermWrapper` and
|
||||||
|
:class:`django.contrib.auth.context_processors.PermLookupDict`,
|
||||||
respectively.
|
respectively.
|
||||||
|
|
||||||
* The :setting:`MEDIA_URL` or :setting:`STATIC_URL` settings are
|
* The :setting:`MEDIA_URL` or :setting:`STATIC_URL` settings will be
|
||||||
required to end with a trailing slash to ensure there is a consistent
|
required to end with a trailing slash to ensure there is a consistent
|
||||||
way to combine paths in templates.
|
way to combine paths in templates.
|
||||||
|
|
||||||
* ``django.db.models.fields.URLField.verify_exists`` was deprecated in 1.4
|
* ``django.db.models.fields.URLField.verify_exists`` will be removed. The
|
||||||
due to intractable security and performance issues. The argument will be
|
feature was deprecated in 1.3.1 due to intractable security and
|
||||||
removed in 1.5.
|
performance issues and will follow a slightly accelerated deprecation
|
||||||
|
timeframe.
|
||||||
|
|
||||||
1.6
|
1.6
|
||||||
---
|
---
|
||||||
|
|
||||||
|
See the :doc:`Django 1.4 release notes</releases/1.4>` for more details on
|
||||||
|
these changes.
|
||||||
|
|
||||||
* The compatibility modules ``django.utils.copycompat`` and
|
* The compatibility modules ``django.utils.copycompat`` and
|
||||||
``django.utils.hashcompat`` as well as the functions
|
``django.utils.hashcompat`` as well as the functions
|
||||||
``django.utils.itercompat.all`` and ``django.utils.itercompat.any``
|
``django.utils.itercompat.all`` and ``django.utils.itercompat.any`` will
|
||||||
have been deprecated since the 1.4 release. The native versions
|
be removed. The Python builtin versions should be used instead.
|
||||||
should be used instead.
|
|
||||||
|
|
||||||
* The :func:`~django.views.decorators.csrf.csrf_response_exempt` and
|
* The :func:`~django.views.decorators.csrf.csrf_response_exempt` and
|
||||||
:func:`~django.views.decorators.csrf.csrf_view_exempt` decorators will
|
:func:`~django.views.decorators.csrf.csrf_view_exempt` decorators will
|
||||||
|
@ -204,13 +204,11 @@ their deprecation, as per the :ref:`deprecation policy
|
||||||
* The :class:`~django.core.cache.backends.memcached.CacheClass` backend
|
* The :class:`~django.core.cache.backends.memcached.CacheClass` backend
|
||||||
was split into two in Django 1.3 in order to introduce support for
|
was split into two in Django 1.3 in order to introduce support for
|
||||||
PyLibMC. The historical :class:`~django.core.cache.backends.memcached.CacheClass`
|
PyLibMC. The historical :class:`~django.core.cache.backends.memcached.CacheClass`
|
||||||
is now an alias for :class:`~django.core.cache.backends.memcached.MemcachedCache`.
|
will be removed in favor of :class:`~django.core.cache.backends.memcached.MemcachedCache`.
|
||||||
In Django 1.6, the historical alias will be removed.
|
|
||||||
|
|
||||||
* The UK-prefixed objects of ``django.contrib.localflavor.uk`` will only
|
* The UK-prefixed objects of ``django.contrib.localflavor.uk`` will only
|
||||||
be accessible through their new GB-prefixed names (GB is the correct
|
be accessible through their GB-prefixed names (GB is the correct
|
||||||
ISO 3166 code for United Kingdom). They have been deprecated since the
|
ISO 3166 code for United Kingdom).
|
||||||
1.4 release.
|
|
||||||
|
|
||||||
* The :setting:`IGNORABLE_404_STARTS` and :setting:`IGNORABLE_404_ENDS`
|
* The :setting:`IGNORABLE_404_STARTS` and :setting:`IGNORABLE_404_ENDS`
|
||||||
settings have been superseded by :setting:`IGNORABLE_404_URLS` in
|
settings have been superseded by :setting:`IGNORABLE_404_URLS` in
|
||||||
|
@ -218,7 +216,7 @@ their deprecation, as per the :ref:`deprecation policy
|
||||||
|
|
||||||
* The :doc:`form wizard </ref/contrib/formtools/form-wizard>` has been
|
* The :doc:`form wizard </ref/contrib/formtools/form-wizard>` has been
|
||||||
refactored to use class based views with pluggable backends in 1.4.
|
refactored to use class based views with pluggable backends in 1.4.
|
||||||
The previous implementation will be deprecated.
|
The previous implementation will be removed.
|
||||||
|
|
||||||
* Legacy ways of calling
|
* Legacy ways of calling
|
||||||
:func:`~django.views.decorators.cache.cache_page` will be removed.
|
:func:`~django.views.decorators.cache.cache_page` will be removed.
|
||||||
|
@ -230,26 +228,23 @@ their deprecation, as per the :ref:`deprecation policy
|
||||||
|
|
||||||
* The template tag
|
* The template tag
|
||||||
:func:`django.contrib.admin.templatetags.adminmedia.admin_media_prefix`
|
:func:`django.contrib.admin.templatetags.adminmedia.admin_media_prefix`
|
||||||
was deprecated since Django 1.4 and will be removed in favor of the
|
will be removed in favor of the generic static files handling.
|
||||||
generic static files handling.
|
|
||||||
|
|
||||||
* The builin truncation functions
|
* The builtin truncation functions :func:`django.utils.text.truncate_words`
|
||||||
:func:`django.utils.text.truncate_words` and
|
and :func:`django.utils.text.truncate_html_words` will be removed in
|
||||||
:func:`django.utils.text.truncate_html_words`
|
favor of the ``django.utils.text.Truncator`` class.
|
||||||
were deprecated since Django 1.4 and will be removed in favor
|
|
||||||
of the ``django.utils.text.Truncator`` class.
|
|
||||||
|
|
||||||
* The :class:`~django.contrib.gis.geoip.GeoIP` class was moved to
|
* The :class:`~django.contrib.gis.geoip.GeoIP` class was moved to
|
||||||
:mod:`django.contrib.gis.geoip` in 1.4 -- the shortcut in
|
:mod:`django.contrib.gis.geoip` in 1.4 -- the shortcut in
|
||||||
:mod:`django.contrib.gis.utils` will be removed.
|
:mod:`django.contrib.gis.utils` will be removed.
|
||||||
|
|
||||||
* In 1.4, functions :func:`~django.conf.urls.include`, :func:`~django.conf.urls.patterns`
|
* ``django.conf.urls.defaults`` will be removed. The functions
|
||||||
and :func:`~django.conf.urls.url` plus :data:`~django.conf.urls.handler404`,
|
:func:`~django.conf.urls.include`, :func:`~django.conf.urls.patterns` and
|
||||||
:data:`~django.conf.urls.handler500` were moved to :mod:`django.conf.urls`
|
:func:`~django.conf.urls.url` plus :data:`~django.conf.urls.handler404`,
|
||||||
from their previous location ``django.conf.urls.defaults``. This module
|
:data:`~django.conf.urls.handler500`, are now available through
|
||||||
was deprecated at the same time and will be removed in this Django release.
|
:mod:`django.conf.urls` .
|
||||||
|
|
||||||
* The Databrowse contrib module was deprecated in 1.4 and will be removed.
|
* The Databrowse contrib module will be removed.
|
||||||
|
|
||||||
2.0
|
2.0
|
||||||
---
|
---
|
||||||
|
|
Loading…
Reference in New Issue