mirror of
				https://github.com/django/django.git
				synced 2025-10-25 06:36:07 +00:00 
			
		
		
		
	[1.5.X] Fixed broken links, round 3. refs #19516
Backport of b3a8c9dab8 from master
			
			
This commit is contained in:
		| @@ -95,6 +95,7 @@ intersphinx_mapping = { | |||||||
|     'python': ('http://docs.python.org/2.7', None), |     'python': ('http://docs.python.org/2.7', None), | ||||||
|     'sphinx': ('http://sphinx.pocoo.org/', None), |     'sphinx': ('http://sphinx.pocoo.org/', None), | ||||||
|     'six': ('http://packages.python.org/six/', None), |     'six': ('http://packages.python.org/six/', None), | ||||||
|  |     'simplejson': ('http://simplejson.readthedocs.org/en/latest/', None), | ||||||
| } | } | ||||||
|  |  | ||||||
| # Python's docs don't change every week. | # Python's docs don't change every week. | ||||||
|   | |||||||
| @@ -123,7 +123,7 @@ Error reports are really helpful for debugging errors, so it is generally | |||||||
| useful to record as much relevant information about those errors as possible. | useful to record as much relevant information about those errors as possible. | ||||||
| For example, by default Django records the `full traceback`_ for the | For example, by default Django records the `full traceback`_ for the | ||||||
| exception raised, each `traceback frame`_'s local variables, and the | exception raised, each `traceback frame`_'s local variables, and the | ||||||
| :class:`HttpRequest`'s :ref:`attributes<httprequest-attributes>`. | :class:`~django.http.HttpRequest`'s :ref:`attributes<httprequest-attributes>`. | ||||||
|  |  | ||||||
| However, sometimes certain types of information may be too sensitive and thus | However, sometimes certain types of information may be too sensitive and thus | ||||||
| may not be appropriate to be kept track of, for example a user's password or | may not be appropriate to be kept track of, for example a user's password or | ||||||
| @@ -165,11 +165,11 @@ production environment (that is, where :setting:`DEBUG` is set to ``False``): | |||||||
|  |  | ||||||
| .. function:: sensitive_post_parameters(*parameters) | .. function:: sensitive_post_parameters(*parameters) | ||||||
|  |  | ||||||
|     If one of your views receives an :class:`HttpRequest` object with |     If one of your views receives an :class:`~django.http.HttpRequest` object | ||||||
|     :attr:`POST parameters<HttpRequest.POST>` susceptible to contain sensitive |     with :attr:`POST parameters<django.http.HttpRequest.POST>` susceptible to | ||||||
|     information, you may prevent the values of those parameters from being |     contain sensitive information, you may prevent the values of those | ||||||
|     included in the error reports using the ``sensitive_post_parameters`` |     parameters from being included in the error reports using the | ||||||
|     decorator:: |     ``sensitive_post_parameters`` decorator:: | ||||||
|  |  | ||||||
|         from django.views.decorators.debug import sensitive_post_parameters |         from django.views.decorators.debug import sensitive_post_parameters | ||||||
|  |  | ||||||
| @@ -198,10 +198,10 @@ production environment (that is, where :setting:`DEBUG` is set to ``False``): | |||||||
|     .. versionchanged:: 1.4 |     .. versionchanged:: 1.4 | ||||||
|  |  | ||||||
|     Since version 1.4, all POST parameters are systematically filtered out of |     Since version 1.4, all POST parameters are systematically filtered out of | ||||||
|     error reports for certain :mod:`contrib.views.auth` views (``login``, |     error reports for certain :mod:`django.contrib.auth.views` views ( | ||||||
|     ``password_reset_confirm``, ``password_change``, and ``add_view`` and |     ``login``, ``password_reset_confirm``, ``password_change``, and | ||||||
|     ``user_change_password`` in the ``auth`` admin) to prevent the leaking of |     ``add_view`` and ``user_change_password`` in the ``auth`` admin) to prevent | ||||||
|     sensitive information such as user passwords. |     the leaking of sensitive information such as user passwords. | ||||||
|  |  | ||||||
| .. _custom-error-reports: | .. _custom-error-reports: | ||||||
|  |  | ||||||
|   | |||||||
| @@ -398,9 +398,9 @@ That adds a "Filter" sidebar that lets people filter the change list by the | |||||||
|    :alt: Polls change list page, updated |    :alt: Polls change list page, updated | ||||||
|  |  | ||||||
| The type of filter displayed depends on the type of field you're filtering on. | The type of filter displayed depends on the type of field you're filtering on. | ||||||
| Because ``pub_date`` is a :class:`~django.db.models.fields.DateTimeField`, | Because ``pub_date`` is a :class:`~django.db.models.DateTimeField`, Django | ||||||
| Django knows to give appropriate filter options: "Any date," "Today," "Past 7 | knows to give appropriate filter options: "Any date," "Today," "Past 7 days," | ||||||
| days," "This month," "This year." | "This month," "This year." | ||||||
|  |  | ||||||
| This is shaping up well. Let's add some search capability:: | This is shaping up well. Let's add some search capability:: | ||||||
|  |  | ||||||
|   | |||||||
| @@ -98,9 +98,10 @@ This code includes a few things we haven't covered yet in this tutorial: | |||||||
|   <django.http.HttpRequest.POST>` in our code, to ensure that data is only |   <django.http.HttpRequest.POST>` in our code, to ensure that data is only | ||||||
|   altered via a POST call. |   altered via a POST call. | ||||||
|  |  | ||||||
| * ``request.POST['choice']`` will raise :exc:`KeyError` if ``choice`` wasn't | * ``request.POST['choice']`` will raise :exc:`~exceptions.KeyError` if | ||||||
|   provided in POST data. The above code checks for :exc:`KeyError` and |   ``choice`` wasn't provided in POST data. The above code checks for | ||||||
|   redisplays the poll form with an error message if ``choice`` isn't given. |   :exc:`~exceptions.KeyError` and redisplays the poll form with an error | ||||||
|  |   message if ``choice`` isn't given. | ||||||
|  |  | ||||||
| * After incrementing the choice count, the code returns an | * After incrementing the choice count, the code returns an | ||||||
|   :class:`~django.http.HttpResponseRedirect` rather than a normal |   :class:`~django.http.HttpResponseRedirect` rather than a normal | ||||||
|   | |||||||
| @@ -11,12 +11,12 @@ The built-in comment models | |||||||
|  |  | ||||||
|     .. attribute:: content_object |     .. attribute:: content_object | ||||||
|  |  | ||||||
|         A :class:`~django.contrib.contettypes.generic.GenericForeignKey` |         A :class:`~django.contrib.contenttypes.generic.GenericForeignKey` | ||||||
|         attribute pointing to the object the comment is attached to. You can use |         attribute pointing to the object the comment is attached to. You can use | ||||||
|         this to get at the related object (i.e. ``my_comment.content_object``). |         this to get at the related object (i.e. ``my_comment.content_object``). | ||||||
|  |  | ||||||
|         Since this field is a |         Since this field is a | ||||||
|         :class:`~django.contrib.contettypes.generic.GenericForeignKey`, it's |         :class:`~django.contrib.contenttypes.generic.GenericForeignKey`, it's | ||||||
|         actually syntactic sugar on top of two underlying attributes, described |         actually syntactic sugar on top of two underlying attributes, described | ||||||
|         below. |         below. | ||||||
|  |  | ||||||
| @@ -77,4 +77,3 @@ The built-in comment models | |||||||
|  |  | ||||||
|         ``True`` if the comment was removed. Used to keep track of removed |         ``True`` if the comment was removed. Used to keep track of removed | ||||||
|         comments instead of just deleting them. |         comments instead of just deleting them. | ||||||
|  |  | ||||||
|   | |||||||
| @@ -81,8 +81,8 @@ Built-in moderation options | |||||||
|     .. attribute:: auto_close_field |     .. attribute:: auto_close_field | ||||||
|  |  | ||||||
|         If this is set to the name of a |         If this is set to the name of a | ||||||
|         :class:`~django.db.models.fields.DateField` or |         :class:`~django.db.models.DateField` or | ||||||
|         :class:`~django.db.models.fields.DateTimeField` on the model for which |         :class:`~django.db.models.DateTimeField` on the model for which | ||||||
|         comments are being moderated, new comments for objects of that model |         comments are being moderated, new comments for objects of that model | ||||||
|         will be disallowed (immediately deleted) when a certain number of days |         will be disallowed (immediately deleted) when a certain number of days | ||||||
|         have passed after the date specified in that field. Must be |         have passed after the date specified in that field. Must be | ||||||
| @@ -117,7 +117,7 @@ Built-in moderation options | |||||||
|     .. attribute:: enable_field |     .. attribute:: enable_field | ||||||
|  |  | ||||||
|         If this is set to the name of a |         If this is set to the name of a | ||||||
|         :class:`~django.db.models.fields.BooleanField` on the model |         :class:`~django.db.models.BooleanField` on the model | ||||||
|         for which comments are being moderated, new comments on |         for which comments are being moderated, new comments on | ||||||
|         objects of that model will be disallowed (immediately deleted) |         objects of that model will be disallowed (immediately deleted) | ||||||
|         whenever the value of that field is ``False`` on the object |         whenever the value of that field is ``False`` on the object | ||||||
|   | |||||||
| @@ -234,13 +234,15 @@ lookup:: | |||||||
|  |  | ||||||
| .. versionadded:: 1.5 | .. versionadded:: 1.5 | ||||||
|  |  | ||||||
| Prior to Django 1.5 :meth:`~ContentTypeManager.get_for_model()` and | Prior to Django 1.5, | ||||||
| :meth:`~ContentTypeManager.get_for_models()` always returned the | :meth:`~django.contrib.contenttypes.models.ContentTypeManager.get_for_model` and | ||||||
| :class:`~django.contrib.contenttypes.models.ContentType` associated with the | :meth:`~django.contrib.contenttypes.models.ContentTypeManager.get_for_models` | ||||||
| concrete model of the specified one(s). That means there was no way to retreive | always returned the :class:`~django.contrib.contenttypes.models.ContentType` | ||||||
| the :class:`~django.contrib.contenttypes.models.ContentType` of a proxy model | associated with the concrete model of the specified one(s). That means there | ||||||
|  | was no way to retreive the | ||||||
|  | :class:`~django.contrib.contenttypes.models.ContentType` of a proxy model | ||||||
| using those methods. As of Django 1.5 you can now pass a boolean flag – | using those methods. As of Django 1.5 you can now pass a boolean flag – | ||||||
| respectively ``for_concrete_model`` and ``for_concrete_models`` – to specify | ``for_concrete_model`` and ``for_concrete_models`` respectively – to specify | ||||||
| wether or not you want to retreive the | wether or not you want to retreive the | ||||||
| :class:`~django.contrib.contenttypes.models.ContentType` for the concrete or | :class:`~django.contrib.contenttypes.models.ContentType` for the concrete or | ||||||
| direct model. | direct model. | ||||||
|   | |||||||
| @@ -150,11 +150,11 @@ it's not necessary to include every field in your form. For example:: | |||||||
| These values are only displayed for unbound forms, and they're not used as | These values are only displayed for unbound forms, and they're not used as | ||||||
| fallback values if a particular value isn't provided. | fallback values if a particular value isn't provided. | ||||||
|  |  | ||||||
| Note that if a :class:`~django.forms.fields.Field` defines | Note that if a :class:`~django.forms.Field` defines :attr:`~Form.initial` *and* | ||||||
| :attr:`~Form.initial` *and* you include ``initial`` when instantiating the | you include ``initial`` when instantiating the ``Form``, then the latter | ||||||
| ``Form``, then the latter ``initial`` will have precedence. In this example, | ``initial`` will have precedence. In this example, ``initial`` is provided both | ||||||
| ``initial`` is provided both at the field level and at the form instance level, | at the field level and at the form instance level, and the latter gets | ||||||
| and the latter gets precedence:: | precedence:: | ||||||
|  |  | ||||||
|     >>> class CommentForm(forms.Form): |     >>> class CommentForm(forms.Form): | ||||||
|     ...     name = forms.CharField(initial='class') |     ...     name = forms.CharField(initial='class') | ||||||
|   | |||||||
| @@ -885,7 +885,7 @@ Slightly complex built-in ``Field`` classes | |||||||
|     .. attribute:: MultiValueField.widget |     .. attribute:: MultiValueField.widget | ||||||
|  |  | ||||||
|         Must be a subclass of :class:`django.forms.MultiWidget`. |         Must be a subclass of :class:`django.forms.MultiWidget`. | ||||||
|         Default value is :class:`~django.forms.widgets.TextInput`, which |         Default value is :class:`~django.forms.TextInput`, which | ||||||
|         probably is not very useful in this case. |         probably is not very useful in this case. | ||||||
|  |  | ||||||
|     .. method:: compress(data_list) |     .. method:: compress(data_list) | ||||||
|   | |||||||
| @@ -49,8 +49,8 @@ Setting arguments for widgets | |||||||
|  |  | ||||||
| Many widgets have optional extra arguments; they can be set when defining the | Many widgets have optional extra arguments; they can be set when defining the | ||||||
| widget on the field. In the following example, the | widget on the field. In the following example, the | ||||||
| :attr:`~SelectDateWidget.years` attribute is set for a | :attr:`~django.forms.extras.widgets.SelectDateWidget.years` attribute is set | ||||||
| :class:`~django.forms.extras.widgets.SelectDateWidget`:: | for a :class:`~django.forms.extras.widgets.SelectDateWidget`:: | ||||||
|  |  | ||||||
|     from django.forms.fields import DateField, ChoiceField, MultipleChoiceField |     from django.forms.fields import DateField, ChoiceField, MultipleChoiceField | ||||||
|     from django.forms.widgets import RadioSelect, CheckboxSelectMultiple |     from django.forms.widgets import RadioSelect, CheckboxSelectMultiple | ||||||
| @@ -222,7 +222,7 @@ foundation for custom widgets. | |||||||
| .. class:: MultiWidget(widgets, attrs=None) | .. class:: MultiWidget(widgets, attrs=None) | ||||||
|  |  | ||||||
|     A widget that is composed of multiple widgets. |     A widget that is composed of multiple widgets. | ||||||
|     :class:`~django.forms.widgets.MultiWidget` works hand in hand with the |     :class:`~django.forms.MultiWidget` works hand in hand with the | ||||||
|     :class:`~django.forms.MultiValueField`. |     :class:`~django.forms.MultiValueField`. | ||||||
|  |  | ||||||
|     :class:`MultiWidget` has one required argument: |     :class:`MultiWidget` has one required argument: | ||||||
| @@ -246,8 +246,8 @@ foundation for custom widgets. | |||||||
|         the combined value of the form field into the values for each widget. |         the combined value of the form field into the values for each widget. | ||||||
|  |  | ||||||
|         An example of this is how :class:`SplitDateTimeWidget` turns a |         An example of this is how :class:`SplitDateTimeWidget` turns a | ||||||
|         :class:`datetime` value into a list with date and time split into two |         :class:`~datetime.datetime` value into a list with date and time split | ||||||
|         separate values:: |         into two separate values:: | ||||||
|  |  | ||||||
|             class SplitDateTimeWidget(MultiWidget): |             class SplitDateTimeWidget(MultiWidget): | ||||||
|  |  | ||||||
|   | |||||||
| @@ -547,8 +547,7 @@ Also has one optional argument: | |||||||
|     Optional. A storage object, which handles the storage and retrieval of your |     Optional. A storage object, which handles the storage and retrieval of your | ||||||
|     files. See :doc:`/topics/files` for details on how to provide this object. |     files. See :doc:`/topics/files` for details on how to provide this object. | ||||||
|  |  | ||||||
| The default form widget for this field is a | The default form widget for this field is a :class:`~django.forms.FileInput`. | ||||||
| :class:`~django.forms.widgets.FileInput`. |  | ||||||
|  |  | ||||||
| Using a :class:`FileField` or an :class:`ImageField` (see below) in a model | Using a :class:`FileField` or an :class:`ImageField` (see below) in a model | ||||||
| takes a few steps: | takes a few steps: | ||||||
| @@ -590,7 +589,7 @@ topic guide. | |||||||
|     saved. |     saved. | ||||||
|  |  | ||||||
| The uploaded file's relative URL can be obtained using the | The uploaded file's relative URL can be obtained using the | ||||||
| :attr:`~django.db.models.fields.FileField.url` attribute. Internally, | :attr:`~django.db.models.FileField.url` attribute. Internally, | ||||||
| this calls the :meth:`~django.core.files.storage.Storage.url` method of the | this calls the :meth:`~django.core.files.storage.Storage.url` method of the | ||||||
| underlying :class:`~django.core.files.storage.Storage` class. | underlying :class:`~django.core.files.storage.Storage` class. | ||||||
|  |  | ||||||
|   | |||||||
| @@ -659,7 +659,7 @@ For every :class:`~django.db.models.DateField` and | |||||||
| <django.db.models.Field.null>`, the object will have ``get_next_by_FOO()`` and | <django.db.models.Field.null>`, the object will have ``get_next_by_FOO()`` and | ||||||
| ``get_previous_by_FOO()`` methods, where ``FOO`` is the name of the field. This | ``get_previous_by_FOO()`` methods, where ``FOO`` is the name of the field. This | ||||||
| returns the next and previous object with respect to the date field, raising | returns the next and previous object with respect to the date field, raising | ||||||
| a :exc:`~django.db.DoesNotExist` exception when appropriate. | a :exc:`~django.core.exceptions.DoesNotExist` exception when appropriate. | ||||||
|  |  | ||||||
| Both methods accept optional keyword arguments, which should be in the format | Both methods accept optional keyword arguments, which should be in the format | ||||||
| described in :ref:`Field lookups <field-lookups>`. | described in :ref:`Field lookups <field-lookups>`. | ||||||
|   | |||||||
| @@ -1112,9 +1112,9 @@ one, doing so will result in an error. | |||||||
|  |  | ||||||
| .. note:: | .. note:: | ||||||
|  |  | ||||||
|     When calling :meth:`~Model.save()` for instances with deferred fields, |     When calling :meth:`~django.db.models.Model.save()` for instances with | ||||||
|     only the loaded fields will be saved. See :meth:`~Model.save()` for more |     deferred fields, only the loaded fields will be saved. See | ||||||
|     details. |     :meth:`~django.db.models.Model.save()` for more details. | ||||||
|  |  | ||||||
|  |  | ||||||
| only | only | ||||||
| @@ -1164,9 +1164,9 @@ using :meth:`select_related` is an error as well. | |||||||
|  |  | ||||||
| .. note:: | .. note:: | ||||||
|  |  | ||||||
|     When calling :meth:`~Model.save()` for instances with deferred fields, |     When calling :meth:`~django.db.models.Model.save()` for instances with | ||||||
|     only the loaded fields will be saved. See :meth:`~Model.save()` for more |     deferred fields, only the loaded fields will be saved. See | ||||||
|     details. |     :meth:`~django.db.models.Model.save()` for more details. | ||||||
|  |  | ||||||
| using | using | ||||||
| ~~~~~ | ~~~~~ | ||||||
| @@ -1248,7 +1248,7 @@ the format described in `Field lookups`_. | |||||||
|  |  | ||||||
| ``get()`` raises :exc:`~django.core.exceptions.MultipleObjectsReturned` if more | ``get()`` raises :exc:`~django.core.exceptions.MultipleObjectsReturned` if more | ||||||
| than one object was found. The | than one object was found. The | ||||||
| :exc:`~django.core.excpetions.MultipleObjectsReturned` exception is an | :exc:`~django.core.exceptions.MultipleObjectsReturned` exception is an | ||||||
| attribute of the model class. | attribute of the model class. | ||||||
|  |  | ||||||
| ``get()`` raises a :exc:`~django.core.exceptions.DoesNotExist` exception if an | ``get()`` raises a :exc:`~django.core.exceptions.DoesNotExist` exception if an | ||||||
|   | |||||||
| @@ -212,24 +212,24 @@ m2m_changed | |||||||
| .. data:: django.db.models.signals.m2m_changed | .. data:: django.db.models.signals.m2m_changed | ||||||
|    :module: |    :module: | ||||||
|  |  | ||||||
| Sent when a :class:`ManyToManyField` is changed on a model instance. | Sent when a :class:`~django.db.models.ManyToManyField` is changed on a model | ||||||
| Strictly speaking, this is not a model signal since it is sent by the | instance. Strictly speaking, this is not a model signal since it is sent by the | ||||||
| :class:`ManyToManyField`, but since it complements the | :class:`~django.db.models.ManyToManyField`, but since it complements the | ||||||
| :data:`pre_save`/:data:`post_save` and :data:`pre_delete`/:data:`post_delete` | :data:`pre_save`/:data:`post_save` and :data:`pre_delete`/:data:`post_delete` | ||||||
| when it comes to tracking changes to models, it is included here. | when it comes to tracking changes to models, it is included here. | ||||||
|  |  | ||||||
| Arguments sent with this signal: | Arguments sent with this signal: | ||||||
|  |  | ||||||
| ``sender`` | ``sender`` | ||||||
|     The intermediate model class describing the :class:`ManyToManyField`. |     The intermediate model class describing the | ||||||
|     This class is automatically created when a many-to-many field is |     :class:`~django.db.models.ManyToManyField`. This class is automatically | ||||||
|     defined; you can access it using the ``through`` attribute on the |     created when a many-to-many field is defined; you can access it using the | ||||||
|     many-to-many field. |     ``through`` attribute on the many-to-many field. | ||||||
|  |  | ||||||
| ``instance`` | ``instance`` | ||||||
|     The instance whose many-to-many relation is updated. This can be an |     The instance whose many-to-many relation is updated. This can be an | ||||||
|     instance of the ``sender``, or of the class the :class:`ManyToManyField` |     instance of the ``sender``, or of the class the | ||||||
|     is related to. |     :class:`~django.db.models.ManyToManyField` is related to. | ||||||
|  |  | ||||||
| ``action`` | ``action`` | ||||||
|     A string indicating the type of update that is done on the relation. |     A string indicating the type of update that is done on the relation. | ||||||
| @@ -303,8 +303,9 @@ Argument        Value | |||||||
|  |  | ||||||
| ``action``      ``"pre_add"`` (followed by a separate signal with ``"post_add"``) | ``action``      ``"pre_add"`` (followed by a separate signal with ``"post_add"``) | ||||||
|  |  | ||||||
| ``reverse``     ``False`` (``Pizza`` contains the :class:`ManyToManyField`, | ``reverse``     ``False`` (``Pizza`` contains the | ||||||
|                 so this call modifies the forward relation) |                 :class:`~django.db.models.ManyToManyField`, so this call | ||||||
|  |                 modifies the forward relation) | ||||||
|  |  | ||||||
| ``model``       ``Topping`` (the class of the objects added to the | ``model``       ``Topping`` (the class of the objects added to the | ||||||
|                 ``Pizza``) |                 ``Pizza``) | ||||||
| @@ -329,8 +330,9 @@ Argument        Value | |||||||
|  |  | ||||||
| ``action``      ``"pre_remove"`` (followed by a separate signal with ``"post_remove"``) | ``action``      ``"pre_remove"`` (followed by a separate signal with ``"post_remove"``) | ||||||
|  |  | ||||||
| ``reverse``     ``True`` (``Pizza`` contains the :class:`ManyToManyField`, | ``reverse``     ``True`` (``Pizza`` contains the | ||||||
|                 so this call modifies the reverse relation) |                 :class:`~django.db.models.ManyToManyField`, so this call | ||||||
|  |                 modifies the reverse relation) | ||||||
|  |  | ||||||
| ``model``       ``Pizza`` (the class of the objects removed from the | ``model``       ``Pizza`` (the class of the objects removed from the | ||||||
|                 ``Topping``) |                 ``Topping``) | ||||||
|   | |||||||
| @@ -857,7 +857,7 @@ an attribute "description," you could use:: | |||||||
|     {% regroup cities by country.description as country_list %} |     {% regroup cities by country.description as country_list %} | ||||||
|  |  | ||||||
| Or, if ``country`` is a field with ``choices``, it will have a | Or, if ``country`` is a field with ``choices``, it will have a | ||||||
| :meth:`^django.db.models.Model.get_FOO_display` method available as an | :meth:`~django.db.models.Model.get_FOO_display` method available as an | ||||||
| attribute, allowing  you to group on the display string rather than the | attribute, allowing  you to group on the display string rather than the | ||||||
| ``choices`` key:: | ``choices`` key:: | ||||||
|  |  | ||||||
|   | |||||||
| @@ -145,8 +145,8 @@ results. Instead do:: | |||||||
|  |  | ||||||
| The functions defined in this module share the following properties: | The functions defined in this module share the following properties: | ||||||
|  |  | ||||||
| - They raise :exc:`ValueError` if their input is well formatted but isn't a | - They raise :exc:`~exceptions.ValueError` if their input is well formatted but | ||||||
|   valid date or time. |   isn't a valid date or time. | ||||||
| - They return ``None`` if it isn't well formatted at all. | - They return ``None`` if it isn't well formatted at all. | ||||||
| - They accept up to picosecond resolution in input, but they truncate it to | - They accept up to picosecond resolution in input, but they truncate it to | ||||||
|   microseconds, since that's what Python supports. |   microseconds, since that's what Python supports. | ||||||
|   | |||||||
| @@ -439,9 +439,10 @@ Settings | |||||||
| Better exceptions | Better exceptions | ||||||
| ~~~~~~~~~~~~~~~~~ | ~~~~~~~~~~~~~~~~~ | ||||||
|  |  | ||||||
| The old :exc:`EnvironmentError` has split into an :exc:`ImportError` when | The old :exc:`~exceptions.EnvironmentError` has split into an | ||||||
| Django fails to find the settings module and a :exc:`RuntimeError` when you try | :exc:`~exceptions.ImportError` when Django fails to find the settings module | ||||||
| to reconfigure settings after having already used them | and a :exc:`~exceptions.RuntimeError` when you try to reconfigure settings | ||||||
|  | after having already used them. | ||||||
|  |  | ||||||
| :setting:`LOGIN_URL` has moved | :setting:`LOGIN_URL` has moved | ||||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||||
| @@ -476,8 +477,8 @@ Smaller model changes | |||||||
| Different exception from ``get()`` | Different exception from ``get()`` | ||||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||||
|  |  | ||||||
| Managers now return a :exc:`MultipleObjectsReturned` exception | Managers now return a :exc:`~django.core.exceptions.MultipleObjectsReturned` | ||||||
| instead of :exc:`AssertionError`: | exception instead of :exc:`~exceptions.AssertionError`: | ||||||
|  |  | ||||||
| Old (0.96):: | Old (0.96):: | ||||||
|  |  | ||||||
|   | |||||||
| @@ -132,7 +132,7 @@ public methods. | |||||||
| Fixed the ``join`` filter's escaping behavior | Fixed the ``join`` filter's escaping behavior | ||||||
| --------------------------------------------- | --------------------------------------------- | ||||||
|  |  | ||||||
| The :ttag:`join` filter no longer escapes the literal value that is | The :tfilter:`join` filter no longer escapes the literal value that is | ||||||
| passed in for the connector. | passed in for the connector. | ||||||
|  |  | ||||||
| This is backwards incompatible for the special situation of the literal string | This is backwards incompatible for the special situation of the literal string | ||||||
|   | |||||||
| @@ -156,7 +156,7 @@ requests. These include: | |||||||
|   requests in tests. |   requests in tests. | ||||||
|  |  | ||||||
| * A new test assertion -- | * A new test assertion -- | ||||||
|   :meth:`~django.test.client.Client.assertNumQueries` -- making it |   :meth:`~django.test.TestCase.assertNumQueries` -- making it | ||||||
|   easier to test the database activity associated with a view. |   easier to test the database activity associated with a view. | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
| @@ -357,8 +357,8 @@ Extended IPv6 support | |||||||
|  |  | ||||||
| The previously added support for IPv6 addresses when using the runserver | The previously added support for IPv6 addresses when using the runserver | ||||||
| management command in Django 1.3 has now been further extended by adding | management command in Django 1.3 has now been further extended by adding | ||||||
| a :class:`~django.db.models.fields.GenericIPAddressField` model field, | a :class:`~django.db.models.GenericIPAddressField` model field, | ||||||
| a :class:`~django.forms.fields.GenericIPAddressField` form field and | a :class:`~django.forms.GenericIPAddressField` form field and | ||||||
| the validators :data:`~django.core.validators.validate_ipv46_address` and | the validators :data:`~django.core.validators.validate_ipv46_address` and | ||||||
| :data:`~django.core.validators.validate_ipv6_address` | :data:`~django.core.validators.validate_ipv6_address` | ||||||
|  |  | ||||||
|   | |||||||
| @@ -395,8 +395,8 @@ Extended IPv6 support | |||||||
|  |  | ||||||
| The previously added support for IPv6 addresses when using the runserver | The previously added support for IPv6 addresses when using the runserver | ||||||
| management command in Django 1.3 has now been further extended by adding | management command in Django 1.3 has now been further extended by adding | ||||||
| a :class:`~django.db.models.fields.GenericIPAddressField` model field, | a :class:`~django.db.models.GenericIPAddressField` model field, | ||||||
| a :class:`~django.forms.fields.GenericIPAddressField` form field and | a :class:`~django.forms.GenericIPAddressField` form field and | ||||||
| the validators :data:`~django.core.validators.validate_ipv46_address` and | the validators :data:`~django.core.validators.validate_ipv46_address` and | ||||||
| :data:`~django.core.validators.validate_ipv6_address` | :data:`~django.core.validators.validate_ipv6_address` | ||||||
|  |  | ||||||
|   | |||||||
| @@ -526,8 +526,8 @@ Extended IPv6 support | |||||||
| ~~~~~~~~~~~~~~~~~~~~~ | ~~~~~~~~~~~~~~~~~~~~~ | ||||||
|  |  | ||||||
| Django 1.4 can now better handle IPv6 addresses with the new | Django 1.4 can now better handle IPv6 addresses with the new | ||||||
| :class:`~django.db.models.fields.GenericIPAddressField` model field, | :class:`~django.db.models.GenericIPAddressField` model field, | ||||||
| :class:`~django.forms.fields.GenericIPAddressField` form field and | :class:`~django.forms.GenericIPAddressField` form field and | ||||||
| the validators :data:`~django.core.validators.validate_ipv46_address` and | the validators :data:`~django.core.validators.validate_ipv46_address` and | ||||||
| :data:`~django.core.validators.validate_ipv6_address`. | :data:`~django.core.validators.validate_ipv6_address`. | ||||||
|  |  | ||||||
| @@ -890,7 +890,7 @@ object, Django raises an exception. | |||||||
|  |  | ||||||
| The MySQL backend historically has raised :class:`MySQLdb.OperationalError` | The MySQL backend historically has raised :class:`MySQLdb.OperationalError` | ||||||
| when a query triggered an exception. We've fixed this bug, and we now raise | when a query triggered an exception. We've fixed this bug, and we now raise | ||||||
| :class:`django.db.utils.DatabaseError` instead. If you were testing for | :exc:`django.db.DatabaseError` instead. If you were testing for | ||||||
| :class:`MySQLdb.OperationalError`, you'll need to update your ``except`` | :class:`MySQLdb.OperationalError`, you'll need to update your ``except`` | ||||||
| clauses. | clauses. | ||||||
|  |  | ||||||
| @@ -1092,8 +1092,8 @@ wild, because they would confuse browsers too. | |||||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||||
|  |  | ||||||
| It's now possible to check whether a template was used within a block of | It's now possible to check whether a template was used within a block of | ||||||
| code with :meth:`~django.test.test.TestCase.assertTemplateUsed` and | code with :meth:`~django.test.TestCase.assertTemplateUsed` and | ||||||
| :meth:`~django.test.test.TestCase.assertTemplateNotUsed`. And they | :meth:`~django.test.TestCase.assertTemplateNotUsed`. And they | ||||||
| can be used as a context manager:: | can be used as a context manager:: | ||||||
|  |  | ||||||
|     with self.assertTemplateUsed('index.html'): |     with self.assertTemplateUsed('index.html'): | ||||||
|   | |||||||
| @@ -391,12 +391,12 @@ System version of :mod:`simplejson` no longer used | |||||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||||
|  |  | ||||||
| As explained below, Django 1.5 deprecates | As explained below, Django 1.5 deprecates | ||||||
| :mod:`django.utils.simplejson` in favor of Python 2.6's built-in :mod:`json` | ``django.utils.simplejson`` in favor of Python 2.6's built-in :mod:`json` | ||||||
| module. In theory, this change is harmless. Unfortunately, because of | module. In theory, this change is harmless. Unfortunately, because of | ||||||
| incompatibilities between versions of :mod:`simplejson`, it may trigger errors | incompatibilities between versions of :mod:`simplejson`, it may trigger errors | ||||||
| in some circumstances. | in some circumstances. | ||||||
|  |  | ||||||
| JSON-related features in Django 1.4 always used :mod:`django.utils.simplejson`. | JSON-related features in Django 1.4 always used ``django.utils.simplejson``. | ||||||
| This module was actually: | This module was actually: | ||||||
|  |  | ||||||
| - A system version of :mod:`simplejson`, if one was available (ie. ``import | - A system version of :mod:`simplejson`, if one was available (ie. ``import | ||||||
| @@ -546,8 +546,9 @@ Miscellaneous | |||||||
| * :class:`django.forms.ModelMultipleChoiceField` now returns an empty | * :class:`django.forms.ModelMultipleChoiceField` now returns an empty | ||||||
|   ``QuerySet`` as the empty value instead of an empty list. |   ``QuerySet`` as the empty value instead of an empty list. | ||||||
|  |  | ||||||
| * :func:`~django.utils.http.int_to_base36` properly raises a :exc:`TypeError` | * :func:`~django.utils.http.int_to_base36` properly raises a | ||||||
|   instead of :exc:`ValueError` for non-integer inputs. |   :exc:`~exceptions.TypeError` instead of :exc:`~exceptions.ValueError` for | ||||||
|  |   non-integer inputs. | ||||||
|  |  | ||||||
| * The ``slugify`` template filter is now available as a standard python | * The ``slugify`` template filter is now available as a standard python | ||||||
|   function at :func:`django.utils.text.slugify`. Similarly, ``remove_tags`` is |   function at :func:`django.utils.text.slugify`. Similarly, ``remove_tags`` is | ||||||
| @@ -584,8 +585,8 @@ the :setting:`AUTH_PROFILE_MODULE` setting, and the | |||||||
| :meth:`~django.contrib.auth.models.User.get_profile()` method for accessing | :meth:`~django.contrib.auth.models.User.get_profile()` method for accessing | ||||||
| the user profile model, should not be used any longer. | the user profile model, should not be used any longer. | ||||||
|  |  | ||||||
| Streaming behavior of :class:`HttpResponse` | Streaming behavior of :class:`~django.http.HttpResponse` | ||||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||||
|  |  | ||||||
| Django 1.5 deprecates the ability to stream a response by passing an iterator | Django 1.5 deprecates the ability to stream a response by passing an iterator | ||||||
| to :class:`~django.http.HttpResponse`. If you rely on this behavior, switch to | to :class:`~django.http.HttpResponse`. If you rely on this behavior, switch to | ||||||
| @@ -600,7 +601,7 @@ In Django 1.7 and above, the iterator will be consumed immediately by | |||||||
| Since Django 1.5 drops support for Python 2.5, we can now rely on the | Since Django 1.5 drops support for Python 2.5, we can now rely on the | ||||||
| :mod:`json` module being available in Python's standard library, so we've | :mod:`json` module being available in Python's standard library, so we've | ||||||
| removed our own copy of :mod:`simplejson`. You should now import :mod:`json` | removed our own copy of :mod:`simplejson`. You should now import :mod:`json` | ||||||
| instead :mod:`django.utils.simplejson`. | instead of ``django.utils.simplejson``. | ||||||
|  |  | ||||||
| Unfortunately, this change might have unwanted side-effects, because of | Unfortunately, this change might have unwanted side-effects, because of | ||||||
| incompatibilities between versions of :mod:`simplejson` -- see the backwards- | incompatibilities between versions of :mod:`simplejson` -- see the backwards- | ||||||
|   | |||||||
| @@ -416,12 +416,12 @@ System version of :mod:`simplejson` no longer used | |||||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||||
|  |  | ||||||
| :ref:`As explained below <simplejson-deprecation-beta-1>`, Django 1.5 deprecates | :ref:`As explained below <simplejson-deprecation-beta-1>`, Django 1.5 deprecates | ||||||
| :mod:`django.utils.simplejson` in favor of Python 2.6's built-in :mod:`json` | ``django.utils.simplejson`` in favor of Python 2.6's built-in :mod:`json` | ||||||
| module. In theory, this change is harmless. Unfortunately, because of | module. In theory, this change is harmless. Unfortunately, because of | ||||||
| incompatibilities between versions of :mod:`simplejson`, it may trigger errors | incompatibilities between versions of :mod:`simplejson`, it may trigger errors | ||||||
| in some circumstances. | in some circumstances. | ||||||
|  |  | ||||||
| JSON-related features in Django 1.4 always used :mod:`django.utils.simplejson`. | JSON-related features in Django 1.4 always used ``django.utils.simplejson``. | ||||||
| This module was actually: | This module was actually: | ||||||
|  |  | ||||||
| - A system version of :mod:`simplejson`, if one was available (ie. ``import | - A system version of :mod:`simplejson`, if one was available (ie. ``import | ||||||
| @@ -585,8 +585,9 @@ Miscellaneous | |||||||
| * :class:`django.forms.ModelMultipleChoiceField` now returns an empty | * :class:`django.forms.ModelMultipleChoiceField` now returns an empty | ||||||
|   ``QuerySet`` as the empty value instead of an empty list. |   ``QuerySet`` as the empty value instead of an empty list. | ||||||
|  |  | ||||||
| * :func:`~django.utils.http.int_to_base36` properly raises a :exc:`TypeError` | * :func:`~django.utils.http.int_to_base36` properly raises a | ||||||
|   instead of :exc:`ValueError` for non-integer inputs. |   :exc:`~exceptions.TypeError` instead of :exc:`~exceptions.ValueError` for | ||||||
|  |   non-integer inputs. | ||||||
|  |  | ||||||
| * The ``slugify`` template filter is now available as a standard python | * The ``slugify`` template filter is now available as a standard python | ||||||
|   function at :func:`django.utils.text.slugify`. Similarly, ``remove_tags`` is |   function at :func:`django.utils.text.slugify`. Similarly, ``remove_tags`` is | ||||||
| @@ -636,8 +637,8 @@ the :setting:`AUTH_PROFILE_MODULE` setting, and the | |||||||
| :meth:`~django.contrib.auth.models.User.get_profile()` method for accessing | :meth:`~django.contrib.auth.models.User.get_profile()` method for accessing | ||||||
| the user profile model, should not be used any longer. | the user profile model, should not be used any longer. | ||||||
|  |  | ||||||
| Streaming behavior of :class:`HttpResponse` | Streaming behavior of :class:`~django.http.HttpResponse` | ||||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||||
|  |  | ||||||
| Django 1.5 deprecates the ability to stream a response by passing an iterator | Django 1.5 deprecates the ability to stream a response by passing an iterator | ||||||
| to :class:`~django.http.HttpResponse`. If you rely on this behavior, switch to | to :class:`~django.http.HttpResponse`. If you rely on this behavior, switch to | ||||||
| @@ -653,7 +654,7 @@ In Django 1.7 and above, the iterator will be consumed immediately by | |||||||
| Since Django 1.5 drops support for Python 2.5, we can now rely on the | Since Django 1.5 drops support for Python 2.5, we can now rely on the | ||||||
| :mod:`json` module being available in Python's standard library, so we've | :mod:`json` module being available in Python's standard library, so we've | ||||||
| removed our own copy of :mod:`simplejson`. You should now import :mod:`json` | removed our own copy of :mod:`simplejson`. You should now import :mod:`json` | ||||||
| instead :mod:`django.utils.simplejson`. | instead of ``django.utils.simplejson``. | ||||||
|  |  | ||||||
| Unfortunately, this change might have unwanted side-effects, because of | Unfortunately, this change might have unwanted side-effects, because of | ||||||
| incompatibilities between versions of :mod:`simplejson` -- see the | incompatibilities between versions of :mod:`simplejson` -- see the | ||||||
|   | |||||||
| @@ -429,12 +429,12 @@ System version of :mod:`simplejson` no longer used | |||||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||||
|  |  | ||||||
| :ref:`As explained below <simplejson-deprecation>`, Django 1.5 deprecates | :ref:`As explained below <simplejson-deprecation>`, Django 1.5 deprecates | ||||||
| :mod:`django.utils.simplejson` in favor of Python 2.6's built-in :mod:`json` | ``django.utils.simplejson`` in favor of Python 2.6's built-in :mod:`json` | ||||||
| module. In theory, this change is harmless. Unfortunately, because of | module. In theory, this change is harmless. Unfortunately, because of | ||||||
| incompatibilities between versions of :mod:`simplejson`, it may trigger errors | incompatibilities between versions of :mod:`simplejson`, it may trigger errors | ||||||
| in some circumstances. | in some circumstances. | ||||||
|  |  | ||||||
| JSON-related features in Django 1.4 always used :mod:`django.utils.simplejson`. | JSON-related features in Django 1.4 always used ``django.utils.simplejson``. | ||||||
| This module was actually: | This module was actually: | ||||||
|  |  | ||||||
| - A system version of :mod:`simplejson`, if one was available (ie. ``import | - A system version of :mod:`simplejson`, if one was available (ie. ``import | ||||||
| @@ -598,8 +598,9 @@ Miscellaneous | |||||||
| * :class:`django.forms.ModelMultipleChoiceField` now returns an empty | * :class:`django.forms.ModelMultipleChoiceField` now returns an empty | ||||||
|   ``QuerySet`` as the empty value instead of an empty list. |   ``QuerySet`` as the empty value instead of an empty list. | ||||||
|  |  | ||||||
| * :func:`~django.utils.http.int_to_base36` properly raises a :exc:`TypeError` | * :func:`~django.utils.http.int_to_base36` properly raises a | ||||||
|   instead of :exc:`ValueError` for non-integer inputs. |   :exc:`~exceptions.TypeError` instead of :exc:`~exceptions.ValueError` for | ||||||
|  |   non-integer inputs. | ||||||
|  |  | ||||||
| * The ``slugify`` template filter is now available as a standard python | * The ``slugify`` template filter is now available as a standard python | ||||||
|   function at :func:`django.utils.text.slugify`. Similarly, ``remove_tags`` is |   function at :func:`django.utils.text.slugify`. Similarly, ``remove_tags`` is | ||||||
| @@ -668,8 +669,8 @@ the :setting:`AUTH_PROFILE_MODULE` setting, and the | |||||||
| :meth:`~django.contrib.auth.models.User.get_profile()` method for accessing | :meth:`~django.contrib.auth.models.User.get_profile()` method for accessing | ||||||
| the user profile model, should not be used any longer. | the user profile model, should not be used any longer. | ||||||
|  |  | ||||||
| Streaming behavior of :class:`HttpResponse` | Streaming behavior of :class:`~django.http.HttpResponse` | ||||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||||
|  |  | ||||||
| Django 1.5 deprecates the ability to stream a response by passing an iterator | Django 1.5 deprecates the ability to stream a response by passing an iterator | ||||||
| to :class:`~django.http.HttpResponse`. If you rely on this behavior, switch to | to :class:`~django.http.HttpResponse`. If you rely on this behavior, switch to | ||||||
| @@ -687,7 +688,7 @@ In Django 1.7 and above, the iterator will be consumed immediately by | |||||||
| Since Django 1.5 drops support for Python 2.5, we can now rely on the | Since Django 1.5 drops support for Python 2.5, we can now rely on the | ||||||
| :mod:`json` module being available in Python's standard library, so we've | :mod:`json` module being available in Python's standard library, so we've | ||||||
| removed our own copy of :mod:`simplejson`. You should now import :mod:`json` | removed our own copy of :mod:`simplejson`. You should now import :mod:`json` | ||||||
| instead :mod:`django.utils.simplejson`. | instead of ``django.utils.simplejson``. | ||||||
|  |  | ||||||
| Unfortunately, this change might have unwanted side-effects, because of | Unfortunately, this change might have unwanted side-effects, because of | ||||||
| incompatibilities between versions of :mod:`simplejson` -- see the | incompatibilities between versions of :mod:`simplejson` -- see the | ||||||
|   | |||||||
| @@ -284,7 +284,7 @@ Manager functions | |||||||
|         .. versionchanged:: 1.4 |         .. versionchanged:: 1.4 | ||||||
|            The ``email`` parameter was made optional. The username |            The ``email`` parameter was made optional. The username | ||||||
|            parameter is now checked for emptiness and raises a |            parameter is now checked for emptiness and raises a | ||||||
|            :exc:`ValueError` in case of a negative result. |            :exc:`~exceptions.ValueError` in case of a negative result. | ||||||
|  |  | ||||||
|         Creates, saves and returns a :class:`~django.contrib.auth.models.User`. |         Creates, saves and returns a :class:`~django.contrib.auth.models.User`. | ||||||
|  |  | ||||||
| @@ -558,7 +558,7 @@ Anonymous users | |||||||
|       :meth:`~django.contrib.auth.models.User.delete()`, |       :meth:`~django.contrib.auth.models.User.delete()`, | ||||||
|       :meth:`~django.contrib.auth.models.User.set_groups()` and |       :meth:`~django.contrib.auth.models.User.set_groups()` and | ||||||
|       :meth:`~django.contrib.auth.models.User.set_permissions()` raise |       :meth:`~django.contrib.auth.models.User.set_permissions()` raise | ||||||
|       :exc:`NotImplementedError`. |       :exc:`~exceptions.NotImplementedError`. | ||||||
|  |  | ||||||
| In practice, you probably won't need to use | In practice, you probably won't need to use | ||||||
| :class:`~django.contrib.auth.models.AnonymousUser` objects on your own, but | :class:`~django.contrib.auth.models.AnonymousUser` objects on your own, but | ||||||
|   | |||||||
| @@ -327,8 +327,8 @@ a primary key of 1, Django will raise ``Entry.DoesNotExist``. | |||||||
|  |  | ||||||
| Similarly, Django will complain if more than one item matches the | Similarly, Django will complain if more than one item matches the | ||||||
| :meth:`~django.db.models.query.QuerySet.get` query. In this case, it will raise | :meth:`~django.db.models.query.QuerySet.get` query. In this case, it will raise | ||||||
| ``MultipleObjectsReturned``, which again is an attribute of the model class | :exc:`~django.core.exceptions.MultipleObjectsReturned`, which again is an | ||||||
| itself. | attribute of the model class itself. | ||||||
|  |  | ||||||
|  |  | ||||||
| Other QuerySet methods | Other QuerySet methods | ||||||
|   | |||||||
| @@ -456,8 +456,9 @@ zone support. | |||||||
|  |  | ||||||
| Fixtures generated with ``USE_TZ = False``, or before Django 1.4, use the | Fixtures generated with ``USE_TZ = False``, or before Django 1.4, use the | ||||||
| "naive" format. If your project contains such fixtures, after you enable time | "naive" format. If your project contains such fixtures, after you enable time | ||||||
| zone support, you'll see :exc:`RuntimeWarning`\ s when you load them. To get | zone support, you'll see :exc:`~exceptions.RuntimeWarning`\ s when you load | ||||||
| rid of the warnings, you must convert your fixtures to the "aware" format. | them. To get rid of the warnings, you must convert your fixtures to the "aware" | ||||||
|  | format. | ||||||
|  |  | ||||||
| You can regenerate fixtures with :djadmin:`loaddata` then :djadmin:`dumpdata`. | You can regenerate fixtures with :djadmin:`loaddata` then :djadmin:`dumpdata`. | ||||||
| Or, if they're small enough, you can simply edit them to add the UTC offset | Or, if they're small enough, you can simply edit them to add the UTC offset | ||||||
|   | |||||||
| @@ -928,7 +928,7 @@ function. Example:: | |||||||
|  |  | ||||||
|     :func:`~django.conf.urls.i18n.i18n_patterns` is only allowed in your root |     :func:`~django.conf.urls.i18n.i18n_patterns` is only allowed in your root | ||||||
|     URLconf. Using it within an included URLconf will throw an |     URLconf. Using it within an included URLconf will throw an | ||||||
|     :exc:`ImproperlyConfigured` exception. |     :exc:`~django.core.exceptions.ImproperlyConfigured` exception. | ||||||
|  |  | ||||||
| .. warning:: | .. warning:: | ||||||
|  |  | ||||||
|   | |||||||
| @@ -343,7 +343,7 @@ meaning of ``str`` changed. To test these types, use the following idioms:: | |||||||
|     isinstance(myvalue, bytes)                  # replacement for str |     isinstance(myvalue, bytes)                  # replacement for str | ||||||
|  |  | ||||||
| Python ≥ 2.6 provides ``bytes`` as an alias for ``str``, so you don't need | Python ≥ 2.6 provides ``bytes`` as an alias for ``str``, so you don't need | ||||||
| :attr:`six.binary_type`. | :data:`six.binary_type`. | ||||||
|  |  | ||||||
| ``long`` | ``long`` | ||||||
| ~~~~~~~~ | ~~~~~~~~ | ||||||
| @@ -356,7 +356,7 @@ The ``long`` type no longer exists in Python 3. ``1L`` is a syntax error. Use | |||||||
| ``xrange`` | ``xrange`` | ||||||
| ~~~~~~~~~~ | ~~~~~~~~~~ | ||||||
|  |  | ||||||
| Import :func:`six.moves.xrange` wherever you use ``xrange``. | Import ``six.moves.xrange`` wherever you use ``xrange``. | ||||||
|  |  | ||||||
| Moved modules | Moved modules | ||||||
| ~~~~~~~~~~~~~ | ~~~~~~~~~~~~~ | ||||||
|   | |||||||
| @@ -38,7 +38,7 @@ in unauthorized JavaScript execution, depending on how the browser renders | |||||||
| imperfect HTML. | imperfect HTML. | ||||||
|  |  | ||||||
| It is also important to be particularly careful when using ``is_safe`` with | It is also important to be particularly careful when using ``is_safe`` with | ||||||
| custom template tags, the :ttag:`safe` template tag, :mod:`mark_safe | custom template tags, the :tfilter:`safe` template tag, :mod:`mark_safe | ||||||
| <django.utils.safestring>`, and when autoescape is turned off. | <django.utils.safestring>`, and when autoescape is turned off. | ||||||
|  |  | ||||||
| In addition, if you are using the template system to output something other | In addition, if you are using the template system to output something other | ||||||
|   | |||||||
| @@ -193,7 +193,7 @@ This strategy works well for most objects, but it can cause difficulty in some | |||||||
| circumstances. | circumstances. | ||||||
|  |  | ||||||
| Consider the case of a list of objects that have a foreign key referencing | Consider the case of a list of objects that have a foreign key referencing | ||||||
| :class:`~django.contrib.conttenttypes.models.ContentType`. If you're going to | :class:`~django.contrib.contenttypes.models.ContentType`. If you're going to | ||||||
| serialize an object that refers to a content type, then you need to have a way | serialize an object that refers to a content type, then you need to have a way | ||||||
| to refer to that content type to begin with. Since ``ContentType`` objects are | to refer to that content type to begin with. Since ``ContentType`` objects are | ||||||
| automatically created by Django during the database synchronization process, | automatically created by Django during the database synchronization process, | ||||||
|   | |||||||
| @@ -30,7 +30,7 @@ notifications: | |||||||
|  |  | ||||||
| * :data:`django.db.models.signals.m2m_changed` | * :data:`django.db.models.signals.m2m_changed` | ||||||
|  |  | ||||||
|   Sent when a :class:`ManyToManyField` on a model is changed. |   Sent when a :class:`~django.db.models.ManyToManyField` on a model is changed. | ||||||
|  |  | ||||||
| * :data:`django.core.signals.request_started` & | * :data:`django.core.signals.request_started` & | ||||||
|   :data:`django.core.signals.request_finished` |   :data:`django.core.signals.request_finished` | ||||||
|   | |||||||
| @@ -38,7 +38,7 @@ frameworks are: | |||||||
|  |  | ||||||
| * **Unit tests** -- tests that are expressed as methods on a Python class | * **Unit tests** -- tests that are expressed as methods on a Python class | ||||||
|   that subclasses :class:`unittest.TestCase` or Django's customized |   that subclasses :class:`unittest.TestCase` or Django's customized | ||||||
|   :class:`TestCase`. For example:: |   :class:`~django.test.TestCase`. For example:: | ||||||
|  |  | ||||||
|       import unittest |       import unittest | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user