1
0
mirror of https://github.com/django/django.git synced 2025-10-25 06:36:07 +00:00

Removed references to changes made in 1.2.

Thanks Florian Apolloner for the patch.
This commit is contained in:
Aymeric Augustin
2012-06-07 15:02:35 +02:00
parent 6492e8e5e6
commit c28e700c7e
46 changed files with 22 additions and 474 deletions

View File

@@ -26,8 +26,6 @@ SELECTs, etc. Each time your app hits the database, the query will be recorded.
Note that the SQL recorded here may be :ref:`incorrectly quoted under SQLite Note that the SQL recorded here may be :ref:`incorrectly quoted under SQLite
<sqlite-connection-queries>`. <sqlite-connection-queries>`.
.. versionadded:: 1.2
If you are using :doc:`multiple databases</topics/db/multi-db>`, you can use the If you are using :doc:`multiple databases</topics/db/multi-db>`, you can use the
same interface on each member of the ``connections`` dictionary:: same interface on each member of the ``connections`` dictionary::

View File

@@ -313,9 +313,6 @@ Custom database types
.. method:: Field.db_type(self, connection) .. method:: Field.db_type(self, connection)
.. versionadded:: 1.2
The ``connection`` argument was added to support multiple databases.
Returns the database column data type for the :class:`~django.db.models.Field`, Returns the database column data type for the :class:`~django.db.models.Field`,
taking into account the connection object, and the settings associated with it. taking into account the connection object, and the settings associated with it.
@@ -452,9 +449,6 @@ Converting Python objects to query values
.. method:: Field.get_prep_value(self, value) .. method:: Field.get_prep_value(self, value)
.. versionadded:: 1.2
This method was factored out of ``get_db_prep_value()``
This is the reverse of :meth:`.to_python` when working with the This is the reverse of :meth:`.to_python` when working with the
database backends (as opposed to serialization). The ``value`` database backends (as opposed to serialization). The ``value``
parameter is the current value of the model's attribute (a field has parameter is the current value of the model's attribute (a field has
@@ -480,9 +474,6 @@ Converting query values to database values
.. method:: Field.get_db_prep_value(self, value, connection, prepared=False) .. method:: Field.get_db_prep_value(self, value, connection, prepared=False)
.. versionadded:: 1.2
The ``connection`` and ``prepared`` arguments were added to support multiple databases.
Some data types (for example, dates) need to be in a specific format Some data types (for example, dates) need to be in a specific format
before they can be used by a database backend. before they can be used by a database backend.
:meth:`.get_db_prep_value` is the method where those conversions should :meth:`.get_db_prep_value` is the method where those conversions should
@@ -499,9 +490,6 @@ processing.
.. method:: Field.get_db_prep_save(self, value, connection) .. method:: Field.get_db_prep_save(self, value, connection)
.. versionadded:: 1.2
The ``connection`` argument was added to support multiple databases.
Same as the above, but called when the Field value must be *saved* to Same as the above, but called when the Field value must be *saved* to
the database. As the default implementation just calls the database. As the default implementation just calls
:meth:`.get_db_prep_value`, you shouldn't need to implement this method :meth:`.get_db_prep_value`, you shouldn't need to implement this method
@@ -540,9 +528,6 @@ two phase process.
.. method:: Field.get_prep_lookup(self, lookup_type, value) .. method:: Field.get_prep_lookup(self, lookup_type, value)
.. versionadded:: 1.2
This method was factored out of ``get_db_prep_lookup()``
:meth:`.get_prep_lookup` performs the first phase of lookup preparation, :meth:`.get_prep_lookup` performs the first phase of lookup preparation,
performing generic data validity checks performing generic data validity checks
@@ -591,9 +576,6 @@ accepted lookup types to ``exact`` and ``in``::
.. method:: Field.get_db_prep_lookup(self, lookup_type, value, connection, prepared=False) .. method:: Field.get_db_prep_lookup(self, lookup_type, value, connection, prepared=False)
.. versionadded:: 1.2
The ``connection`` and ``prepared`` arguments were added to support multiple databases.
Performs any database-specific data conversions required by a lookup. Performs any database-specific data conversions required by a lookup.
As with :meth:`.get_db_prep_value`, the specific connection that will As with :meth:`.get_db_prep_value`, the specific connection that will
be used for the query is passed as the ``connection`` parameter. be used for the query is passed as the ``connection`` parameter.

View File

@@ -540,8 +540,6 @@ tag is used inside a :ttag:`{% autoescape off %}<autoescape>` block.
Thread-safety considerations Thread-safety considerations
~~~~~~~~~~~~~~~~~~~~~~~~~~~~ ~~~~~~~~~~~~~~~~~~~~~~~~~~~~
.. versionadded:: 1.2
Once a node is parsed, its ``render`` method may be called any number of times. Once a node is parsed, its ``render`` method may be called any number of times.
Since Django is sometimes run in multi-threaded environments, a single node may Since Django is sometimes run in multi-threaded environments, a single node may
be simultaneously rendering with different contexts in response to two separate be simultaneously rendering with different contexts in response to two separate

View File

@@ -127,8 +127,6 @@ should be considered non-trivial, just ask.
Javascript patches Javascript patches
------------------ ------------------
.. versionadded:: 1.2
Django's admin system leverages the jQuery framework to increase the Django's admin system leverages the jQuery framework to increase the
capabilities of the admin interface. In conjunction, there is an emphasis on capabilities of the admin interface. In conjunction, there is an emphasis on
admin javascript performance and minimizing overall admin media file size. admin javascript performance and minimizing overall admin media file size.

View File

@@ -115,8 +115,6 @@ subclass::
.. attribute:: ModelAdmin.actions_selection_counter .. attribute:: ModelAdmin.actions_selection_counter
.. versionadded:: 1.2
Controls whether a selection counter is display next to the action dropdown. Controls whether a selection counter is display next to the action dropdown.
By default, the admin changelist will display it By default, the admin changelist will display it
(``actions_selection_counter = True``). (``actions_selection_counter = True``).
@@ -177,12 +175,9 @@ subclass::
fields = ('url', 'title', 'content') fields = ('url', 'title', 'content')
In the above example, only the fields ``url``, ``title`` and ``content`` In the above example, only the fields ``url``, ``title`` and ``content``
will be displayed, sequentially, in the form. will be displayed, sequentially, in the form. ``fields`` can contain
values defined in :attr:`ModelAdmin.readonly_fields` to be displayed as
.. versionadded:: 1.2 read-only.
``fields`` can contain values defined in :attr:`ModelAdmin.readonly_fields`
to be displayed as read-only.
.. versionadded:: 1.4 .. versionadded:: 1.4
@@ -262,8 +257,6 @@ subclass::
'fields': (('first_name', 'last_name'), 'address', 'city', 'state'), 'fields': (('first_name', 'last_name'), 'address', 'city', 'state'),
} }
.. versionadded:: 1.2
``fields`` can contain values defined in ``fields`` can contain values defined in
:attr:`~ModelAdmin.readonly_fields` to be displayed as read-only. :attr:`~ModelAdmin.readonly_fields` to be displayed as read-only.
@@ -380,8 +373,6 @@ subclass::
.. attribute:: ModelAdmin.get_changelist .. attribute:: ModelAdmin.get_changelist
.. versionchanged:: 1.2
Returns the Changelist class to be used for listing. By default, Returns the Changelist class to be used for listing. By default,
``django.contrib.admin.views.main.ChangeList`` is used. By inheriting this ``django.contrib.admin.views.main.ChangeList`` is used. By inheriting this
class you can change the behavior of the listing. class you can change the behavior of the listing.
@@ -819,8 +810,6 @@ subclass::
.. attribute:: ModelAdmin.readonly_fields .. attribute:: ModelAdmin.readonly_fields
.. versionadded:: 1.2
By default the admin shows all fields as editable. Any fields in this By default the admin shows all fields as editable. Any fields in this
option (which should be a ``list`` or ``tuple``) will display its data option (which should be a ``list`` or ``tuple``) will display its data
as-is and non-editable. This option behaves nearly identical to as-is and non-editable. This option behaves nearly identical to
@@ -928,8 +917,6 @@ templates used by the :class:`ModelAdmin` views:
.. attribute:: ModelAdmin.add_form_template .. attribute:: ModelAdmin.add_form_template
.. versionadded:: 1.2
Path to a custom template, used by :meth:`add_view`. Path to a custom template, used by :meth:`add_view`.
.. attribute:: ModelAdmin.change_form_template .. attribute:: ModelAdmin.change_form_template
@@ -947,8 +934,6 @@ templates used by the :class:`ModelAdmin` views:
.. attribute:: ModelAdmin.delete_selected_confirmation_template .. attribute:: ModelAdmin.delete_selected_confirmation_template
.. versionadded:: 1.2
Path to a custom template, used by the :meth:`delete_selected` Path to a custom template, used by the :meth:`delete_selected`
action method for displaying a confirmation page when deleting one action method for displaying a confirmation page when deleting one
or more objects. See the :doc:`actions or more objects. See the :doc:`actions
@@ -1035,8 +1020,6 @@ templates used by the :class:`ModelAdmin` views:
.. method:: ModelAdmin.get_readonly_fields(self, request, obj=None) .. method:: ModelAdmin.get_readonly_fields(self, request, obj=None)
.. versionadded:: 1.2
The ``get_readonly_fields`` method is given the ``HttpRequest`` and the The ``get_readonly_fields`` method is given the ``HttpRequest`` and the
``obj`` being edited (or ``None`` on an add form) and is expected to return ``obj`` being edited (or ``None`` on an add form) and is expected to return
a ``list`` or ``tuple`` of field names that will be displayed as read-only, a ``list`` or ``tuple`` of field names that will be displayed as read-only,
@@ -1405,20 +1388,17 @@ adds some of its own (the shared features are actually defined in the
- :attr:`~InlineModelAdmin.form` - :attr:`~InlineModelAdmin.form`
- :attr:`~ModelAdmin.fieldsets` - :attr:`~ModelAdmin.fieldsets`
- :attr:`~ModelAdmin.fields` - :attr:`~ModelAdmin.fields`
- :attr:`~ModelAdmin.formfield_overrides`
- :attr:`~ModelAdmin.exclude` - :attr:`~ModelAdmin.exclude`
- :attr:`~ModelAdmin.filter_horizontal` - :attr:`~ModelAdmin.filter_horizontal`
- :attr:`~ModelAdmin.filter_vertical` - :attr:`~ModelAdmin.filter_vertical`
- :attr:`~ModelAdmin.prepopulated_fields` - :attr:`~ModelAdmin.prepopulated_fields`
- :attr:`~ModelAdmin.radio_fields` - :attr:`~ModelAdmin.radio_fields`
- :attr:`~ModelAdmin.readonly_fields`
- :attr:`~InlineModelAdmin.raw_id_fields` - :attr:`~InlineModelAdmin.raw_id_fields`
- :meth:`~ModelAdmin.formfield_for_foreignkey` - :meth:`~ModelAdmin.formfield_for_foreignkey`
- :meth:`~ModelAdmin.formfield_for_manytomany` - :meth:`~ModelAdmin.formfield_for_manytomany`
.. versionadded:: 1.2
- :attr:`~ModelAdmin.readonly_fields`
- :attr:`~ModelAdmin.formfield_overrides`
.. versionadded:: 1.3 .. versionadded:: 1.3
- :attr:`~ModelAdmin.ordering` - :attr:`~ModelAdmin.ordering`
@@ -1463,8 +1443,6 @@ The ``InlineModelAdmin`` class adds:
:doc:`formsets documentation </topics/forms/formsets>` for more :doc:`formsets documentation </topics/forms/formsets>` for more
information. information.
.. versionadded:: 1.2
For users with JavaScript-enabled browsers, an "Add another" link is For users with JavaScript-enabled browsers, an "Add another" link is
provided to enable any number of additional inlines to be added in addition provided to enable any number of additional inlines to be added in addition
to those provided as a result of the ``extra`` argument. to those provided as a result of the ``extra`` argument.
@@ -1541,8 +1519,6 @@ automatically::
Working with many-to-many models Working with many-to-many models
-------------------------------- --------------------------------
.. versionadded:: 1.2
By default, admin widgets for many-to-many relations will be displayed By default, admin widgets for many-to-many relations will be displayed
on whichever model contains the actual reference to the on whichever model contains the actual reference to the
:class:`~django.db.models.ManyToManyField`. Depending on your ``ModelAdmin`` :class:`~django.db.models.ManyToManyField`. Depending on your ``ModelAdmin``
@@ -1842,21 +1818,15 @@ Templates can override or extend base admin templates as described in
.. attribute:: AdminSite.logout_template .. attribute:: AdminSite.logout_template
.. versionadded:: 1.2
Path to a custom template that will be used by the admin site logout view. Path to a custom template that will be used by the admin site logout view.
.. attribute:: AdminSite.password_change_template .. attribute:: AdminSite.password_change_template
.. versionadded:: 1.2
Path to a custom template that will be used by the admin site password Path to a custom template that will be used by the admin site password
change view. change view.
.. attribute:: AdminSite.password_change_done_template .. attribute:: AdminSite.password_change_done_template
.. versionadded:: 1.2
Path to a custom template that will be used by the admin site password Path to a custom template that will be used by the admin site password
change done view. change done view.

View File

@@ -37,8 +37,6 @@ available in the context, then you can refer to it directly::
{% get_comment_count for entry as comment_count %} {% get_comment_count for entry as comment_count %}
<p>{{ comment_count }} comments have been posted.</p> <p>{{ comment_count }} comments have been posted.</p>
.. versionadded:: 1.2
Next, we can use the :ttag:`render_comment_list` tag, to render all comments Next, we can use the :ttag:`render_comment_list` tag, to render all comments
to the given instance (``entry``) by using the ``comments/list.html`` template:: to the given instance (``entry``) by using the ``comments/list.html`` template::

View File

@@ -130,8 +130,6 @@ details.
Linking to comments Linking to comments
------------------- -------------------
.. versionadded:: 1.2
To provide a permalink to a specific comment, use :ttag:`get_comment_permalink`:: To provide a permalink to a specific comment, use :ttag:`get_comment_permalink`::
{% get_comment_permalink comment_obj [format_string] %} {% get_comment_permalink comment_obj [format_string] %}

View File

@@ -434,8 +434,6 @@ A number of settings can be used to control Django's CSRF behavior.
CSRF_COOKIE_DOMAIN CSRF_COOKIE_DOMAIN
------------------ ------------------
.. versionadded:: 1.2
Default: ``None`` Default: ``None``
The domain to be used when setting the CSRF cookie. This can be useful for The domain to be used when setting the CSRF cookie. This can be useful for
@@ -450,8 +448,6 @@ mechanism is not safe against cross-subdomain attacks -- see `Limitations`_.
CSRF_COOKIE_NAME CSRF_COOKIE_NAME
---------------- ----------------
.. versionadded:: 1.2
Default: ``'csrftoken'`` Default: ``'csrftoken'``
The name of the cookie to use for the CSRF authentication token. This can be The name of the cookie to use for the CSRF authentication token. This can be
@@ -485,8 +481,6 @@ cookie is only sent under an HTTPS connection.
CSRF_FAILURE_VIEW CSRF_FAILURE_VIEW
----------------- -----------------
.. versionadded:: 1.2
Default: ``'django.views.csrf.csrf_failure'`` Default: ``'django.views.csrf.csrf_failure'``
A dotted path to the view function to be used when an incoming request A dotted path to the view function to be used when an incoming request

View File

@@ -110,8 +110,6 @@ default templates.
Advanced ``FormPreview`` methods Advanced ``FormPreview`` methods
================================ ================================
.. versionadded:: 1.2
.. method:: FormPreview.process_preview .. method:: FormPreview.process_preview
Given a validated form, performs any extra processing before displaying the Given a validated form, performs any extra processing before displaying the

View File

@@ -12,11 +12,7 @@ GeoDjango Database API
Spatial Backends Spatial Backends
================ ================
.. versionadded:: 1.2 GeoDjango currently provides the following spatial database backends:
In Django 1.2, support for :doc:`multiple databases </topics/db/multi-db>` was
introduced. In order to support multiple databases, GeoDjango has segregated
its functionality into full-fledged spatial database backends:
* :mod:`django.contrib.gis.db.backends.postgis` * :mod:`django.contrib.gis.db.backends.postgis`
* :mod:`django.contrib.gis.db.backends.mysql` * :mod:`django.contrib.gis.db.backends.mysql`

View File

@@ -212,8 +212,6 @@ __ http://www.gdal.org/ogr/ogr_formats.html
.. attribute:: spatial_filter .. attribute:: spatial_filter
.. versionadded:: 1.2
Property that may be used to retrieve or set a spatial filter for this Property that may be used to retrieve or set a spatial filter for this
layer. A spatial filter can only be set with an :class:`OGRGeometry` layer. A spatial filter can only be set with an :class:`OGRGeometry`
instance, a 4-tuple extent, or ``None``. When set with something instance, a 4-tuple extent, or ``None``. When set with something
@@ -490,15 +488,9 @@ systems and coordinate transformation::
.. attribute:: coord_dim .. attribute:: coord_dim
.. versionchanged:: 1.2
Returns or sets the coordinate dimension of this geometry. For Returns or sets the coordinate dimension of this geometry. For
example, the value would be 2 for two-dimensional geometries. example, the value would be 2 for two-dimensional geometries.
.. note::
Setting this property is only available in versions 1.2 and above.
.. attribute:: geom_count .. attribute:: geom_count
Returns the number of elements in this geometry:: Returns the number of elements in this geometry::
@@ -619,8 +611,6 @@ systems and coordinate transformation::
.. attribute:: ewkt .. attribute:: ewkt
.. versionadded:: 1.2
Returns the EWKT representation of this geometry. Returns the EWKT representation of this geometry.
.. method:: clone() .. method:: clone()

View File

@@ -117,8 +117,6 @@ SpatiaLite ``Contains(poly, geom)``
contains_properly contains_properly
----------------- -----------------
.. versionadded:: 1.2
*Availability*: PostGIS *Availability*: PostGIS
Returns true if the lookup geometry intersects the interior of the Returns true if the lookup geometry intersects the interior of the
@@ -803,8 +801,6 @@ Geometry Editors
.. method:: GeoQuerySet.force_rhr(**kwargs) .. method:: GeoQuerySet.force_rhr(**kwargs)
.. versionadded:: 1.2
*Availability*: PostGIS *Availability*: PostGIS
Returns a modified version of the polygon/multipolygon in which all Returns a modified version of the polygon/multipolygon in which all
@@ -816,8 +812,6 @@ of the vertices follow the Right-Hand-Rule, and attaches as a
.. method:: GeoQuerySet.reverse_geom(**kwargs) .. method:: GeoQuerySet.reverse_geom(**kwargs)
.. versionadded:: 1.2
*Availability*: PostGIS, Oracle *Availability*: PostGIS, Oracle
Reverse the coordinate order of the geometry field, and attaches as a Reverse the coordinate order of the geometry field, and attaches as a
@@ -943,8 +937,6 @@ of the geometry field in each model converted to the requested output format.
.. method:: GeoQuerySet.geohash(precision=20, **kwargs) .. method:: GeoQuerySet.geohash(precision=20, **kwargs)
.. versionadded:: 1.2
Attaches a ``geohash`` attribute to every model the queryset Attaches a ``geohash`` attribute to every model the queryset
containing the `GeoHash`__ representation of the geometry. containing the `GeoHash`__ representation of the geometry.
@@ -1136,8 +1128,6 @@ Example::
.. method:: GeoQuerySet.extent3d(**kwargs) .. method:: GeoQuerySet.extent3d(**kwargs)
.. versionadded:: 1.2
*Availability*: PostGIS *Availability*: PostGIS
Returns the 3D extent of the ``GeoQuerySet`` as a six-tuple, comprising Returns the 3D extent of the ``GeoQuerySet`` as a six-tuple, comprising
@@ -1224,8 +1214,6 @@ Returns the same as the :meth:`GeoQuerySet.extent` aggregate method.
.. class:: Extent3D(geo_field) .. class:: Extent3D(geo_field)
.. versionadded:: 1.2
Returns the same as the :meth:`GeoQuerySet.extent3d` aggregate method. Returns the same as the :meth:`GeoQuerySet.extent3d` aggregate method.
``MakeLine`` ``MakeLine``

View File

@@ -265,8 +265,6 @@ because it is not a part of the OGC specification (use the
.. attribute:: GEOSGeometry.hexewkb .. attribute:: GEOSGeometry.hexewkb
.. versionadded:: 1.2
Returns the EWKB of this Geometry in hexadecimal form. This is an Returns the EWKB of this Geometry in hexadecimal form. This is an
extension of the WKB specification that includes SRID and Z values extension of the WKB specification that includes SRID and Z values
that are a part of this geometry. that are a part of this geometry.
@@ -314,8 +312,6 @@ as a Python buffer. SRID and Z values are not included, use the
.. attribute:: GEOSGeometry.ewkb .. attribute:: GEOSGeometry.ewkb
.. versionadded:: 1.2
Return the EWKB representation of this Geometry as a Python buffer. Return the EWKB representation of this Geometry as a Python buffer.
This is an extension of the WKB specification that includes any SRID This is an extension of the WKB specification that includes any SRID
and Z values that are a part of this geometry. and Z values that are a part of this geometry.

View File

@@ -624,8 +624,6 @@ features such as the geographic admin or KML sitemaps will not function properly
Add Google projection to ``spatial_ref_sys`` table Add Google projection to ``spatial_ref_sys`` table
-------------------------------------------------- --------------------------------------------------
.. versionchanged:: 1.2
.. note:: .. note::
If you're running PostGIS 1.4 or above, you can skip this step. The entry If you're running PostGIS 1.4 or above, you can skip this step. The entry

View File

@@ -163,8 +163,6 @@ field.
``dim`` ``dim``
------- -------
.. versionadded:: 1.2
.. attribute:: GeometryField.dim .. attribute:: GeometryField.dim
This option may be used for customizing the coordinate dimension of the This option may be used for customizing the coordinate dimension of the
@@ -180,8 +178,6 @@ three-dimensonal support.
``geography`` ``geography``
------------- -------------
.. versionadded:: 1.2
.. attribute:: GeometryField.geography .. attribute:: GeometryField.geography
If set to ``True``, this option will create a database column of If set to ``True``, this option will create a database column of

View File

@@ -2,12 +2,6 @@
Testing GeoDjango apps Testing GeoDjango apps
====================== ======================
.. versionchanged:: 1.2
In Django 1.2, the addition of :ref:`spatial-backends` simplified the
process of testing GeoDjango applications. The process is now the
same as :doc:`/topics/testing`.
Included in this documentation are some additional notes and settings Included in this documentation are some additional notes and settings
for :ref:`testing-postgis` and :ref:`testing-spatialite` users. for :ref:`testing-postgis` and :ref:`testing-spatialite` users.
@@ -28,11 +22,9 @@ Settings
``POSTGIS_TEMPLATE`` ``POSTGIS_TEMPLATE``
^^^^^^^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^^^^^
.. versionchanged:: 1.2
This setting may be used to customize the name of the PostGIS template This setting may be used to customize the name of the PostGIS template
database to use. In Django versions 1.2 and above, it automatically database to use. It automatically defaults to ``'template_postgis'``
defaults to ``'template_postgis'`` (the same name used in the (the same name used in the
:ref:`installation documentation <spatialdb_template>`). :ref:`installation documentation <spatialdb_template>`).
.. setting:: POSTGIS_VERSION .. setting:: POSTGIS_VERSION

View File

@@ -142,9 +142,6 @@ See the :doc:`markup documentation </ref/contrib/markup>`.
messages messages
======== ========
.. versionchanged:: 1.2
The messages framework was added.
A framework for storing and retrieving temporary cookie- or session-based A framework for storing and retrieving temporary cookie- or session-based
messages messages

View File

@@ -12,9 +12,6 @@ in a subsequent request (usually the next one). Every message is tagged
with a specific ``level`` that determines its priority (e.g., ``info``, with a specific ``level`` that determines its priority (e.g., ``info``,
``warning``, or ``error``). ``warning``, or ``error``).
.. versionadded:: 1.2
The messages framework was added.
Enabling messages Enabling messages
================= =================

View File

@@ -22,10 +22,6 @@ lower-level way.
The high-level framework The high-level framework
======================== ========================
.. versionchanged:: 1.2
The high-level feeds framework was refactored in Django 1.2. The
pre-1.2 interface has been removed in Django 1.4.
Overview Overview
-------- --------
@@ -176,9 +172,6 @@ These can be matched with a :doc:`URLconf </topics/http/urls>` line such as::
Like a view, the arguments in the URL are passed to the ``get_object()`` Like a view, the arguments in the URL are passed to the ``get_object()``
method along with the request object. method along with the request object.
.. versionchanged:: 1.2
Prior to version 1.2, ``get_object()`` only accepted a ``bits`` argument.
Here's the code for these beat-specific feeds:: Here's the code for these beat-specific feeds::
from django.contrib.syndication.views import FeedDoesNotExist from django.contrib.syndication.views import FeedDoesNotExist

View File

@@ -373,15 +373,6 @@ these methods in no-op's based in the results of such detection.
Notes on specific fields Notes on specific fields
------------------------ ------------------------
Boolean fields
~~~~~~~~~~~~~~
.. versionchanged:: 1.2
In previous versions of Django when running under MySQL ``BooleanFields`` would
return their data as ``ints``, instead of true ``bools``. See the release
notes for a complete description of the change.
Character fields Character fields
~~~~~~~~~~~~~~~~ ~~~~~~~~~~~~~~~~

View File

@@ -119,8 +119,6 @@ createcachetable
Creates a cache table named ``tablename`` for use with the database cache Creates a cache table named ``tablename`` for use with the database cache
backend. See :doc:`/topics/cache` for more information. backend. See :doc:`/topics/cache` for more information.
.. versionadded:: 1.2
The :djadminopt:`--database` option can be used to specify the database The :djadminopt:`--database` option can be used to specify the database
onto which the cachetable will be installed. onto which the cachetable will be installed.
@@ -142,8 +140,6 @@ the program name (``psql``, ``mysql``, ``sqlite3``) will find the program in
the right place. There's no way to specify the location of the program the right place. There's no way to specify the location of the program
manually. manually.
.. versionadded:: 1.2
The :djadminopt:`--database` option can be used to specify the database The :djadminopt:`--database` option can be used to specify the database
onto which to open a shell. onto which to open a shell.
@@ -212,15 +208,11 @@ name to ``dumpdata``, the dumped output will be restricted to that model,
rather than the entire application. You can also mix application names and rather than the entire application. You can also mix application names and
model names. model names.
.. versionadded:: 1.2
The :djadminopt:`--database` option can be used to specify the database The :djadminopt:`--database` option can be used to specify the database
from which data will be dumped. from which data will be dumped.
.. django-admin-option:: --natural .. django-admin-option:: --natural
.. versionadded:: 1.2
Use :ref:`natural keys <topics-serialization-natural-keys>` to represent Use :ref:`natural keys <topics-serialization-natural-keys>` to represent
any foreign key and many-to-many relationship with a model that provides any foreign key and many-to-many relationship with a model that provides
a natural key definition. If you are dumping ``contrib.auth`` ``Permission`` a natural key definition. If you are dumping ``contrib.auth`` ``Permission``
@@ -240,8 +232,6 @@ fixture will be re-installed.
The :djadminopt:`--noinput` option may be provided to suppress all user The :djadminopt:`--noinput` option may be provided to suppress all user
prompts. prompts.
.. versionadded:: 1.2
The :djadminopt:`--database` option may be used to specify the database The :djadminopt:`--database` option may be used to specify the database
to flush. to flush.
@@ -296,8 +286,6 @@ needed.
``inspectdb`` works with PostgreSQL, MySQL and SQLite. Foreign-key detection ``inspectdb`` works with PostgreSQL, MySQL and SQLite. Foreign-key detection
only works in PostgreSQL and with certain types of MySQL tables. only works in PostgreSQL and with certain types of MySQL tables.
.. versionadded:: 1.2
The :djadminopt:`--database` option may be used to specify the The :djadminopt:`--database` option may be used to specify the
database to introspect. database to introspect.
@@ -308,8 +296,6 @@ loaddata <fixture fixture ...>
Searches for and loads the contents of the named fixture into the database. Searches for and loads the contents of the named fixture into the database.
.. versionadded:: 1.2
The :djadminopt:`--database` option can be used to specify the database The :djadminopt:`--database` option can be used to specify the database
onto which the data will be loaded. onto which the data will be loaded.
@@ -452,8 +438,6 @@ Currently supported:
.. django-admin-option:: --symlinks .. django-admin-option:: --symlinks
.. versionadded:: 1.2
Use the ``--symlinks`` or ``-s`` option to follow symlinks to directories when Use the ``--symlinks`` or ``-s`` option to follow symlinks to directories when
looking for new translation strings. looking for new translation strings.
@@ -768,8 +752,6 @@ sql <appname appname ...>
Prints the CREATE TABLE SQL statements for the given app name(s). Prints the CREATE TABLE SQL statements for the given app name(s).
.. versionadded:: 1.2
The :djadminopt:`--database` option can be used to specify the database for The :djadminopt:`--database` option can be used to specify the database for
which to print the SQL. which to print the SQL.
@@ -783,8 +765,6 @@ Prints the CREATE TABLE and initial-data SQL statements for the given app name(s
Refer to the description of ``sqlcustom`` for an explanation of how to Refer to the description of ``sqlcustom`` for an explanation of how to
specify initial data. specify initial data.
.. versionadded:: 1.2
The :djadminopt:`--database` option can be used to specify the database for The :djadminopt:`--database` option can be used to specify the database for
which to print the SQL. which to print the SQL.
@@ -795,8 +775,6 @@ sqlclear <appname appname ...>
Prints the DROP TABLE SQL statements for the given app name(s). Prints the DROP TABLE SQL statements for the given app name(s).
.. versionadded:: 1.2
The :djadminopt:`--database` option can be used to specify the database for The :djadminopt:`--database` option can be used to specify the database for
which to print the SQL. which to print the SQL.
@@ -821,8 +799,6 @@ table modifications, or insert any SQL functions into the database.
Note that the order in which the SQL files are processed is undefined. Note that the order in which the SQL files are processed is undefined.
.. versionadded:: 1.2
The :djadminopt:`--database` option can be used to specify the database for The :djadminopt:`--database` option can be used to specify the database for
which to print the SQL. which to print the SQL.
@@ -834,8 +810,6 @@ sqlflush
Prints the SQL statements that would be executed for the :djadmin:`flush` Prints the SQL statements that would be executed for the :djadmin:`flush`
command. command.
.. versionadded:: 1.2
The :djadminopt:`--database` option can be used to specify the database for The :djadminopt:`--database` option can be used to specify the database for
which to print the SQL. which to print the SQL.
@@ -846,8 +820,6 @@ sqlindexes <appname appname ...>
Prints the CREATE INDEX SQL statements for the given app name(s). Prints the CREATE INDEX SQL statements for the given app name(s).
.. versionadded:: 1.2
The :djadminopt:`--database` option can be used to specify the database for The :djadminopt:`--database` option can be used to specify the database for
which to print the SQL. which to print the SQL.
@@ -864,8 +836,6 @@ number for automatically incremented fields.
Use this command to generate SQL which will fix cases where a sequence is out Use this command to generate SQL which will fix cases where a sequence is out
of sync with its automatically incremented field data. of sync with its automatically incremented field data.
.. versionadded:: 1.2
The :djadminopt:`--database` option can be used to specify the database for The :djadminopt:`--database` option can be used to specify the database for
which to print the SQL. which to print the SQL.
@@ -1027,8 +997,6 @@ data files.
The :djadminopt:`--noinput` option may be provided to suppress all user The :djadminopt:`--noinput` option may be provided to suppress all user
prompts. prompts.
.. versionadded:: 1.2
The :djadminopt:`--database` option can be used to specify the database to The :djadminopt:`--database` option can be used to specify the database to
synchronize. synchronize.
@@ -1047,7 +1015,6 @@ test <app or test identifier>
Runs tests for all installed models. See :doc:`/topics/testing` for more Runs tests for all installed models. See :doc:`/topics/testing` for more
information. information.
.. versionadded:: 1.2
.. django-admin-option:: --failfast .. django-admin-option:: --failfast
The ``--failfast`` option can be used to stop running tests and report the The ``--failfast`` option can be used to stop running tests and report the
@@ -1155,8 +1122,6 @@ changepassword
.. django-admin:: changepassword .. django-admin:: changepassword
.. versionadded:: 1.2
This command is only available if Django's :doc:`authentication system This command is only available if Django's :doc:`authentication system
</topics/auth>` (``django.contrib.auth``) is installed. </topics/auth>` (``django.contrib.auth``) is installed.
@@ -1317,8 +1282,6 @@ to a number of commands.
.. django-admin-option:: --database .. django-admin-option:: --database
.. versionadded:: 1.2
Used to specify the database on which a command will operate. If not Used to specify the database on which a command will operate. If not
specified, this option will default to an alias of ``default``. specified, this option will default to an alias of ``default``.

View File

@@ -377,8 +377,6 @@ a form object, and each rendering method returns a Unicode object.
Styling required or erroneous form rows Styling required or erroneous form rows
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
.. versionadded:: 1.2
It's pretty common to style form rows and fields that are required or have It's pretty common to style form rows and fields that are required or have
errors. For example, you might want to present required form rows in bold and errors. For example, you might want to present required form rows in bold and
highlight errors in red. highlight errors in red.
@@ -638,8 +636,6 @@ For a field's list of errors, access the field's ``errors`` attribute.
.. method:: BoundField.css_classes() .. method:: BoundField.css_classes()
.. versionadded:: 1.2
When you use Django's rendering shortcuts, CSS classes are used to When you use Django's rendering shortcuts, CSS classes are used to
indicate required form fields or fields that contain errors. If you're indicate required form fields or fields that contain errors. If you're
manually rendering a form, you can access these CSS classes using the manually rendering a form, you can access these CSS classes using the

View File

@@ -256,8 +256,6 @@ error message keys it uses.
``validators`` ``validators``
~~~~~~~~~~~~~~ ~~~~~~~~~~~~~~
.. versionadded:: 1.2
.. attribute:: Field.validators .. attribute:: Field.validators
The ``validators`` argument lets you provide a list of validation functions The ``validators`` argument lets you provide a list of validation functions
@@ -268,8 +266,6 @@ See the :doc:`validators documentation </ref/validators>` for more information.
``localize`` ``localize``
~~~~~~~~~~~~ ~~~~~~~~~~~~
.. versionadded:: 1.2
.. attribute:: Field.localize .. attribute:: Field.localize
The ``localize`` argument enables the localization of form data, input as well The ``localize`` argument enables the localization of form data, input as well
@@ -492,11 +488,6 @@ For each field, we describe the default widget used if you don't specify
If provided, these arguments ensure that the string is at most or at least the If provided, these arguments ensure that the string is at most or at least the
given length. given length.
.. versionchanged:: 1.2
The EmailField previously did not recognize email addresses as valid that
contained an IDN (Internationalized Domain Name; a domain containing
unicode characters) domain part. This has now been corrected.
``FileField`` ``FileField``
~~~~~~~~~~~~~ ~~~~~~~~~~~~~
@@ -815,11 +806,6 @@ For each field, we describe the default widget used if you don't specify
These are the same as ``CharField.max_length`` and ``CharField.min_length``. These are the same as ``CharField.max_length`` and ``CharField.min_length``.
.. versionchanged:: 1.2
The URLField previously did not recognize URLs as valid that contained an IDN
(Internationalized Domain Name; a domain name containing unicode characters)
domain name. This has now been corrected.
Slightly complex built-in ``Field`` classes Slightly complex built-in ``Field`` classes
------------------------------------------- -------------------------------------------

View File

@@ -1,8 +1,6 @@
Form and field validation Form and field validation
========================= =========================
.. versionchanged:: 1.2
Form validation happens when the data is cleaned. If you want to customize Form validation happens when the data is cleaned. If you want to customize
this process, there are various places you can change, each one serving a this process, there are various places you can change, each one serving a
different purpose. Three types of cleaning methods are run during form different purpose. Three types of cleaning methods are run during form
@@ -175,7 +173,6 @@ previous features.
Using validators Using validators
~~~~~~~~~~~~~~~~ ~~~~~~~~~~~~~~~~
.. versionadded:: 1.2
Django's form (and model) fields support use of simple utility functions and Django's form (and model) fields support use of simple utility functions and
classes known as validators. These can be passed to a field's constructor, via classes known as validators. These can be passed to a field's constructor, via

View File

@@ -156,9 +156,6 @@ Message middleware
.. class:: MessageMiddleware .. class:: MessageMiddleware
.. versionadded:: 1.2
``MessageMiddleware`` was added.
Enables cookie- and session-based message support. See the Enables cookie- and session-based message support. See the
:doc:`messages documentation </ref/contrib/messages>`. :doc:`messages documentation </ref/contrib/messages>`.

View File

@@ -208,8 +208,6 @@ automatically generated from the model class. Default is ``True``.
``error_messages`` ``error_messages``
------------------ ------------------
.. versionadded:: 1.2
.. attribute:: Field.error_messages .. attribute:: Field.error_messages
The ``error_messages`` argument lets you override the default messages that the The ``error_messages`` argument lets you override the default messages that the
@@ -309,8 +307,6 @@ underscores to spaces. See :ref:`Verbose field names <verbose-field-names>`.
``validators`` ``validators``
------------------- -------------------
.. versionadded:: 1.2
.. attribute:: Field.validators .. attribute:: Field.validators
A list of validators to run for this field. See the :doc:`validators A list of validators to run for this field. See the :doc:`validators
@@ -336,8 +332,6 @@ otherwise. See :ref:`automatic-primary-key-fields`.
``BigIntegerField`` ``BigIntegerField``
------------------- -------------------
.. versionadded:: 1.2
.. class:: BigIntegerField([**options]) .. class:: BigIntegerField([**options])
A 64 bit integer, much like an :class:`IntegerField` except that it is A 64 bit integer, much like an :class:`IntegerField` except that it is
@@ -357,11 +351,6 @@ The admin represents this as a checkbox.
If you need to accept :attr:`~Field.null` values then use If you need to accept :attr:`~Field.null` values then use
:class:`NullBooleanField` instead. :class:`NullBooleanField` instead.
.. versionchanged:: 1.2
In previous versions of Django when running under MySQL ``BooleanFields``
would return their data as ``ints``, instead of true ``bools``. See the
release notes for a complete description of the change.
``CharField`` ``CharField``
------------- -------------

View File

@@ -30,8 +30,6 @@ that, you need to :meth:`~Model.save()`.
Validating objects Validating objects
================== ==================
.. versionadded:: 1.2
There are three steps involved in validating a model: There are three steps involved in validating a model:
1. Validate the model fields 1. Validate the model fields
@@ -137,9 +135,6 @@ To save an object back to the database, call ``save()``:
.. method:: Model.save([force_insert=False, force_update=False, using=DEFAULT_DB_ALIAS, update_fields=None]) .. method:: Model.save([force_insert=False, force_update=False, using=DEFAULT_DB_ALIAS, update_fields=None])
.. versionadded:: 1.2
The ``using`` argument was added.
If you want customized saving behavior, you can override this ``save()`` If you want customized saving behavior, you can override this ``save()``
method. See :ref:`overriding-model-methods` for more details. method. See :ref:`overriding-model-methods` for more details.
@@ -361,9 +356,6 @@ Deleting objects
.. method:: Model.delete([using=DEFAULT_DB_ALIAS]) .. method:: Model.delete([using=DEFAULT_DB_ALIAS])
.. versionadded:: 1.2
The ``using`` argument was added.
Issues a SQL ``DELETE`` for the object. This only deletes the object in the Issues a SQL ``DELETE`` for the object. This only deletes the object in the
database; the Python instance will still exist and will still have data in database; the Python instance will still exist and will still have data in
its fields. its fields.

View File

@@ -727,8 +727,6 @@ passed to ``select_related()``. This includes foreign keys that have
It's an error to use both a list of fields and the ``depth`` parameter in the It's an error to use both a list of fields and the ``depth`` parameter in the
same ``select_related()`` call; they are conflicting options. same ``select_related()`` call; they are conflicting options.
.. versionchanged:: 1.2
You can also refer to the reverse direction of a You can also refer to the reverse direction of a
:class:`~django.db.models.OneToOneField` in the list of fields passed to :class:`~django.db.models.OneToOneField` in the list of fields passed to
``select_related`` — that is, you can traverse a ``select_related`` — that is, you can traverse a
@@ -1156,8 +1154,6 @@ using
.. method:: using(alias) .. method:: using(alias)
.. versionadded:: 1.2
This method is for controlling which database the ``QuerySet`` will be This method is for controlling which database the ``QuerySet`` will be
evaluated against if you are using more than one database. The only argument evaluated against if you are using more than one database. The only argument
this method takes is the alias of a database, as defined in this method takes is the alias of a database, as defined in
@@ -1512,8 +1508,6 @@ exists
.. method:: exists() .. method:: exists()
.. versionadded:: 1.2
Returns ``True`` if the :class:`.QuerySet` contains any results, and ``False`` Returns ``True`` if the :class:`.QuerySet` contains any results, and ``False``
if not. This tries to perform the query in the simplest and fastest way if not. This tries to perform the query in the simplest and fastest way
possible, but it *does* execute nearly the same query. This means that calling possible, but it *does* execute nearly the same query. This means that calling

View File

@@ -307,8 +307,6 @@ See :doc:`/topics/cache`.
CSRF_COOKIE_DOMAIN CSRF_COOKIE_DOMAIN
------------------ ------------------
.. versionadded:: 1.2
Default: ``None`` Default: ``None``
The domain to be used when setting the CSRF cookie. This can be useful for The domain to be used when setting the CSRF cookie. This can be useful for
@@ -326,8 +324,6 @@ protection is safe from cross-subdomain attacks by default - please see the
CSRF_COOKIE_NAME CSRF_COOKIE_NAME
---------------- ----------------
.. versionadded:: 1.2
Default: ``'csrftoken'`` Default: ``'csrftoken'``
The name of the cookie to use for the CSRF authentication token. This can be whatever you The name of the cookie to use for the CSRF authentication token. This can be whatever you
@@ -367,8 +363,6 @@ cookie is only sent under an HTTPS connection.
CSRF_FAILURE_VIEW CSRF_FAILURE_VIEW
----------------- -----------------
.. versionadded:: 1.2
Default: ``'django.views.csrf.csrf_failure'`` Default: ``'django.views.csrf.csrf_failure'``
A dotted path to the view function to be used when an incoming request A dotted path to the view function to be used when an incoming request
@@ -386,8 +380,6 @@ end users) indicating the reason the request was rejected. See
DATABASES DATABASES
--------- ---------
.. versionadded:: 1.2
Default: ``{}`` (Empty dictionary) Default: ``{}`` (Empty dictionary)
A dictionary containing the settings for all databases to be used with A dictionary containing the settings for all databases to be used with
@@ -430,12 +422,6 @@ You can use a database backend that doesn't ship with Django by setting
scratch is left as an exercise to the reader; see the other backends for scratch is left as an exercise to the reader; see the other backends for
examples. examples.
.. note::
Prior to Django 1.2, you could use a short version of the backend name
to reference the built-in database backends (e.g., you could use
``'sqlite3'`` to refer to the SQLite backend). This format has been
deprecated, and will be removed in Django 1.4.
.. setting:: HOST .. setting:: HOST
HOST HOST
@@ -664,8 +650,6 @@ not provided, Django will use ``'test_' + NAME + '_temp'``.
DATABASE_ROUTERS DATABASE_ROUTERS
---------------- ----------------
.. versionadded:: 1.2
Default: ``[]`` (Empty list) Default: ``[]`` (Empty list)
The list of routers that will be used to determine which database The list of routers that will be used to determine which database
@@ -686,9 +670,6 @@ system. Note that if :setting:`USE_L10N` is set to ``True``, then the
locale-dictated format has higher precedence and will be applied instead. See locale-dictated format has higher precedence and will be applied instead. See
:tfilter:`allowed date format strings <date>`. :tfilter:`allowed date format strings <date>`.
.. versionchanged:: 1.2
This setting can now be overriden by setting :setting:`USE_L10N` to ``True``.
See also :setting:`DATETIME_FORMAT`, :setting:`TIME_FORMAT` and :setting:`SHORT_DATE_FORMAT`. See also :setting:`DATETIME_FORMAT`, :setting:`TIME_FORMAT` and :setting:`SHORT_DATE_FORMAT`.
.. setting:: DATE_INPUT_FORMATS .. setting:: DATE_INPUT_FORMATS
@@ -696,8 +677,6 @@ See also :setting:`DATETIME_FORMAT`, :setting:`TIME_FORMAT` and :setting:`SHORT_
DATE_INPUT_FORMATS DATE_INPUT_FORMATS
------------------ ------------------
.. versionadded:: 1.2
Default:: Default::
('%Y-%m-%d', '%m/%d/%Y', '%m/%d/%y', '%b %d %Y', ('%Y-%m-%d', '%m/%d/%Y', '%m/%d/%y', '%b %d %Y',
@@ -728,9 +707,6 @@ system. Note that if :setting:`USE_L10N` is set to ``True``, then the
locale-dictated format has higher precedence and will be applied instead. See locale-dictated format has higher precedence and will be applied instead. See
:tfilter:`allowed date format strings <date>`. :tfilter:`allowed date format strings <date>`.
.. versionchanged:: 1.2
This setting can now be overriden by setting :setting:`USE_L10N` to ``True``.
See also :setting:`DATE_FORMAT`, :setting:`TIME_FORMAT` and :setting:`SHORT_DATETIME_FORMAT`. See also :setting:`DATE_FORMAT`, :setting:`TIME_FORMAT` and :setting:`SHORT_DATETIME_FORMAT`.
.. setting:: DATETIME_INPUT_FORMATS .. setting:: DATETIME_INPUT_FORMATS
@@ -738,8 +714,6 @@ See also :setting:`DATE_FORMAT`, :setting:`TIME_FORMAT` and :setting:`SHORT_DATE
DATETIME_INPUT_FORMATS DATETIME_INPUT_FORMATS
---------------------- ----------------------
.. versionadded:: 1.2
Default:: Default::
('%Y-%m-%d %H:%M:%S', '%Y-%m-%d %H:%M', '%Y-%m-%d', ('%Y-%m-%d %H:%M:%S', '%Y-%m-%d %H:%M', '%Y-%m-%d',
@@ -823,8 +797,6 @@ site.
DECIMAL_SEPARATOR DECIMAL_SEPARATOR
----------------- -----------------
.. versionadded:: 1.2
Default: ``'.'`` (Dot) Default: ``'.'`` (Dot)
Default decimal separator used when formatting decimal numbers. Default decimal separator used when formatting decimal numbers.
@@ -926,8 +898,6 @@ This is only used if ``CommonMiddleware`` is installed (see
EMAIL_BACKEND EMAIL_BACKEND
------------- -------------
.. versionadded:: 1.2
Default: ``'django.core.mail.backends.smtp.EmailBackend'`` Default: ``'django.core.mail.backends.smtp.EmailBackend'``
The backend to use for sending emails. For the list of available backends see The backend to use for sending emails. For the list of available backends see
@@ -938,8 +908,6 @@ The backend to use for sending emails. For the list of available backends see
EMAIL_FILE_PATH EMAIL_FILE_PATH
--------------- ---------------
.. versionadded:: 1.2
Default: Not defined Default: Not defined
The directory used by the ``file`` email backend to store output files. The directory used by the ``file`` email backend to store output files.
@@ -1086,8 +1054,6 @@ See :doc:`/topics/files` for details.
FIRST_DAY_OF_WEEK FIRST_DAY_OF_WEEK
----------------- -----------------
.. versionadded:: 1.2
Default: ``0`` (Sunday) Default: ``0`` (Sunday)
Number representing the first day of the week. This is especially useful Number representing the first day of the week. This is especially useful
@@ -1127,8 +1093,6 @@ of the preferred value or not supplied at all.
FORMAT_MODULE_PATH FORMAT_MODULE_PATH
------------------ ------------------
.. versionadded:: 1.2
Default: ``None`` Default: ``None``
A full Python path to a Python package that contains format definitions for A full Python path to a Python package that contains format definitions for
@@ -1426,8 +1390,6 @@ Example: ``"http://media.example.com/"``
MESSAGE_LEVEL MESSAGE_LEVEL
------------- -------------
.. versionadded:: 1.2
Default: `messages.INFO` Default: `messages.INFO`
Sets the minimum message level that will be recorded by the messages Sets the minimum message level that will be recorded by the messages
@@ -1437,8 +1399,6 @@ more details.
MESSAGE_STORAGE MESSAGE_STORAGE
--------------- ---------------
.. versionadded:: 1.2
Default: ``'django.contrib.messages.storage.user_messages.LegacyFallbackStorage'`` Default: ``'django.contrib.messages.storage.user_messages.LegacyFallbackStorage'``
Controls where Django stores message data. See the Controls where Django stores message data. See the
@@ -1447,8 +1407,6 @@ Controls where Django stores message data. See the
MESSAGE_TAGS MESSAGE_TAGS
------------ ------------
.. versionadded:: 1.2
Default:: Default::
{messages.DEBUG: 'debug', {messages.DEBUG: 'debug',
@@ -1475,11 +1433,6 @@ Default::
A tuple of middleware classes to use. See :doc:`/topics/http/middleware`. A tuple of middleware classes to use. See :doc:`/topics/http/middleware`.
.. versionchanged:: 1.2
``'django.contrib.messages.middleware.MessageMiddleware'`` was added to the
default. For more information, see the :doc:`messages documentation
</ref/contrib/messages>`.
.. setting:: MONTH_DAY_FORMAT .. setting:: MONTH_DAY_FORMAT
MONTH_DAY_FORMAT MONTH_DAY_FORMAT
@@ -1505,8 +1458,6 @@ See :tfilter:`allowed date format strings <date>`. See also
NUMBER_GROUPING NUMBER_GROUPING
---------------- ----------------
.. versionadded:: 1.2
Default: ``0`` Default: ``0``
Number of digits grouped together on the integer part of a number. Number of digits grouped together on the integer part of a number.
@@ -1820,8 +1771,6 @@ Whether to save the session data on every request. See
SHORT_DATE_FORMAT SHORT_DATE_FORMAT
----------------- -----------------
.. versionadded:: 1.2
Default: ``m/d/Y`` (e.g. ``12/31/2003``) Default: ``m/d/Y`` (e.g. ``12/31/2003``)
An available formatting that can be used for displaying date fields on An available formatting that can be used for displaying date fields on
@@ -1836,8 +1785,6 @@ See also :setting:`DATE_FORMAT` and :setting:`SHORT_DATETIME_FORMAT`.
SHORT_DATETIME_FORMAT SHORT_DATETIME_FORMAT
--------------------- ---------------------
.. versionadded:: 1.2
Default: ``m/d/Y P`` (e.g. ``12/31/2003 4 p.m.``) Default: ``m/d/Y P`` (e.g. ``12/31/2003 4 p.m.``)
An available formatting that can be used for displaying datetime fields on An available formatting that can be used for displaying datetime fields on
@@ -1944,16 +1891,6 @@ A tuple of callables that are used to populate the context in ``RequestContext``
These callables take a request object as their argument and return a dictionary These callables take a request object as their argument and return a dictionary
of items to be merged into the context. of items to be merged into the context.
.. versionchanged:: 1.2
``django.contrib.messages.context_processors.messages`` was added to the
default. For more information, see the :doc:`messages documentation
</ref/contrib/messages>`.
.. versionchanged:: 1.2
The auth context processor was moved in this release from its old location
``django.core.context_processors.auth`` to
``django.contrib.auth.context_processors.auth``.
.. versionadded:: 1.3 .. versionadded:: 1.3
The ``django.core.context_processors.static`` context processor The ``django.core.context_processors.static`` context processor
was added in this release. was added in this release.
@@ -2009,12 +1946,6 @@ used instead of a string. The first item in the tuple should be the ``Loader``'s
module, subsequent items are passed to the ``Loader`` during initialization. See module, subsequent items are passed to the ``Loader`` during initialization. See
:doc:`/ref/templates/api`. :doc:`/ref/templates/api`.
.. versionchanged:: 1.2
The class-based API for template loaders was introduced in Django 1.2
although the :setting:`TEMPLATE_LOADERS` setting will accept strings
that specify function-based loaders until compatibility with them is
completely removed in Django 1.4.
.. setting:: TEMPLATE_STRING_IF_INVALID .. setting:: TEMPLATE_STRING_IF_INVALID
TEMPLATE_STRING_IF_INVALID TEMPLATE_STRING_IF_INVALID
@@ -2032,9 +1963,6 @@ TEST_RUNNER
Default: ``'django.test.simple.DjangoTestSuiteRunner'`` Default: ``'django.test.simple.DjangoTestSuiteRunner'``
.. versionchanged:: 1.2
Prior to 1.2, test runners were a function, not a class.
The name of the class to use for starting the test suite. See The name of the class to use for starting the test suite. See
:doc:`/topics/testing`. :doc:`/topics/testing`.
@@ -2045,8 +1973,6 @@ The name of the class to use for starting the test suite. See
THOUSAND_SEPARATOR THOUSAND_SEPARATOR
------------------ ------------------
.. versionadded:: 1.2
Default: ``,`` (Comma) Default: ``,`` (Comma)
Default thousand separator used when formatting numbers. This setting is Default thousand separator used when formatting numbers. This setting is
@@ -2071,9 +1997,6 @@ system. Note that if :setting:`USE_L10N` is set to ``True``, then the
locale-dictated format has higher precedence and will be applied instead. See locale-dictated format has higher precedence and will be applied instead. See
:tfilter:`allowed date format strings <date>`. :tfilter:`allowed date format strings <date>`.
.. versionchanged:: 1.2
This setting can now be overriden by setting :setting:`USE_L10N` to ``True``.
See also :setting:`DATE_FORMAT` and :setting:`DATETIME_FORMAT`. See also :setting:`DATE_FORMAT` and :setting:`DATETIME_FORMAT`.
.. setting:: TIME_INPUT_FORMATS .. setting:: TIME_INPUT_FORMATS
@@ -2081,8 +2004,6 @@ See also :setting:`DATE_FORMAT` and :setting:`DATETIME_FORMAT`.
TIME_INPUT_FORMATS TIME_INPUT_FORMATS
------------------ ------------------
.. versionadded:: 1.2
Default: ``('%H:%M:%S', '%H:%M')`` Default: ``('%H:%M:%S', '%H:%M')``
A tuple of formats that will be accepted when inputting data on a time field. A tuple of formats that will be accepted when inputting data on a time field.
@@ -2104,9 +2025,6 @@ TIME_ZONE
Default: ``'America/Chicago'`` Default: ``'America/Chicago'``
.. versionchanged:: 1.2
``None`` was added as an allowed value.
.. versionchanged:: 1.4 .. versionchanged:: 1.4
The meaning of this setting now depends on the value of :setting:`USE_TZ`. The meaning of this setting now depends on the value of :setting:`USE_TZ`.
@@ -2183,8 +2101,6 @@ See also :setting:`LANGUAGE_CODE`, :setting:`USE_L10N` and :setting:`USE_TZ`.
USE_L10N USE_L10N
-------- --------
.. versionadded:: 1.2
Default: ``False`` Default: ``False``
A boolean that specifies if localized formatting of data will be enabled by A boolean that specifies if localized formatting of data will be enabled by
@@ -2203,8 +2119,6 @@ See also :setting:`LANGUAGE_CODE`, :setting:`USE_I18N` and :setting:`USE_TZ`.
USE_THOUSAND_SEPARATOR USE_THOUSAND_SEPARATOR
---------------------- ----------------------
.. versionadded:: 1.2
Default: ``False`` Default: ``False``
A boolean that specifies whether to display numbers using a thousand separator. A boolean that specifies whether to display numbers using a thousand separator.

View File

@@ -220,8 +220,6 @@ m2m_changed
.. data:: django.db.models.signals.m2m_changed .. data:: django.db.models.signals.m2m_changed
:module: :module:
.. versionadded:: 1.2
Sent when a :class:`ManyToManyField` is changed on a model instance. Sent when a :class:`ManyToManyField` is changed on a model instance.
Strictly speaking, this is not a model signal since it is sent by the Strictly speaking, this is not a model signal since it is sent by the
:class:`ManyToManyField`, but since it complements the :class:`ManyToManyField`, but since it complements the
@@ -544,9 +542,6 @@ connection_created
.. data:: django.db.backends.signals.connection_created .. data:: django.db.backends.signals.connection_created
:module: :module:
.. versionchanged:: 1.2
The connection argument was added
Sent when the database wrapper makes the initial connection to the Sent when the database wrapper makes the initial connection to the
database. This is particularly useful if you'd like to send any post database. This is particularly useful if you'd like to send any post
connection commands to the SQL backend. connection commands to the SQL backend.

View File

@@ -372,22 +372,12 @@ and return a dictionary of items to be merged into the context. By default,
"django.core.context_processors.static", "django.core.context_processors.static",
"django.contrib.messages.context_processors.messages") "django.contrib.messages.context_processors.messages")
.. versionadded:: 1.2
In addition to these, ``RequestContext`` always uses In addition to these, ``RequestContext`` always uses
``django.core.context_processors.csrf``. This is a security ``django.core.context_processors.csrf``. This is a security
related context processor required by the admin and other contrib apps, and, related context processor required by the admin and other contrib apps, and,
in case of accidental misconfiguration, it is deliberately hardcoded in and in case of accidental misconfiguration, it is deliberately hardcoded in and
cannot be turned off by the :setting:`TEMPLATE_CONTEXT_PROCESSORS` setting. cannot be turned off by the :setting:`TEMPLATE_CONTEXT_PROCESSORS` setting.
.. versionadded:: 1.2
The ``'messages'`` context processor was added. For more information, see
the :doc:`messages documentation </ref/contrib/messages>`.
.. versionchanged:: 1.2
The auth context processor was moved in this release from its old location
``django.core.context_processors.auth`` to
``django.contrib.auth.context_processors.auth``.
Each processor is applied in order. That means, if one processor adds a Each processor is applied in order. That means, if one processor adds a
variable to the context and a second processor adds a variable with the same variable to the context and a second processor adds a variable with the same
name, the second will override the first. The default processors are explained name, the second will override the first. The default processors are explained
@@ -447,10 +437,6 @@ If :setting:`TEMPLATE_CONTEXT_PROCESSORS` contains this processor, every
``django.contrib.auth.context_processors.PermWrapper``, representing the ``django.contrib.auth.context_processors.PermWrapper``, representing the
permissions that the currently logged-in user has. permissions that the currently logged-in user has.
.. versionchanged:: 1.2
This context processor was moved in this release from
``django.core.context_processors.auth`` to its current location.
.. versionchanged:: 1.3 .. versionchanged:: 1.3
Prior to version 1.3, ``PermWrapper`` was located in Prior to version 1.3, ``PermWrapper`` was located in
``django.contrib.auth.context_processors``. ``django.contrib.auth.context_processors``.
@@ -503,8 +489,6 @@ value of the :setting:`STATIC_URL` setting.
django.core.context_processors.csrf django.core.context_processors.csrf
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
.. versionadded:: 1.2
This processor adds a token that is needed by the :ttag:`csrf_token` template This processor adds a token that is needed by the :ttag:`csrf_token` template
tag for protection against :doc:`Cross Site Request Forgeries tag for protection against :doc:`Cross Site Request Forgeries
</ref/contrib/csrf>`. </ref/contrib/csrf>`.
@@ -527,15 +511,6 @@ If :setting:`TEMPLATE_CONTEXT_PROCESSORS` contains this processor, every
via the user model (using ``user.message_set.create``) or through via the user model (using ``user.message_set.create``) or through
the :doc:`messages framework </ref/contrib/messages>`. the :doc:`messages framework </ref/contrib/messages>`.
.. versionadded:: 1.2
This template context variable was previously supplied by the ``'auth'``
context processor. For backwards compatibility the ``'auth'`` context
processor will continue to supply the ``messages`` variable until Django
1.4. If you use the ``messages`` variable, your project will work with
either (or both) context processors, but it is recommended to add
``django.contrib.messages.context_processors.messages`` so your project
will be prepared for the future upgrade.
Writing your own context processors Writing your own context processors
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
@@ -657,11 +632,6 @@ by editing your :setting:`TEMPLATE_LOADERS` setting. :setting:`TEMPLATE_LOADERS`
should be a tuple of strings, where each string represents a template loader should be a tuple of strings, where each string represents a template loader
class. Here are the template loaders that come with Django: class. Here are the template loaders that come with Django:
.. versionchanged:: 1.2
Template loaders were based on callables (usually functions) before Django
1.2, starting with the 1.2 release there is a new class-based API, all the
loaders described below implement this new API.
``django.template.loaders.filesystem.Loader`` ``django.template.loaders.filesystem.Loader``
Loads templates from the filesystem, according to :setting:`TEMPLATE_DIRS`. Loads templates from the filesystem, according to :setting:`TEMPLATE_DIRS`.
This loader is enabled by default. This loader is enabled by default.
@@ -800,8 +770,6 @@ and any setting starting with ``TEMPLATE_`` is of obvious interest.
Using an alternative template language Using an alternative template language
====================================== ======================================
.. versionadded:: 1.2
The Django ``Template`` and ``Loader`` classes implement a simple API for The Django ``Template`` and ``Loader`` classes implement a simple API for
loading and rendering templates. By providing some simple wrapper classes that loading and rendering templates. By providing some simple wrapper classes that
implement this API we can use third party template systems like `Jinja2 implement this API we can use third party template systems like `Jinja2

View File

@@ -58,10 +58,8 @@ Ignores everything between ``{% comment %}`` and ``{% endcomment %}``.
csrf_token csrf_token
^^^^^^^^^^ ^^^^^^^^^^
In the Django 1.1.X series, this is a no-op tag that returns an empty string This tag is used for CSRF protection, as described in the documentation for
for future compatibility purposes. In Django 1.2 and later, it is used for :doc:`Cross Site Request Forgeries </ref/contrib/csrf>`.
CSRF protection, as described in the documentation for :doc:`Cross Site Request
Forgeries </ref/contrib/csrf>`.
.. templatetag:: cycle .. templatetag:: cycle
@@ -410,8 +408,6 @@ variables or to negate a given variable::
There are some athletes and absolutely no coaches. There are some athletes and absolutely no coaches.
{% endif %} {% endif %}
.. versionchanged:: 1.2
Use of both ``and`` and ``or`` clauses within the same tag is allowed, with Use of both ``and`` and ``or`` clauses within the same tag is allowed, with
``and`` having higher precedence than ``or`` e.g.:: ``and`` having higher precedence than ``or`` e.g.::
@@ -426,9 +422,6 @@ will be interpreted like:
Use of actual brackets in the :ttag:`if` tag is invalid syntax. If you need Use of actual brackets in the :ttag:`if` tag is invalid syntax. If you need
them to indicate precedence, you should use nested :ttag:`if` tags. them to indicate precedence, you should use nested :ttag:`if` tags.
.. versionadded:: 1.2
:ttag:`if` tags may also use the operators ``==``, ``!=``, ``<``, ``>``, :ttag:`if` tags may also use the operators ``==``, ``!=``, ``<``, ``>``,
``<=``, ``>=`` and ``in`` which work as follows: ``<=``, ``>=`` and ``in`` which work as follows:
@@ -637,7 +630,6 @@ You cannot check for equality with Python objects such as ``True`` or
``False``. If you need to test if something is true or false, use the ``False``. If you need to test if something is true or false, use the
:ttag:`if` tag instead. :ttag:`if` tag instead.
.. versionadded:: 1.2
An alternative to the ``ifequal`` tag is to use the :ttag:`if` tag and the An alternative to the ``ifequal`` tag is to use the :ttag:`if` tag and the
``==`` operator. ``==`` operator.
@@ -649,7 +641,6 @@ ifnotequal
Just like :ttag:`ifequal`, except it tests that the two arguments are not Just like :ttag:`ifequal`, except it tests that the two arguments are not
equal. equal.
.. versionadded:: 1.2
An alternative to the ``ifnotequal`` tag is to use the :ttag:`if` tag and An alternative to the ``ifnotequal`` tag is to use the :ttag:`if` tag and
the ``!=`` operator. the ``!=`` operator.
@@ -1127,9 +1118,6 @@ For example::
If ``value`` is ``4``, then the output will be ``6``. If ``value`` is ``4``, then the output will be ``6``.
.. versionchanged:: 1.2
The following behavior didn't exist in previous Django versions.
This filter will first try to coerce both values to integers. If this fails, This filter will first try to coerce both values to integers. If this fails,
it'll attempt to add the values together anyway. This will work on some data it'll attempt to add the values together anyway. This will work on some data
types (strings, list, etc.) and fail on others. If it fails, the result will types (strings, list, etc.) and fail on others. If it fails, the result will
@@ -1289,10 +1277,6 @@ Z Time zone offset in seconds. The ``-43200`` to ``4320
UTC is always positive. UTC is always positive.
================ ======================================== ===================== ================ ======================================== =====================
.. versionadded:: 1.2
The ``c`` and ``u`` format specification characters were added in Django 1.2.
.. versionadded:: 1.4 .. versionadded:: 1.4
The ``e`` and ``o`` format specification characters were added in Django 1.4. The ``e`` and ``o`` format specification characters were added in Django 1.4.
@@ -1326,9 +1310,6 @@ When used without a format string::
...the formatting string defined in the :setting:`DATE_FORMAT` setting will be ...the formatting string defined in the :setting:`DATE_FORMAT` setting will be
used, without applying any localization. used, without applying any localization.
.. versionchanged:: 1.2
Predefined formats can now be influenced by the current locale.
.. templatefilter:: default .. templatefilter:: default
default default
@@ -1985,9 +1966,6 @@ When used without a format string::
...the formatting string defined in the :setting:`TIME_FORMAT` setting will be ...the formatting string defined in the :setting:`TIME_FORMAT` setting will be
used, without applying any localization. used, without applying any localization.
.. versionchanged:: 1.2
Predefined formats can now be influenced by the current locale.
.. templatefilter:: timesince .. templatefilter:: timesince
timesince timesince

View File

@@ -2,7 +2,6 @@
Validators Validators
========== ==========
.. versionadded:: 1.2
.. module:: django.core.validators .. module:: django.core.validators
:synopsis: Validation utilities and base classes :synopsis: Validation utilities and base classes

View File

@@ -64,11 +64,8 @@ Fields
.. attribute:: models.User.username .. attribute:: models.User.username
Required. 30 characters or fewer. Alphanumeric characters only Required. 30 characters or fewer. Usernames may contain alphanumeric,
(letters, digits and underscores). ``_``, ``@``, ``+``, ``.`` and ``-`` characters.
.. versionchanged:: 1.2
Usernames may now contain ``@``, ``+``, ``.`` and ``-`` characters.
.. attribute:: models.User.first_name .. attribute:: models.User.first_name
@@ -207,8 +204,6 @@ Methods
Returns a set of permission strings that the user has, through his/her Returns a set of permission strings that the user has, through his/her
groups. groups.
.. versionadded:: 1.2
If ``obj`` is passed in, only returns the group permissions for If ``obj`` is passed in, only returns the group permissions for
this specific object. this specific object.
@@ -217,8 +212,6 @@ Methods
Returns a set of permission strings that the user has, both through Returns a set of permission strings that the user has, both through
group and user permissions. group and user permissions.
.. versionadded:: 1.2
If ``obj`` is passed in, only returns the permissions for this If ``obj`` is passed in, only returns the permissions for this
specific object. specific object.
@@ -229,8 +222,6 @@ Methods
`permissions`_ section below). If the user is inactive, this method will `permissions`_ section below). If the user is inactive, this method will
always return ``False``. always return ``False``.
.. versionadded:: 1.2
If ``obj`` is passed in, this method won't check for a permission for If ``obj`` is passed in, this method won't check for a permission for
the model, but for this specific object. the model, but for this specific object.
@@ -241,8 +232,6 @@ Methods
``"<app label>.<permission codename>"``. If the user is inactive, ``"<app label>.<permission codename>"``. If the user is inactive,
this method will always return ``False``. this method will always return ``False``.
.. versionadded:: 1.2
If ``obj`` is passed in, this method won't check for permissions for If ``obj`` is passed in, this method won't check for permissions for
the model, but for the specific object. the model, but for the specific object.
@@ -349,9 +338,6 @@ Django requires add *and* change permissions as a slight security measure.
Changing passwords Changing passwords
~~~~~~~~~~~~~~~~~~ ~~~~~~~~~~~~~~~~~~
.. versionadded:: 1.2
The ``manage.py changepassword`` command was added.
:djadmin:`manage.py changepassword *username* <changepassword>` offers a method :djadmin:`manage.py changepassword *username* <changepassword>` offers a method
of changing a User's password from the command line. It prompts you to of changing a User's password from the command line. It prompts you to
change the password of a given user which you must enter twice. If change the password of a given user which you must enter twice. If
@@ -1046,8 +1032,6 @@ The login_required decorator
{% endblock %} {% endblock %}
.. versionadded:: 1.2
If you are using alternate authentication (see If you are using alternate authentication (see
:ref:`authentication-backends`) you can pass a custom authentication form :ref:`authentication-backends`) you can pass a custom authentication form
to the login view via the ``authentication_form`` parameter. This form must to the login view via the ``authentication_form`` parameter. This form must
@@ -1140,8 +1124,6 @@ includes a few other useful built-in views located in
* ``post_change_redirect``: The URL to redirect to after a successful * ``post_change_redirect``: The URL to redirect to after a successful
password change. password change.
.. versionadded:: 1.2
* ``password_change_form``: A custom "change password" form which must * ``password_change_form``: A custom "change password" form which must
accept a ``user`` keyword argument. The form is responsible for accept a ``user`` keyword argument. The form is responsible for
actually changing the user's password. Defaults to actually changing the user's password. Defaults to
@@ -1899,8 +1881,6 @@ the ``auth_permission`` table most of the time.
Authorization for anonymous users Authorization for anonymous users
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
.. versionchanged:: 1.2
An anonymous user is one that is not authenticated i.e. they have provided no An anonymous user is one that is not authenticated i.e. they have provided no
valid authentication details. However, that does not necessarily mean they are valid authentication details. However, that does not necessarily mean they are
not authorized to do anything. At the most basic level, most Web sites not authorized to do anything. At the most basic level, most Web sites

View File

@@ -83,12 +83,6 @@ two most common are `python-memcached`_ and `pylibmc`_.
.. _`python-memcached`: ftp://ftp.tummy.com/pub/python-memcached/ .. _`python-memcached`: ftp://ftp.tummy.com/pub/python-memcached/
.. _`pylibmc`: http://sendapatch.se/projects/pylibmc/ .. _`pylibmc`: http://sendapatch.se/projects/pylibmc/
.. versionchanged:: 1.2
In Django 1.0 and 1.1, you could also use ``cmemcache`` as a binding.
However, support for this library was deprecated in 1.2 due to
a lack of maintenance on the ``cmemcache`` library itself. Support for
``cmemcache`` will be removed completely in Django 1.4.
.. versionchanged:: 1.3 .. versionchanged:: 1.3
Support for ``pylibmc`` was added. Support for ``pylibmc`` was added.
@@ -493,8 +487,6 @@ more on these decorators.
.. _i18n-cache-key: .. _i18n-cache-key:
.. versionadded:: 1.2
If :setting:`USE_I18N` is set to ``True`` then the generated cache key will If :setting:`USE_I18N` is set to ``True`` then the generated cache key will
include the name of the active :term:`language<language code>` -- see also include the name of the active :term:`language<language code>` -- see also
:ref:`how-django-discovers-language-preference`). This allows you to easily :ref:`how-django-discovers-language-preference`). This allows you to easily
@@ -737,8 +729,6 @@ actually exist in the cache (and haven't expired)::
>>> cache.get_many(['a', 'b', 'c']) >>> cache.get_many(['a', 'b', 'c'])
{'a': 1, 'b': 2, 'c': 3} {'a': 1, 'b': 2, 'c': 3}
.. versionadded:: 1.2
To set multiple values more efficiently, use ``set_many()`` to pass a dictionary To set multiple values more efficiently, use ``set_many()`` to pass a dictionary
of key-value pairs:: of key-value pairs::
@@ -753,15 +743,11 @@ clearing the cache for a particular object::
>>> cache.delete('a') >>> cache.delete('a')
.. versionadded:: 1.2
If you want to clear a bunch of keys at once, ``delete_many()`` can take a list If you want to clear a bunch of keys at once, ``delete_many()`` can take a list
of keys to be cleared:: of keys to be cleared::
>>> cache.delete_many(['a', 'b', 'c']) >>> cache.delete_many(['a', 'b', 'c'])
.. versionadded:: 1.2
Finally, if you want to delete all the keys in the cache, use Finally, if you want to delete all the keys in the cache, use
``cache.clear()``. Be careful with this; ``clear()`` will remove *everything* ``cache.clear()``. Be careful with this; ``clear()`` will remove *everything*
from the cache, not just the keys set by your application. :: from the cache, not just the keys set by your application. ::

View File

@@ -881,8 +881,6 @@ field. This would normally cause a problem in abstract base classes, since the
fields on this class are included into each of the child classes, with exactly fields on this class are included into each of the child classes, with exactly
the same values for the attributes (including :attr:`~django.db.models.ForeignKey.related_name`) each time. the same values for the attributes (including :attr:`~django.db.models.ForeignKey.related_name`) each time.
.. versionchanged:: 1.2
To work around this problem, when you are using :attr:`~django.db.models.ForeignKey.related_name` in an To work around this problem, when you are using :attr:`~django.db.models.ForeignKey.related_name` in an
abstract base class (only), part of the name should contain abstract base class (only), part of the name should contain
``'%(app_label)s'`` and ``'%(class)s'``. ``'%(app_label)s'`` and ``'%(class)s'``.

View File

@@ -2,8 +2,6 @@
Multiple databases Multiple databases
================== ==================
.. versionadded:: 1.2
This topic guide describes Django's support for interacting with This topic guide describes Django's support for interacting with
multiple databases. Most of the rest of Django's documentation assumes multiple databases. Most of the rest of Django's documentation assumes
you are interacting with a single database. If you want to interact you are interacting with a single database. If you want to interact

View File

@@ -18,8 +18,6 @@ __ `executing custom SQL directly`_
Performing raw queries Performing raw queries
====================== ======================
.. versionadded:: 1.2
The ``raw()`` manager method can be used to perform raw SQL queries that The ``raw()`` manager method can be used to perform raw SQL queries that
return model instances: return model instances:

View File

@@ -365,8 +365,6 @@ subtype. For example::
Email backends Email backends
============== ==============
.. versionadded:: 1.2
The actual sending of an email is handled by the email backend. The actual sending of an email is handled by the email backend.
The email backend class has the following methods: The email backend class has the following methods:

View File

@@ -102,15 +102,12 @@ limit the maximum number of empty forms the formset will display::
<tr><th><label for="id_form-0-title">Title:</label></th><td><input type="text" name="form-0-title" id="id_form-0-title" /></td></tr> <tr><th><label for="id_form-0-title">Title:</label></th><td><input type="text" name="form-0-title" id="id_form-0-title" /></td></tr>
<tr><th><label for="id_form-0-pub_date">Pub date:</label></th><td><input type="text" name="form-0-pub_date" id="id_form-0-pub_date" /></td></tr> <tr><th><label for="id_form-0-pub_date">Pub date:</label></th><td><input type="text" name="form-0-pub_date" id="id_form-0-pub_date" /></td></tr>
.. versionchanged:: 1.2
If the value of ``max_num`` is greater than the number of existing If the value of ``max_num`` is greater than the number of existing
objects, up to ``extra`` additional blank forms will be added to the formset, objects, up to ``extra`` additional blank forms will be added to the formset,
so long as the total number of forms does not exceed ``max_num``. so long as the total number of forms does not exceed ``max_num``.
A ``max_num`` value of ``None`` (the default) puts no limit on the number of A ``max_num`` value of ``None`` (the default) puts no limit on the number of
forms displayed. Please note that the default value of ``max_num`` was changed forms displayed.
from ``0`` to ``None`` in version 1.2 to allow ``0`` as a valid value.
Formset validation Formset validation
------------------ ------------------
@@ -210,8 +207,6 @@ pre-filled, and is also used to determine how many forms are required. You
will probably never need to override either of these methods, so please be will probably never need to override either of these methods, so please be
sure you understand what they do before doing so. sure you understand what they do before doing so.
.. versionadded:: 1.2
``empty_form`` ``empty_form``
~~~~~~~~~~~~~~ ~~~~~~~~~~~~~~

View File

@@ -109,9 +109,6 @@ Model field Form field
``URLField`` ``URLField`` ``URLField`` ``URLField``
=============================== ======================================== =============================== ========================================
.. versionadded:: 1.2
The ``BigIntegerField`` is new in Django 1.2.
As you might expect, the ``ForeignKey`` and ``ManyToManyField`` model field As you might expect, the ``ForeignKey`` and ``ManyToManyField`` model field
types are special cases: types are special cases:
@@ -362,9 +359,6 @@ Since the Author model has only 3 fields, 'name', 'title', and
Overriding the default field types or widgets Overriding the default field types or widgets
--------------------------------------------- ---------------------------------------------
.. versionadded:: 1.2
The ``widgets`` attribute is new in Django 1.2.
The default field types, as described in the `Field types`_ table above, are The default field types, as described in the `Field types`_ table above, are
sensible defaults. If you have a ``DateField`` in your model, chances are you'd sensible defaults. If you have a ``DateField`` in your model, chances are you'd
want that to be represented as a ``DateField`` in your form. But want that to be represented as a ``DateField`` in your form. But
@@ -670,8 +664,6 @@ are saved properly.
Limiting the number of editable objects Limiting the number of editable objects
--------------------------------------- ---------------------------------------
.. versionchanged:: 1.2
As with regular formsets, you can use the ``max_num`` and ``extra`` parameters As with regular formsets, you can use the ``max_num`` and ``extra`` parameters
to ``modelformset_factory`` to limit the number of extra forms displayed. to ``modelformset_factory`` to limit the number of extra forms displayed.
@@ -698,8 +690,6 @@ so long as the total number of forms does not exceed ``max_num``::
<tr><th><label for="id_form-2-name">Name:</label></th><td><input id="id_form-2-name" type="text" name="form-2-name" value="Walt Whitman" maxlength="100" /><input type="hidden" name="form-2-id" value="2" id="id_form-2-id" /></td></tr> <tr><th><label for="id_form-2-name">Name:</label></th><td><input id="id_form-2-name" type="text" name="form-2-name" value="Walt Whitman" maxlength="100" /><input type="hidden" name="form-2-id" value="2" id="id_form-2-id" /></td></tr>
<tr><th><label for="id_form-3-name">Name:</label></th><td><input id="id_form-3-name" type="text" name="form-3-name" maxlength="100" /><input type="hidden" name="form-3-id" id="id_form-3-id" /></td></tr> <tr><th><label for="id_form-3-name">Name:</label></th><td><input id="id_form-3-name" type="text" name="form-3-name" maxlength="100" /><input type="hidden" name="form-3-id" id="id_form-3-id" /></td></tr>
.. versionchanged:: 1.2
A ``max_num`` value of ``None`` (the default) puts no limit on the number of A ``max_num`` value of ``None`` (the default) puts no limit on the number of
forms displayed. forms displayed.

View File

@@ -314,9 +314,6 @@ that should be called if none of the URL patterns match.
By default, this is ``'django.views.defaults.page_not_found'``. That default By default, this is ``'django.views.defaults.page_not_found'``. That default
value should suffice. value should suffice.
.. versionchanged:: 1.2
Previous versions of Django only accepted strings representing import paths.
handler500 handler500
---------- ----------
@@ -329,9 +326,6 @@ have runtime errors in view code.
By default, this is ``'django.views.defaults.server_error'``. That default By default, this is ``'django.views.defaults.server_error'``. That default
value should suffice. value should suffice.
.. versionchanged:: 1.2
Previous versions of Django only accepted strings representing import paths.
Notes on capturing text in URLs Notes on capturing text in URLs
=============================== ===============================

View File

@@ -4,8 +4,6 @@
Format localization Format localization
=================== ===================
.. versionadded:: 1.2
Overview Overview
======== ========

View File

@@ -1039,8 +1039,6 @@ Django comes with a tool, :djadmin:`django-admin.py makemessages
commands from the GNU gettext toolset: ``xgettext``, ``msgfmt``, commands from the GNU gettext toolset: ``xgettext``, ``msgfmt``,
``msgmerge`` and ``msguniq``. ``msgmerge`` and ``msguniq``.
.. versionchanged:: 1.2
The minimum version of the ``gettext`` utilities supported is 0.15. The minimum version of the ``gettext`` utilities supported is 0.15.
To create or update a message file, run this command:: To create or update a message file, run this command::

View File

@@ -188,11 +188,6 @@ In particular, :ref:`lazy translation objects <lazy-translations>` need a
Natural keys Natural keys
------------ ------------
.. versionadded:: 1.2
The ability to use natural keys when serializing/deserializing data was
added in the 1.2 release.
The default serialization strategy for foreign keys and many-to-many relations The default serialization strategy for foreign keys and many-to-many relations
is to serialize the value of the primary key(s) of the objects in the relation. is to serialize the value of the primary key(s) of the objects in the relation.
This strategy works well for most objects, but it can cause difficulty in some This strategy works well for most objects, but it can cause difficulty in some

View File

@@ -291,9 +291,6 @@ label::
$ ./manage.py test animals.AnimalTestCase.test_animals_can_speak $ ./manage.py test animals.AnimalTestCase.test_animals_can_speak
.. versionadded:: 1.2
The ability to select individual doctests was added.
You can use the same rules if you're using doctests. Django will use the You can use the same rules if you're using doctests. Django will use the
test label as a path to the test method or class that you want to run. test label as a path to the test method or class that you want to run.
If your ``models.py`` or ``tests.py`` has a function with a doctest, or If your ``models.py`` or ``tests.py`` has a function with a doctest, or
@@ -311,9 +308,6 @@ If you're using a ``__test__`` dictionary to specify doctests for a
module, Django will use the label as a key in the ``__test__`` dictionary module, Django will use the label as a key in the ``__test__`` dictionary
for defined in ``models.py`` and ``tests.py``. for defined in ``models.py`` and ``tests.py``.
.. versionadded:: 1.2
You can now trigger a graceful exit from a test run by pressing ``Ctrl-C``.
If you press ``Ctrl-C`` while the tests are running, the test runner will If you press ``Ctrl-C`` while the tests are running, the test runner will
wait for the currently running test to complete and then exit gracefully. wait for the currently running test to complete and then exit gracefully.
During a graceful exit the test runner will output details of any test During a graceful exit the test runner will output details of any test
@@ -392,8 +386,6 @@ advanced settings.
Testing master/slave configurations Testing master/slave configurations
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
.. versionadded:: 1.2
If you're testing a multiple database configuration with master/slave If you're testing a multiple database configuration with master/slave
replication, this strategy of creating test databases poses a problem. replication, this strategy of creating test databases poses a problem.
When the test databases are created, there won't be any replication, When the test databases are created, there won't be any replication,
@@ -1387,8 +1379,6 @@ Multi-database support
.. attribute:: TestCase.multi_db .. attribute:: TestCase.multi_db
.. versionadded:: 1.2
Django sets up a test database corresponding to every database that is Django sets up a test database corresponding to every database that is
defined in the :setting:`DATABASES` definition in your settings defined in the :setting:`DATABASES` definition in your settings
file. However, a big part of the time taken to run a Django TestCase file. However, a big part of the time taken to run a Django TestCase
@@ -1512,9 +1502,6 @@ Assertions
.. currentmodule:: django.test .. currentmodule:: django.test
.. versionchanged:: 1.2
Added ``msg_prefix`` argument.
As Python's normal :class:`unittest.TestCase` class implements assertion methods As Python's normal :class:`unittest.TestCase` class implements assertion methods
such as :meth:`~unittest.TestCase.assertTrue` and such as :meth:`~unittest.TestCase.assertTrue` and
:meth:`~unittest.TestCase.assertEqual`, Django's custom :class:`TestCase` class :meth:`~unittest.TestCase.assertEqual`, Django's custom :class:`TestCase` class
@@ -2022,9 +2009,6 @@ process to satisfy whatever testing requirements you may have.
Defining a test runner Defining a test runner
---------------------- ----------------------
.. versionchanged:: 1.2
Prior to 1.2, test runners were a single function, not a class.
.. currentmodule:: django.test.simple .. currentmodule:: django.test.simple
A test runner is a class defining a ``run_tests()`` method. Django ships A test runner is a class defining a ``run_tests()`` method. Django ships