mirror of
				https://github.com/django/django.git
				synced 2025-10-26 15:16:09 +00:00 
			
		
		
		
	Fixed broken links, round 4. refs #19516
This commit is contained in:
		| @@ -27,6 +27,8 @@ use of the ``REMOTE_USER`` value using the ``RemoteUserMiddleware`` and | |||||||
| Configuration | Configuration | ||||||
| ============= | ============= | ||||||
|  |  | ||||||
|  | .. class:: django.contrib.auth.middleware.RemoteUserMiddleware | ||||||
|  |  | ||||||
| First, you must add the | First, you must add the | ||||||
| :class:`django.contrib.auth.middleware.RemoteUserMiddleware` to the | :class:`django.contrib.auth.middleware.RemoteUserMiddleware` to the | ||||||
| :setting:`MIDDLEWARE_CLASSES` setting **after** the | :setting:`MIDDLEWARE_CLASSES` setting **after** the | ||||||
|   | |||||||
| @@ -2,6 +2,8 @@ | |||||||
| Writing custom django-admin commands | Writing custom django-admin commands | ||||||
| ==================================== | ==================================== | ||||||
|  |  | ||||||
|  | .. module:: django.core.management | ||||||
|  |  | ||||||
| Applications can register their own actions with ``manage.py``. For example, | Applications can register their own actions with ``manage.py``. For example, | ||||||
| you might want to add a ``manage.py`` action for a Django app that you're | you might want to add a ``manage.py`` action for a Django app that you're | ||||||
| distributing. In this document, we will be building a custom ``closepoll`` | distributing. In this document, we will be building a custom ``closepoll`` | ||||||
| @@ -261,6 +263,13 @@ the :meth:`~BaseCommand.handle` method must be implemented. | |||||||
|  |  | ||||||
|     The actual logic of the command. Subclasses must implement this method. |     The actual logic of the command. Subclasses must implement this method. | ||||||
|  |  | ||||||
|  | .. method:: BaseCommand.validate(app=None, display_num_errors=False) | ||||||
|  |  | ||||||
|  |     Validates the given app, raising :class:`CommandError` for any errors. | ||||||
|  |  | ||||||
|  |     If ``app`` is None, then all installed apps are validated. | ||||||
|  |  | ||||||
|  |  | ||||||
| .. _ref-basecommand-subclasses: | .. _ref-basecommand-subclasses: | ||||||
|  |  | ||||||
| BaseCommand subclasses | BaseCommand subclasses | ||||||
|   | |||||||
| @@ -153,8 +153,8 @@ class, from which everything is descended. | |||||||
|  |  | ||||||
| Initializing your new field is a matter of separating out any arguments that are | Initializing your new field is a matter of separating out any arguments that are | ||||||
| specific to your case from the common arguments and passing the latter to the | specific to your case from the common arguments and passing the latter to the | ||||||
| :meth:`~django.db.models.Field.__init__` method of | ``__init__()`` method of :class:`~django.db.models.Field` (or your parent | ||||||
| :class:`~django.db.models.Field` (or your parent class). | class). | ||||||
|  |  | ||||||
| In our example, we'll call our field ``HandField``. (It's a good idea to call | In our example, we'll call our field ``HandField``. (It's a good idea to call | ||||||
| your :class:`~django.db.models.Field` subclass ``<Something>Field``, so it's | your :class:`~django.db.models.Field` subclass ``<Something>Field``, so it's | ||||||
| @@ -602,11 +602,11 @@ Returns the default form field to use when this field is displayed in a model. | |||||||
| This method is called by the :class:`~django.forms.ModelForm` helper. | This method is called by the :class:`~django.forms.ModelForm` helper. | ||||||
|  |  | ||||||
| All of the ``kwargs`` dictionary is passed directly to the form field's | All of the ``kwargs`` dictionary is passed directly to the form field's | ||||||
| :meth:`~django.forms.Field__init__` method. Normally, all you need to do is | ``__init__()`` method. Normally, all you need to do is set up a good default | ||||||
| set up a good default for the ``form_class`` argument and then delegate further | for the ``form_class`` argument and then delegate further handling to the | ||||||
| handling to the parent class. This might require you to write a custom form | parent class. This might require you to write a custom form field (and even a | ||||||
| field (and even a form widget). See the :doc:`forms documentation | form widget). See the :doc:`forms documentation </topics/forms/index>` for | ||||||
| </topics/forms/index>` for information about this, and take a look at the code in | information about this, and take a look at the code in | ||||||
| :mod:`django.contrib.localflavor` for some examples of custom widgets. | :mod:`django.contrib.localflavor` for some examples of custom widgets. | ||||||
|  |  | ||||||
| Continuing our ongoing example, we can write the :meth:`.formfield` method as:: | Continuing our ongoing example, we can write the :meth:`.formfield` method as:: | ||||||
| @@ -668,7 +668,7 @@ Converting field data for serialization | |||||||
| .. method:: Field.value_to_string(self, obj) | .. method:: Field.value_to_string(self, obj) | ||||||
|  |  | ||||||
| This method is used by the serializers to convert the field into a string for | This method is used by the serializers to convert the field into a string for | ||||||
| output. Calling :meth:`Field._get_val_from_obj(obj)` is the best way to get the | output. Calling ``Field._get_val_from_obj(obj)`` is the best way to get the | ||||||
| value to serialize. For example, since our ``HandField`` uses strings for its | value to serialize. For example, since our ``HandField`` uses strings for its | ||||||
| data storage anyway, we can reuse some existing conversion code:: | data storage anyway, we can reuse some existing conversion code:: | ||||||
|  |  | ||||||
| @@ -692,12 +692,12 @@ smoothly: | |||||||
|    a field that's similar to what you want and extend it a little bit, |    a field that's similar to what you want and extend it a little bit, | ||||||
|    instead of creating an entirely new field from scratch. |    instead of creating an entirely new field from scratch. | ||||||
|  |  | ||||||
| 2. Put a :meth:`__str__` or :meth:`__unicode__` method on the class you're | 2. Put a ``__str__()`` or ``__unicode__()`` method on the class you're | ||||||
|    wrapping up as a field. There are a lot of places where the default |    wrapping up as a field. There are a lot of places where the default | ||||||
|    behavior of the field code is to call |    behavior of the field code is to call | ||||||
|    :func:`~django.utils.encoding.force_text` on the value. (In our |    :func:`~django.utils.encoding.force_text` on the value. (In our | ||||||
|    examples in this document, ``value`` would be a ``Hand`` instance, not a |    examples in this document, ``value`` would be a ``Hand`` instance, not a | ||||||
|    ``HandField``). So if your :meth:`__unicode__` method automatically |    ``HandField``). So if your ``__unicode__()`` method automatically | ||||||
|    converts to the string form of your Python object, you can save yourself |    converts to the string form of your Python object, you can save yourself | ||||||
|    a lot of work. |    a lot of work. | ||||||
|  |  | ||||||
|   | |||||||
| @@ -20,7 +20,7 @@ these changes. | |||||||
| * The old imports for CSRF functionality (``django.contrib.csrf.*``), | * The old imports for CSRF functionality (``django.contrib.csrf.*``), | ||||||
|   which moved to core in 1.2, will be removed. |   which moved to core in 1.2, will be removed. | ||||||
|  |  | ||||||
| * The :mod:`django.contrib.gis.db.backend` module will be removed in favor | * The ``django.contrib.gis.db.backend`` module will be removed in favor | ||||||
|   of the specific backends. |   of the specific backends. | ||||||
|  |  | ||||||
| * ``SMTPConnection`` will be removed in favor of a generic Email backend API. | * ``SMTPConnection`` will be removed in favor of a generic Email backend API. | ||||||
| @@ -122,23 +122,23 @@ these changes. | |||||||
|   The :attr:`~django.test.client.Response.templates` attribute should be |   The :attr:`~django.test.client.Response.templates` attribute should be | ||||||
|   used instead. |   used instead. | ||||||
|  |  | ||||||
| * The :class:`~django.test.simple.DjangoTestRunner` will be removed. | * The ``django.test.simple.DjangoTestRunner`` will be removed. | ||||||
|   Instead use a unittest-native class.  The features of the |   Instead use a unittest-native class.  The features of the | ||||||
|   :class:`django.test.simple.DjangoTestRunner` (including fail-fast and |   ``django.test.simple.DjangoTestRunner`` (including fail-fast and | ||||||
|   Ctrl-C test termination) can currently be provided by the unittest-native |   Ctrl-C test termination) can currently be provided by the unittest-native | ||||||
|   :class:`TextTestRunner`. |   :class:`~unittest.TextTestRunner`. | ||||||
|  |  | ||||||
| * The undocumented function | * The undocumented function | ||||||
|   :func:`django.contrib.formtools.utils.security_hash` will be removed, |   ``django.contrib.formtools.utils.security_hash`` will be removed, | ||||||
|   instead use :func:`django.contrib.formtools.utils.form_hmac` |   instead use ``django.contrib.formtools.utils.form_hmac`` | ||||||
|  |  | ||||||
| * The function-based generic view modules will be removed in favor of their | * The function-based generic view modules will be removed in favor of their | ||||||
|   class-based equivalents, outlined :doc:`here |   class-based equivalents, outlined :doc:`here | ||||||
|   </topics/class-based-views/index>`. |   </topics/class-based-views/index>`. | ||||||
|  |  | ||||||
| * The :class:`~django.core.servers.basehttp.AdminMediaHandler` will be | * The ``django.core.servers.basehttp.AdminMediaHandler`` will be | ||||||
|   removed.  In its place use |   removed.  In its place use | ||||||
|   :class:`~django.contrib.staticfiles.handlers.StaticFilesHandler`. |   ``django.contrib.staticfiles.handlers.StaticFilesHandler``. | ||||||
|  |  | ||||||
| * The template tags library ``adminmedia`` and the template tag ``{% | * The template tags library ``adminmedia`` and the template tag ``{% | ||||||
|   admin_media_prefix %}`` will be removed in favor of the generic static files |   admin_media_prefix %}`` will be removed in favor of the generic static files | ||||||
| @@ -150,8 +150,7 @@ these changes. | |||||||
|   an implied string. In 1.4, this behavior is provided by a version of the tag |   an implied string. In 1.4, this behavior is provided by a version of the tag | ||||||
|   in the ``future`` template tag library. |   in the ``future`` template tag library. | ||||||
|  |  | ||||||
| * The :djadmin:`reset` and :djadmin:`sqlreset` management commands | * The ``reset`` and ``sqlreset`` management commands will be removed. | ||||||
|   will be removed. |  | ||||||
|  |  | ||||||
| * Authentication backends will need to support an inactive user | * Authentication backends will need to support an inactive user | ||||||
|   being passed to all methods dealing with permissions. |   being passed to all methods dealing with permissions. | ||||||
| @@ -162,11 +161,11 @@ these changes. | |||||||
|   a :class:`~django.contrib.gis.geos.GEOSException` when called |   a :class:`~django.contrib.gis.geos.GEOSException` when called | ||||||
|   on a geometry with no SRID value. |   on a geometry with no SRID value. | ||||||
|  |  | ||||||
| * :class:`~django.http.CompatCookie` will be removed in favor of | * ``django.http.CompatCookie`` will be removed in favor of | ||||||
|   :class:`~django.http.SimpleCookie`. |   ``django.http.SimpleCookie``. | ||||||
|  |  | ||||||
| * :class:`django.core.context_processors.PermWrapper` and | * ``django.core.context_processors.PermWrapper`` and | ||||||
|   :class:`django.core.context_processors.PermLookupDict` will be removed in |   ``django.core.context_processors.PermLookupDict`` will be removed in | ||||||
|   favor of the corresponding |   favor of the corresponding | ||||||
|   :class:`django.contrib.auth.context_processors.PermWrapper` and |   :class:`django.contrib.auth.context_processors.PermWrapper` and | ||||||
|   :class:`django.contrib.auth.context_processors.PermLookupDict`, |   :class:`django.contrib.auth.context_processors.PermLookupDict`, | ||||||
| @@ -213,8 +212,7 @@ these changes. | |||||||
|   ``django.utils.itercompat.all`` and ``django.utils.itercompat.any`` will |   ``django.utils.itercompat.all`` and ``django.utils.itercompat.any`` will | ||||||
|   be removed. The Python builtin versions should be used instead. |   be removed. The Python builtin versions should be used instead. | ||||||
|  |  | ||||||
| * The :func:`~django.views.decorators.csrf.csrf_response_exempt` and | * The ``csrf_response_exempt`` and ``csrf_view_exempt`` decorators will | ||||||
|   :func:`~django.views.decorators.csrf.csrf_view_exempt` decorators will |  | ||||||
|   be removed. Since 1.4 ``csrf_response_exempt`` has been a no-op (it |   be removed. Since 1.4 ``csrf_response_exempt`` has been a no-op (it | ||||||
|   returns the same function), and ``csrf_view_exempt`` has been a |   returns the same function), and ``csrf_view_exempt`` has been a | ||||||
|   synonym for ``django.views.decorators.csrf.csrf_exempt``, which should |   synonym for ``django.views.decorators.csrf.csrf_exempt``, which should | ||||||
|   | |||||||
| @@ -349,7 +349,7 @@ Login and logout signals | |||||||
| The auth framework uses two :doc:`signals </topics/signals>` that can be used | The auth framework uses two :doc:`signals </topics/signals>` that can be used | ||||||
| for notification when a user logs in or out. | for notification when a user logs in or out. | ||||||
|  |  | ||||||
| .. function:: django.contrib.auth.signals.user_logged_in | .. function:: user_logged_in | ||||||
|  |  | ||||||
|     Sent when a user logs in successfully. |     Sent when a user logs in successfully. | ||||||
|  |  | ||||||
| @@ -364,7 +364,7 @@ for notification when a user logs in or out. | |||||||
|     ``user`` |     ``user`` | ||||||
|         The user instance that just logged in. |         The user instance that just logged in. | ||||||
|  |  | ||||||
| .. function:: django.contrib.auth.signals.user_logged_out | .. function:: user_logged_out | ||||||
|  |  | ||||||
|     Sent when the logout method is called. |     Sent when the logout method is called. | ||||||
|  |  | ||||||
| @@ -379,9 +379,9 @@ for notification when a user logs in or out. | |||||||
|         The user instance that just logged out or ``None`` if the |         The user instance that just logged out or ``None`` if the | ||||||
|         user was not authenticated. |         user was not authenticated. | ||||||
|  |  | ||||||
| .. function:: django.contrib.auth.signals.user_login_failed | .. function:: user_login_failed | ||||||
|  |  | ||||||
| .. versionadded:: 1.5 |     .. versionadded:: 1.5 | ||||||
|  |  | ||||||
|     Sent when the user failed to login successfully |     Sent when the user failed to login successfully | ||||||
|  |  | ||||||
|   | |||||||
| @@ -140,6 +140,8 @@ with the rest of :ref:`Django's unit tests <running-unit-tests>`. | |||||||
| Run only GeoDjango tests | Run only GeoDjango tests | ||||||
| ------------------------ | ------------------------ | ||||||
|  |  | ||||||
|  | .. class:: django.contrib.gis.tests.GeoDjangoTestSuiteRunner | ||||||
|  |  | ||||||
| To run *only* the tests for GeoDjango, the :setting:`TEST_RUNNER` | To run *only* the tests for GeoDjango, the :setting:`TEST_RUNNER` | ||||||
| setting must be changed to use the | setting must be changed to use the | ||||||
| :class:`~django.contrib.gis.tests.GeoDjangoTestSuiteRunner`:: | :class:`~django.contrib.gis.tests.GeoDjangoTestSuiteRunner`:: | ||||||
|   | |||||||
| @@ -149,6 +149,8 @@ tags for the levels you wish to override:: | |||||||
| Using messages in views and templates | Using messages in views and templates | ||||||
| ===================================== | ===================================== | ||||||
|  |  | ||||||
|  | .. function:: add_message(request, level, message, extra_tags='', fail_silently=False) | ||||||
|  |  | ||||||
| Adding a message | Adding a message | ||||||
| ---------------- | ---------------- | ||||||
|  |  | ||||||
|   | |||||||
| @@ -27,9 +27,8 @@ module system. | |||||||
| .. warning:: | .. warning:: | ||||||
|  |  | ||||||
|     Many of these signals are sent by various model methods like |     Many of these signals are sent by various model methods like | ||||||
|     :meth:`~django.db.models.Model.__init__` or |     ``__init__()`` or :meth:`~django.db.models.Model.save` that you can | ||||||
|     :meth:`~django.db.models.Model.save` that you can overwrite in your own |     override in your own code. | ||||||
|     code. |  | ||||||
|  |  | ||||||
|     If you override these methods on your model, you must call the parent class' |     If you override these methods on your model, you must call the parent class' | ||||||
|     methods for this signals to be sent. |     methods for this signals to be sent. | ||||||
| @@ -47,7 +46,7 @@ pre_init | |||||||
| .. ^^^^^^^ this :module: hack keeps Sphinx from prepending the module. | .. ^^^^^^^ this :module: hack keeps Sphinx from prepending the module. | ||||||
|  |  | ||||||
| Whenever you instantiate a Django model, this signal is sent at the beginning | Whenever you instantiate a Django model, this signal is sent at the beginning | ||||||
| of the model's :meth:`~django.db.models.Model.__init__` method. | of the model's ``__init__()`` method. | ||||||
|  |  | ||||||
| Arguments sent with this signal: | Arguments sent with this signal: | ||||||
|  |  | ||||||
| @@ -55,12 +54,10 @@ Arguments sent with this signal: | |||||||
|     The model class that just had an instance created. |     The model class that just had an instance created. | ||||||
|  |  | ||||||
| ``args`` | ``args`` | ||||||
|     A list of positional arguments passed to |     A list of positional arguments passed to ``__init__()``: | ||||||
|     :meth:`~django.db.models.Model.__init__`: |  | ||||||
|  |  | ||||||
| ``kwargs`` | ``kwargs`` | ||||||
|     A dictionary of keyword arguments passed to |     A dictionary of keyword arguments passed to ``__init__()``: | ||||||
|     :meth:`~django.db.models.Model.__init__`:. |  | ||||||
|  |  | ||||||
| For example, the :doc:`tutorial </intro/tutorial01>` has this line:: | For example, the :doc:`tutorial </intro/tutorial01>` has this line:: | ||||||
|  |  | ||||||
| @@ -74,7 +71,7 @@ Argument    Value | |||||||
| ``sender``  ``Poll`` (the class itself) | ``sender``  ``Poll`` (the class itself) | ||||||
|  |  | ||||||
| ``args``    ``[]`` (an empty list because there were no positional | ``args``    ``[]`` (an empty list because there were no positional | ||||||
|             arguments passed to ``__init__``.) |             arguments passed to ``__init__()``.) | ||||||
|  |  | ||||||
| ``kwargs``  ``{'question': "What's up?", 'pub_date': datetime.now()}`` | ``kwargs``  ``{'question': "What's up?", 'pub_date': datetime.now()}`` | ||||||
| ==========  =============================================================== | ==========  =============================================================== | ||||||
| @@ -85,7 +82,7 @@ post_init | |||||||
| .. data:: django.db.models.signals.post_init | .. data:: django.db.models.signals.post_init | ||||||
|    :module: |    :module: | ||||||
|  |  | ||||||
| Like pre_init, but this one is sent when the :meth:`~django.db.models.Model.__init__`: method finishes. | Like pre_init, but this one is sent when the ``__init__()`` method finishes. | ||||||
|  |  | ||||||
| Arguments sent with this signal: | Arguments sent with this signal: | ||||||
|  |  | ||||||
|   | |||||||
| @@ -277,8 +277,9 @@ Handle uploaded files using the new API | |||||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||||
|  |  | ||||||
| Replace use of uploaded files -- that is, entries in ``request.FILES`` -- as | Replace use of uploaded files -- that is, entries in ``request.FILES`` -- as | ||||||
| simple dictionaries with the new :class:`~django.core.files.UploadedFile`. The | simple dictionaries with the new | ||||||
| old dictionary syntax no longer works. | :class:`~django.core.files.uploadedfile.UploadedFile`. The old dictionary | ||||||
|  | syntax no longer works. | ||||||
|  |  | ||||||
| Thus, in a view like:: | Thus, in a view like:: | ||||||
|  |  | ||||||
| @@ -410,7 +411,7 @@ U.S. local flavor | |||||||
| ~~~~~~~~~~~~~~~~~ | ~~~~~~~~~~~~~~~~~ | ||||||
|  |  | ||||||
| ``django.contrib.localflavor.usa`` has been renamed to | ``django.contrib.localflavor.usa`` has been renamed to | ||||||
| :mod:`django.contrib.localflavor.us`. This change was made to match the naming | ``django.contrib.localflavor.us``. This change was made to match the naming | ||||||
| scheme of other local flavors. To migrate your code, all you need to do is | scheme of other local flavors. To migrate your code, all you need to do is | ||||||
| change the imports. | change the imports. | ||||||
|  |  | ||||||
| @@ -642,8 +643,8 @@ The generic relation classes -- ``GenericForeignKey`` and ``GenericRelation`` | |||||||
| Testing | Testing | ||||||
| ------- | ------- | ||||||
|  |  | ||||||
| :meth:`django.test.Client.login` has changed | :meth:`django.test.client.Client.login` has changed | ||||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||||
|  |  | ||||||
| Old (0.96):: | Old (0.96):: | ||||||
|  |  | ||||||
| @@ -721,7 +722,7 @@ To update your code: | |||||||
| 1. Use :class:`django.utils.datastructures.SortedDict` wherever you were | 1. Use :class:`django.utils.datastructures.SortedDict` wherever you were | ||||||
|    using ``django.newforms.forms.SortedDictFromList``. |    using ``django.newforms.forms.SortedDictFromList``. | ||||||
|  |  | ||||||
| 2. Because :meth:`django.utils.datastructures.SortedDict.copy` doesn't | 2. Because ``django.utils.datastructures.SortedDict.copy`` doesn't | ||||||
|    return a deepcopy as ``SortedDictFromList.copy()`` did, you will need |    return a deepcopy as ``SortedDictFromList.copy()`` did, you will need | ||||||
|    to update your code if you were relying on a deepcopy. Do this by using |    to update your code if you were relying on a deepcopy. Do this by using | ||||||
|    ``copy.deepcopy`` directly. |    ``copy.deepcopy`` directly. | ||||||
|   | |||||||
| @@ -36,7 +36,7 @@ A number of features have been added to Django's model layer: | |||||||
| You can now control whether or not Django creates database tables for a model | You can now control whether or not Django creates database tables for a model | ||||||
| using the :attr:`~Options.managed` model option. This defaults to ``True``, | using the :attr:`~Options.managed` model option. This defaults to ``True``, | ||||||
| meaning that Django will create the appropriate database tables in | meaning that Django will create the appropriate database tables in | ||||||
| :djadmin:`syncdb` and remove them as part of :djadmin:`reset` command. That | :djadmin:`syncdb` and remove them as part of ``reset`` command. That | ||||||
| is, Django *manages* the database table's lifecycle. | is, Django *manages* the database table's lifecycle. | ||||||
|  |  | ||||||
| If you set this to ``False``, however, no database table creating or deletion | If you set this to ``False``, however, no database table creating or deletion | ||||||
|   | |||||||
| @@ -37,7 +37,7 @@ If you are using a 32-bit platform, you're off the hook; you'll observe no | |||||||
| differences as a result of this change. | differences as a result of this change. | ||||||
|  |  | ||||||
| However, **users on 64-bit platforms may experience some problems** using the | However, **users on 64-bit platforms may experience some problems** using the | ||||||
| :djadmin:`reset` management command. Prior to this change, 64-bit platforms | ``reset`` management command. Prior to this change, 64-bit platforms | ||||||
| would generate a 64-bit, 16 character digest in the constraint name; for | would generate a 64-bit, 16 character digest in the constraint name; for | ||||||
| example:: | example:: | ||||||
|  |  | ||||||
| @@ -48,14 +48,14 @@ Following this change, all platforms, regardless of word size, will generate a | |||||||
|  |  | ||||||
|     ALTER TABLE myapp_sometable ADD CONSTRAINT object_id_refs_id_32091d1e FOREIGN KEY ... |     ALTER TABLE myapp_sometable ADD CONSTRAINT object_id_refs_id_32091d1e FOREIGN KEY ... | ||||||
|  |  | ||||||
| As a result of this change, you will not be able to use the :djadmin:`reset` | As a result of this change, you will not be able to use the ``reset`` | ||||||
| management command on any table made by a 64-bit machine. This is because the | management command on any table made by a 64-bit machine. This is because the | ||||||
| the new generated name will not match the historically generated name; as a | the new generated name will not match the historically generated name; as a | ||||||
| result, the SQL constructed by the reset command will be invalid. | result, the SQL constructed by the reset command will be invalid. | ||||||
|  |  | ||||||
| If you need to reset an application that was created with 64-bit constraints, | If you need to reset an application that was created with 64-bit constraints, | ||||||
| you will need to manually drop the old constraint prior to invoking | you will need to manually drop the old constraint prior to invoking | ||||||
| :djadmin:`reset`. | ``reset``. | ||||||
|  |  | ||||||
| Test cases are now run in a transaction | Test cases are now run in a transaction | ||||||
| --------------------------------------- | --------------------------------------- | ||||||
| @@ -120,9 +120,8 @@ has been saved. | |||||||
| Changes to how model formsets are saved | Changes to how model formsets are saved | ||||||
| --------------------------------------- | --------------------------------------- | ||||||
|  |  | ||||||
| .. currentmodule:: django.forms.models | In Django 1.1, :class:`~django.forms.models.BaseModelFormSet` now calls | ||||||
|  | ``ModelForm.save()``. | ||||||
| In Django 1.1, :class:`BaseModelFormSet` now calls :meth:`ModelForm.save()`. |  | ||||||
|  |  | ||||||
| This is backwards-incompatible if you were modifying ``self.initial`` in a model | This is backwards-incompatible if you were modifying ``self.initial`` in a model | ||||||
| formset's ``__init__``, or if you relied on the internal ``_total_form_count`` | formset's ``__init__``, or if you relied on the internal ``_total_form_count`` | ||||||
| @@ -146,7 +145,7 @@ Permanent redirects and the ``redirect_to()`` generic view | |||||||
| ---------------------------------------------------------- | ---------------------------------------------------------- | ||||||
|  |  | ||||||
| Django 1.1 adds a ``permanent`` argument to the | Django 1.1 adds a ``permanent`` argument to the | ||||||
| :func:`django.views.generic.simple.redirect_to()` view. This is technically | ``django.views.generic.simple.redirect_to()`` view. This is technically | ||||||
| backwards-incompatible if you were using the ``redirect_to`` view with a | backwards-incompatible if you were using the ``redirect_to`` view with a | ||||||
| format-string key called 'permanent', which is highly unlikely. | format-string key called 'permanent', which is highly unlikely. | ||||||
|  |  | ||||||
| @@ -211,8 +210,8 @@ Query expressions | |||||||
|  |  | ||||||
| Queries can now refer to a another field on the query and can traverse | Queries can now refer to a another field on the query and can traverse | ||||||
| relationships to refer to fields on related models. This is implemented in the | relationships to refer to fields on related models. This is implemented in the | ||||||
| new :class:`F` object; for full details, including examples, consult the | new :class:`~django.db.models.F` object; for full details, including examples, | ||||||
| :ref:`documentation for F expressions <query-expressions>`. | consult the :ref:`documentation for F expressions <query-expressions>`. | ||||||
|  |  | ||||||
| Model improvements | Model improvements | ||||||
| ------------------ | ------------------ | ||||||
| @@ -225,7 +224,7 @@ A number of features have been added to Django's model layer: | |||||||
| You can now control whether or not Django manages the life-cycle of the database | You can now control whether or not Django manages the life-cycle of the database | ||||||
| tables for a model using the :attr:`~Options.managed` model option. This | tables for a model using the :attr:`~Options.managed` model option. This | ||||||
| defaults to ``True``, meaning that Django will create the appropriate database | defaults to ``True``, meaning that Django will create the appropriate database | ||||||
| tables in :djadmin:`syncdb` and remove them as part of the :djadmin:`reset` | tables in :djadmin:`syncdb` and remove them as part of the ``reset`` | ||||||
| command. That is, Django *manages* the database table's lifecycle. | command. That is, Django *manages* the database table's lifecycle. | ||||||
|  |  | ||||||
| If you set this to ``False``, however, no database table creating or deletion | If you set this to ``False``, however, no database table creating or deletion | ||||||
|   | |||||||
| @@ -76,7 +76,7 @@ GeoDjango | |||||||
| ========= | ========= | ||||||
|  |  | ||||||
| The function-based :setting:`TEST_RUNNER` previously used to execute | The function-based :setting:`TEST_RUNNER` previously used to execute | ||||||
| the GeoDjango test suite, :func:`django.contrib.gis.tests.run_gis_tests`, | the GeoDjango test suite, ``django.contrib.gis.tests.run_gis_tests``, | ||||||
| was finally deprecated in favor of a class-based test runner, | was finally deprecated in favor of a class-based test runner, | ||||||
| :class:`django.contrib.gis.tests.GeoDjangoTestSuiteRunner`, added in this | :class:`django.contrib.gis.tests.GeoDjangoTestSuiteRunner`, added in this | ||||||
| release. | release. | ||||||
|   | |||||||
| @@ -311,37 +311,35 @@ As a result of the introduction of class-based generic views, the | |||||||
| function-based generic views provided by Django have been deprecated. | function-based generic views provided by Django have been deprecated. | ||||||
| The following modules and the views they contain have been deprecated: | The following modules and the views they contain have been deprecated: | ||||||
|  |  | ||||||
| * :mod:`django.views.generic.create_update` | * ``django.views.generic.create_update`` | ||||||
| * :mod:`django.views.generic.date_based` | * ``django.views.generic.date_based`` | ||||||
| * :mod:`django.views.generic.list_detail` | * ``django.views.generic.list_detail`` | ||||||
| * :mod:`django.views.generic.simple` | * ``django.views.generic.simple`` | ||||||
|  |  | ||||||
| Test client response ``template`` attribute | Test client response ``template`` attribute | ||||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||||
|  |  | ||||||
| Django's :ref:`test client <test-client>` returns | Django's :ref:`test client <test-client>` returns | ||||||
| :class:`~django.test.client.Response` objects annotated with extra testing | :class:`~django.test.client.Response` objects annotated with extra testing | ||||||
| information. In Django versions prior to 1.3, this included a | information. In Django versions prior to 1.3, this included a ``template`` | ||||||
| :attr:`~django.test.client.Response.template` attribute containing information | attribute containing information about templates rendered in generating the | ||||||
| about templates rendered in generating the response: either None, a single | response: either None, a single :class:`~django.template.Template` object, or a | ||||||
| :class:`~django.template.Template` object, or a list of | list of :class:`~django.template.Template` objects. This inconsistency in | ||||||
| :class:`~django.template.Template` objects. This inconsistency in return values | return values (sometimes a list, sometimes not) made the attribute difficult | ||||||
| (sometimes a list, sometimes not) made the attribute difficult to work with. | to work with. | ||||||
|  |  | ||||||
| In Django 1.3 the :attr:`~django.test.client.Response.template` attribute is | In Django 1.3 the ``template`` attribute is deprecated in favor of a new | ||||||
| deprecated in favor of a new :attr:`~django.test.client.Response.templates` | :attr:`~django.test.client.Response.templates` attribute, which is always a | ||||||
| attribute, which is always a list, even if it has only a single element or no | list, even if it has only a single element or no elements. | ||||||
| elements. |  | ||||||
|  |  | ||||||
| ``DjangoTestRunner`` | ``DjangoTestRunner`` | ||||||
| ~~~~~~~~~~~~~~~~~~~~ | ~~~~~~~~~~~~~~~~~~~~ | ||||||
|  |  | ||||||
| As a result of the introduction of support for unittest2, the features | As a result of the introduction of support for unittest2, the features | ||||||
| of :class:`django.test.simple.DjangoTestRunner` (including fail-fast | of ``django.test.simple.DjangoTestRunner`` (including fail-fast | ||||||
| and Ctrl-C test termination) have been made redundant. In view of this | and Ctrl-C test termination) have been made redundant. In view of this | ||||||
| redundancy, :class:`~django.test.simple.DjangoTestRunner` has been | redundancy, ``DjangoTestRunner`` has been turned into an empty placeholder | ||||||
| turned into an empty placeholder class, and will be removed entirely | class, and will be removed entirely in Django 1.5. | ||||||
| in Django 1.5. |  | ||||||
|  |  | ||||||
| The Django 1.3 roadmap | The Django 1.3 roadmap | ||||||
| ====================== | ====================== | ||||||
|   | |||||||
| @@ -142,10 +142,9 @@ Changes to ``USStateField`` | |||||||
|  |  | ||||||
| The :mod:`django.contrib.localflavor` application contains collections | The :mod:`django.contrib.localflavor` application contains collections | ||||||
| of code relevant to specific countries or cultures. One such is | of code relevant to specific countries or cultures. One such is | ||||||
| :class:`~django.contrib.localflavor.us.models.USStateField`, which | ``USStateField``, which provides a field for storing the two-letter postal | ||||||
| provides a field for storing the two-letter postal abbreviation of a | abbreviation of a U.S. state. This field has consistently caused problems, | ||||||
| U.S. state. This field has consistently caused problems, however, | however, because it is often used to store the state portion of a U.S postal | ||||||
| because it is often used to store the state portion of a U.S postal |  | ||||||
| address, but not all "states" recognized by the U.S Postal Service are | address, but not all "states" recognized by the U.S Postal Service are | ||||||
| actually states of the U.S. or even U.S. territory. Several | actually states of the U.S. or even U.S. territory. Several | ||||||
| compromises over the list of choices resulted in some users feeling | compromises over the list of choices resulted in some users feeling | ||||||
| @@ -161,7 +160,7 @@ as a pair of changes: | |||||||
|   choices, plus the U.S. Armed Forces postal codes. |   choices, plus the U.S. Armed Forces postal codes. | ||||||
|  |  | ||||||
| * A new model field, | * A new model field, | ||||||
|   :class:`django.contrib.localflavor.us.models.USPostalCodeField`, has |   ``django.contrib.localflavor.us.models.USPostalCodeField``, has | ||||||
|   been added which draws its choices from a list of all postal |   been added which draws its choices from a list of all postal | ||||||
|   abbreviations recognized by the U.S Postal Service. This includes |   abbreviations recognized by the U.S Postal Service. This includes | ||||||
|   all abbreviations recognized by `USStateField`, plus three |   all abbreviations recognized by `USStateField`, plus three | ||||||
|   | |||||||
| @@ -700,40 +700,35 @@ As a result of the introduction of class-based generic views, the | |||||||
| function-based generic views provided by Django have been deprecated. | function-based generic views provided by Django have been deprecated. | ||||||
| The following modules and the views they contain have been deprecated: | The following modules and the views they contain have been deprecated: | ||||||
|  |  | ||||||
| * :mod:`django.views.generic.create_update` | * ``django.views.generic.create_update`` | ||||||
|  | * ``django.views.generic.date_based`` | ||||||
| * :mod:`django.views.generic.date_based` | * ``django.views.generic.list_detail`` | ||||||
|  | * ``django.views.generic.simple`` | ||||||
| * :mod:`django.views.generic.list_detail` |  | ||||||
|  |  | ||||||
| * :mod:`django.views.generic.simple` |  | ||||||
|  |  | ||||||
| Test client response ``template`` attribute | Test client response ``template`` attribute | ||||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||||
|  |  | ||||||
| Django's :ref:`test client <test-client>` returns | Django's :ref:`test client <test-client>` returns | ||||||
| :class:`~django.test.client.Response` objects annotated with extra testing | :class:`~django.test.client.Response` objects annotated with extra testing | ||||||
| information. In Django versions prior to 1.3, this included a | information. In Django versions prior to 1.3, this included a ``template`` | ||||||
| :attr:`~django.test.client.Response.template` attribute containing information | attribute containing information about templates rendered in generating the | ||||||
| about templates rendered in generating the response: either None, a single | response: either None, a single :class:`~django.template.Template` object, or a | ||||||
| :class:`~django.template.Template` object, or a list of | list of :class:`~django.template.Template` objects. This inconsistency in | ||||||
| :class:`~django.template.Template` objects. This inconsistency in return values | return values (sometimes a list, sometimes not) made the attribute difficult | ||||||
| (sometimes a list, sometimes not) made the attribute difficult to work with. | to work with. | ||||||
|  |  | ||||||
| In Django 1.3 the :attr:`~django.test.client.Response.template` attribute is | In Django 1.3 the ``template`` attribute is deprecated in favor of a new | ||||||
| deprecated in favor of a new :attr:`~django.test.client.Response.templates` | :attr:`~django.test.client.Response.templates` attribute, which is always a | ||||||
| attribute, which is always a list, even if it has only a single element or no | list, even if it has only a single element or no elements. | ||||||
| elements. |  | ||||||
|  |  | ||||||
| ``DjangoTestRunner`` | ``DjangoTestRunner`` | ||||||
| ~~~~~~~~~~~~~~~~~~~~ | ~~~~~~~~~~~~~~~~~~~~ | ||||||
|  |  | ||||||
| As a result of the introduction of support for unittest2, the features | As a result of the introduction of support for unittest2, the features | ||||||
| of :class:`django.test.simple.DjangoTestRunner` (including fail-fast | of ``django.test.simple.DjangoTestRunner`` (including fail-fast | ||||||
| and Ctrl-C test termination) have been made redundant. In view of this | and Ctrl-C test termination) have been made redundant. In view of this | ||||||
| redundancy, :class:`~django.test.simple.DjangoTestRunner` has been | redundancy, ``DjangoTestRunner`` has been turned into an empty placeholder | ||||||
| turned into an empty placeholder class, and will be removed entirely | class, and will be removed entirely in Django 1.5. | ||||||
| in Django 1.5. |  | ||||||
|  |  | ||||||
| Changes to :ttag:`url` and :ttag:`ssi` | Changes to :ttag:`url` and :ttag:`ssi` | ||||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||||
| @@ -805,9 +800,8 @@ GeoDjango | |||||||
| ~~~~~~~~~ | ~~~~~~~~~ | ||||||
|  |  | ||||||
| * The function-based :setting:`TEST_RUNNER` previously used to execute | * The function-based :setting:`TEST_RUNNER` previously used to execute | ||||||
|   the GeoDjango test suite, |   the GeoDjango test suite, ``django.contrib.gis.tests.run_gis_tests``, was | ||||||
|   :func:`django.contrib.gis.tests.run_gis_tests`, was deprecated for |   deprecated for the class-based runner, | ||||||
|   the class-based runner, |  | ||||||
|   :class:`django.contrib.gis.tests.GeoDjangoTestSuiteRunner`. |   :class:`django.contrib.gis.tests.GeoDjangoTestSuiteRunner`. | ||||||
|  |  | ||||||
| * Previously, calling | * Previously, calling | ||||||
| @@ -886,11 +880,10 @@ identical to their old versions; only the module location has changed. | |||||||
| Removal of ``XMLField`` | Removal of ``XMLField`` | ||||||
| ~~~~~~~~~~~~~~~~~~~~~~~ | ~~~~~~~~~~~~~~~~~~~~~~~ | ||||||
|  |  | ||||||
| When Django was first released, Django included an | When Django was first released, Django included an ``XMLField`` that performed | ||||||
| :class:`~django.db.models.XMLField` that performed automatic XML validation | automatic XML validation for any field input. However, this validation function | ||||||
| for any field input. However, this validation function hasn't been | hasn't been performed since the introduction of ``newforms``, prior to the 1.0 | ||||||
| performed since the introduction of ``newforms``, prior to the 1.0 release. | release. As a result, ``XMLField`` as currently implemented is functionally | ||||||
| As a result, ``XMLField`` as currently implemented is functionally |  | ||||||
| indistinguishable from a simple :class:`~django.db.models.TextField`. | indistinguishable from a simple :class:`~django.db.models.TextField`. | ||||||
|  |  | ||||||
| For this reason, Django 1.3 has fast-tracked the deprecation of | For this reason, Django 1.3 has fast-tracked the deprecation of | ||||||
|   | |||||||
| @@ -503,7 +503,7 @@ Django 1.4 also includes several smaller improvements worth noting: | |||||||
| * In the documentation, a helpful :doc:`security overview </topics/security>` | * In the documentation, a helpful :doc:`security overview </topics/security>` | ||||||
|   page. |   page. | ||||||
|  |  | ||||||
| * The :func:`django.contrib.auth.models.check_password` function has been moved | * The ``django.contrib.auth.models.check_password`` function has been moved | ||||||
|   to the :mod:`django.contrib.auth.utils` module. Importing it from the old |   to the :mod:`django.contrib.auth.utils` module. Importing it from the old | ||||||
|   location will still work, but you should update your imports. |   location will still work, but you should update your imports. | ||||||
|  |  | ||||||
|   | |||||||
| @@ -563,7 +563,7 @@ Django 1.4 also includes several smaller improvements worth noting: | |||||||
| * In the documentation, a helpful :doc:`security overview </topics/security>` | * In the documentation, a helpful :doc:`security overview </topics/security>` | ||||||
|   page. |   page. | ||||||
|  |  | ||||||
| * The :func:`django.contrib.auth.models.check_password` function has been moved | * The ``django.contrib.auth.models.check_password`` function has been moved | ||||||
|   to the :mod:`django.contrib.auth.utils` module. Importing it from the old |   to the :mod:`django.contrib.auth.utils` module. Importing it from the old | ||||||
|   location will still work, but you should update your imports. |   location will still work, but you should update your imports. | ||||||
|  |  | ||||||
|   | |||||||
| @@ -585,7 +585,7 @@ Django 1.4 also includes several smaller improvements worth noting: | |||||||
| * In the documentation, a helpful :doc:`security overview </topics/security>` | * In the documentation, a helpful :doc:`security overview </topics/security>` | ||||||
|   page. |   page. | ||||||
|  |  | ||||||
| * The :func:`django.contrib.auth.models.check_password` function has been moved | * The ``django.contrib.auth.models.check_password`` function has been moved | ||||||
|   to the :mod:`django.contrib.auth.hashers` module. Importing it from the old |   to the :mod:`django.contrib.auth.hashers` module. Importing it from the old | ||||||
|   location will still work, but you should update your imports. |   location will still work, but you should update your imports. | ||||||
|  |  | ||||||
|   | |||||||
| @@ -423,7 +423,7 @@ More information on these incompatibilities is available in `ticket #18023`_. | |||||||
|  |  | ||||||
| The net result is that, if you have installed :mod:`simplejson` and your code | The net result is that, if you have installed :mod:`simplejson` and your code | ||||||
| uses Django's serialization internals directly -- for instance | uses Django's serialization internals directly -- for instance | ||||||
| :class:`django.core.serializers.json.DjangoJSONEncoder`, the switch from | ``django.core.serializers.json.DjangoJSONEncoder``, the switch from | ||||||
| :mod:`simplejson` to :mod:`json` could break your code. (In general, changes to | :mod:`simplejson` to :mod:`json` could break your code. (In general, changes to | ||||||
| internals aren't documented; we're making an exception here.) | internals aren't documented; we're making an exception here.) | ||||||
|  |  | ||||||
| @@ -449,8 +449,8 @@ When using :doc:`object pagination </topics/pagination>`, | |||||||
| the ``previous_page_number()`` and ``next_page_number()`` methods of the | the ``previous_page_number()`` and ``next_page_number()`` methods of the | ||||||
| :class:`~django.core.paginator.Page` object did not check if the returned | :class:`~django.core.paginator.Page` object did not check if the returned | ||||||
| number was inside the existing page range. | number was inside the existing page range. | ||||||
| It does check it now and raises an :exc:`InvalidPage` exception when the number | It does check it now and raises an :exc:`~django.core.paginator.InvalidPage` | ||||||
| is either too low or too high. | exception when the number is either too low or too high. | ||||||
|  |  | ||||||
| Behavior of autocommit database option on PostgreSQL changed | Behavior of autocommit database option on PostgreSQL changed | ||||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||||
| @@ -619,10 +619,9 @@ Define a ``__str__`` method and apply the | |||||||
| ``django.utils.itercompat.product`` | ``django.utils.itercompat.product`` | ||||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||||
|  |  | ||||||
| The :func:`~django.utils.itercompat.product` function has been deprecated. Use | The ``django.utils.itercompat.product`` function has been deprecated. Use | ||||||
| the built-in :func:`itertools.product` instead. | the built-in :func:`itertools.product` instead. | ||||||
|  |  | ||||||
|  |  | ||||||
| ``django.utils.markup`` | ``django.utils.markup`` | ||||||
| ~~~~~~~~~~~~~~~~~~~~~~~ | ~~~~~~~~~~~~~~~~~~~~~~~ | ||||||
|  |  | ||||||
|   | |||||||
| @@ -448,7 +448,7 @@ More information on these incompatibilities is available in `ticket #18023`_. | |||||||
|  |  | ||||||
| The net result is that, if you have installed :mod:`simplejson` and your code | The net result is that, if you have installed :mod:`simplejson` and your code | ||||||
| uses Django's serialization internals directly -- for instance | uses Django's serialization internals directly -- for instance | ||||||
| :class:`django.core.serializers.json.DjangoJSONEncoder`, the switch from | ``django.core.serializers.json.DjangoJSONEncoder``, the switch from | ||||||
| :mod:`simplejson` to :mod:`json` could break your code. (In general, changes to | :mod:`simplejson` to :mod:`json` could break your code. (In general, changes to | ||||||
| internals aren't documented; we're making an exception here.) | internals aren't documented; we're making an exception here.) | ||||||
|  |  | ||||||
| @@ -474,8 +474,8 @@ When using :doc:`object pagination </topics/pagination>`, | |||||||
| the ``previous_page_number()`` and ``next_page_number()`` methods of the | the ``previous_page_number()`` and ``next_page_number()`` methods of the | ||||||
| :class:`~django.core.paginator.Page` object did not check if the returned | :class:`~django.core.paginator.Page` object did not check if the returned | ||||||
| number was inside the existing page range. | number was inside the existing page range. | ||||||
| It does check it now and raises an :exc:`InvalidPage` exception when the number | It does check it now and raises an :exc:`~django.core.paginator.InvalidPage` | ||||||
| is either too low or too high. | exception when the number is either too low or too high. | ||||||
|  |  | ||||||
| Behavior of autocommit database option on PostgreSQL changed | Behavior of autocommit database option on PostgreSQL changed | ||||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||||
| @@ -672,7 +672,7 @@ Define a ``__str__`` method and apply the | |||||||
| ``django.utils.itercompat.product`` | ``django.utils.itercompat.product`` | ||||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||||
|  |  | ||||||
| The :func:`~django.utils.itercompat.product` function has been deprecated. Use | The ``django.utils.itercompat.product`` function has been deprecated. Use | ||||||
| the built-in :func:`itertools.product` instead. | the built-in :func:`itertools.product` instead. | ||||||
|  |  | ||||||
| ``django.utils.markup`` | ``django.utils.markup`` | ||||||
|   | |||||||
| @@ -100,7 +100,7 @@ Some features of Django aren't available because they depend on third-party | |||||||
| software that hasn't been ported to Python 3 yet, including: | software that hasn't been ported to Python 3 yet, including: | ||||||
|  |  | ||||||
| - the MySQL database backend (depends on MySQLdb) | - the MySQL database backend (depends on MySQLdb) | ||||||
| - :class:`~django.db.models.fields.ImageField` (depends on PIL) | - :class:`~django.db.models.ImageField` (depends on PIL) | ||||||
| - :class:`~django.test.LiveServerTestCase` (depends on Selenium WebDriver) | - :class:`~django.test.LiveServerTestCase` (depends on Selenium WebDriver) | ||||||
|  |  | ||||||
| Further, Django's more than a web framework; it's an ecosystem of pluggable | Further, Django's more than a web framework; it's an ecosystem of pluggable | ||||||
| @@ -469,7 +469,7 @@ More information on these incompatibilities is available in `ticket #18023`_. | |||||||
|  |  | ||||||
| The net result is that, if you have installed :mod:`simplejson` and your code | The net result is that, if you have installed :mod:`simplejson` and your code | ||||||
| uses Django's serialization internals directly -- for instance | uses Django's serialization internals directly -- for instance | ||||||
| :class:`django.core.serializers.json.DjangoJSONEncoder`, the switch from | ``django.core.serializers.json.DjangoJSONEncoder``, the switch from | ||||||
| :mod:`simplejson` to :mod:`json` could break your code. (In general, changes to | :mod:`simplejson` to :mod:`json` could break your code. (In general, changes to | ||||||
| internals aren't documented; we're making an exception here.) | internals aren't documented; we're making an exception here.) | ||||||
|  |  | ||||||
| @@ -495,8 +495,8 @@ When using :doc:`object pagination </topics/pagination>`, | |||||||
| the ``previous_page_number()`` and ``next_page_number()`` methods of the | the ``previous_page_number()`` and ``next_page_number()`` methods of the | ||||||
| :class:`~django.core.paginator.Page` object did not check if the returned | :class:`~django.core.paginator.Page` object did not check if the returned | ||||||
| number was inside the existing page range. | number was inside the existing page range. | ||||||
| It does check it now and raises an :exc:`InvalidPage` exception when the number | It does check it now and raises an :exc:`~django.core.paginator.InvalidPage` | ||||||
| is either too low or too high. | exception when the number is either too low or too high. | ||||||
|  |  | ||||||
| Behavior of autocommit database option on PostgreSQL changed | Behavior of autocommit database option on PostgreSQL changed | ||||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||||
| @@ -714,7 +714,7 @@ Define a ``__str__`` method and apply the | |||||||
| ``django.utils.itercompat.product`` | ``django.utils.itercompat.product`` | ||||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||||
|  |  | ||||||
| The :func:`~django.utils.itercompat.product` function has been deprecated. Use | The ``django.utils.itercompat.product`` function has been deprecated. Use | ||||||
| the built-in :func:`itertools.product` instead. | the built-in :func:`itertools.product` instead. | ||||||
|  |  | ||||||
| ``cleanup`` management command | ``cleanup`` management command | ||||||
|   | |||||||
| @@ -93,8 +93,8 @@ DetailView: working with a single Django object | |||||||
|  |  | ||||||
| To show the detail of an object, we basically need to do two things: | To show the detail of an object, we basically need to do two things: | ||||||
| we need to look up the object and then we need to make a | we need to look up the object and then we need to make a | ||||||
| :class:`TemplateResponse` with a suitable template, and that object as | :class:`~django.template.response.TemplateResponse` with a suitable template, | ||||||
| context. | and that object as context. | ||||||
|  |  | ||||||
| To get the object, :class:`~django.views.generic.detail.DetailView` | To get the object, :class:`~django.views.generic.detail.DetailView` | ||||||
| relies on :class:`~django.views.generic.detail.SingleObjectMixin`, | relies on :class:`~django.views.generic.detail.SingleObjectMixin`, | ||||||
| @@ -111,15 +111,14 @@ attribute if that's provided). :class:`SingleObjectMixin` also overrides | |||||||
| which is used across all Django's built in class-based views to supply | which is used across all Django's built in class-based views to supply | ||||||
| context data for template renders. | context data for template renders. | ||||||
|  |  | ||||||
| To then make a :class:`TemplateResponse`, :class:`DetailView` uses | To then make a :class:`~django.template.response.TemplateResponse`, | ||||||
|  | :class:`DetailView` uses | ||||||
| :class:`~django.views.generic.detail.SingleObjectTemplateResponseMixin`, | :class:`~django.views.generic.detail.SingleObjectTemplateResponseMixin`, | ||||||
| which extends | which extends :class:`~django.views.generic.base.TemplateResponseMixin`, | ||||||
| :class:`~django.views.generic.base.TemplateResponseMixin`, overriding | overriding :meth:`get_template_names()` as discussed above. It actually | ||||||
| :meth:`get_template_names()` as discussed above. It actually provides | provides a fairly sophisticated set of options, but the main one that most | ||||||
| a fairly sophisticated set of options, but the main one that most | people are going to use is ``<app_label>/<object_name>_detail.html``. The | ||||||
| people are going to use is | ``_detail`` part can be changed by setting | ||||||
| ``<app_label>/<object_name>_detail.html``. The ``_detail`` part can be |  | ||||||
| changed by setting |  | ||||||
| :attr:`~django.views.generic.detail.SingleObjectTemplateResponseMixin.template_name_suffix` | :attr:`~django.views.generic.detail.SingleObjectTemplateResponseMixin.template_name_suffix` | ||||||
| on a subclass to something else. (For instance, the :doc:`generic edit | on a subclass to something else. (For instance, the :doc:`generic edit | ||||||
| views<generic-editing>` use ``_form`` for create and update views, and | views<generic-editing>` use ``_form`` for create and update views, and | ||||||
| @@ -265,7 +264,7 @@ We can hook this into our URLs easily enough:: | |||||||
|  |  | ||||||
| Note the ``pk`` named group, which | Note the ``pk`` named group, which | ||||||
| :meth:`~django.views.generic.detail.SingleObjectMixin.get_object` uses | :meth:`~django.views.generic.detail.SingleObjectMixin.get_object` uses | ||||||
| to look up the :class:`Author` instance. You could also use a slug, or | to look up the ``Author`` instance. You could also use a slug, or | ||||||
| any of the other features of :class:`SingleObjectMixin`. | any of the other features of :class:`SingleObjectMixin`. | ||||||
|  |  | ||||||
| Using SingleObjectMixin with ListView | Using SingleObjectMixin with ListView | ||||||
| @@ -299,7 +298,7 @@ object. In order to do this, we need to have two different querysets: | |||||||
|     will add in the suitable ``page_obj`` and ``paginator`` for us |     will add in the suitable ``page_obj`` and ``paginator`` for us | ||||||
|     providing we remember to call ``super()``. |     providing we remember to call ``super()``. | ||||||
|  |  | ||||||
| Now we can write a new :class:`PublisherDetail`:: | Now we can write a new ``PublisherDetail``:: | ||||||
|  |  | ||||||
|     from django.views.generic import ListView |     from django.views.generic import ListView | ||||||
|     from django.views.generic.detail import SingleObjectMixin |     from django.views.generic.detail import SingleObjectMixin | ||||||
| @@ -403,7 +402,7 @@ At this point it's natural to reach for a :class:`Form` to encapsulate | |||||||
| the information sent from the user's browser to Django. Say also that | the information sent from the user's browser to Django. Say also that | ||||||
| we're heavily invested in `REST`_, so we want to use the same URL for | we're heavily invested in `REST`_, so we want to use the same URL for | ||||||
| displaying the author as for capturing the message from the | displaying the author as for capturing the message from the | ||||||
| user. Let's rewrite our :class:`AuthorDetailView` to do that. | user. Let's rewrite our ``AuthorDetailView`` to do that. | ||||||
|  |  | ||||||
| .. _REST: http://en.wikipedia.org/wiki/Representational_state_transfer | .. _REST: http://en.wikipedia.org/wiki/Representational_state_transfer | ||||||
|  |  | ||||||
| @@ -423,7 +422,7 @@ code so that on ``POST`` the form gets called appropriately. | |||||||
|  |  | ||||||
| .. highlightlang:: python | .. highlightlang:: python | ||||||
|  |  | ||||||
| Our new :class:`AuthorDetail` looks like this:: | Our new ``AuthorDetail`` looks like this:: | ||||||
|  |  | ||||||
|     # CAUTION: you almost certainly do not want to do this. |     # CAUTION: you almost certainly do not want to do this. | ||||||
|     # It is provided as part of a discussion of problems you can |     # It is provided as part of a discussion of problems you can | ||||||
| @@ -507,10 +506,10 @@ clear division here: ``GET`` requests should get the | |||||||
| data), and ``POST`` requests should get the :class:`FormView`. Let's | data), and ``POST`` requests should get the :class:`FormView`. Let's | ||||||
| set up those views first. | set up those views first. | ||||||
|  |  | ||||||
| The :class:`AuthorDisplay` view is almost the same as :ref:`when we | The ``AuthorDisplay`` view is almost the same as :ref:`when we | ||||||
| first introduced AuthorDetail<generic-views-extra-work>`; we have to | first introduced AuthorDetail<generic-views-extra-work>`; we have to | ||||||
| write our own :meth:`get_context_data()` to make the | write our own :meth:`get_context_data()` to make the | ||||||
| :class:`AuthorInterestForm` available to the template. We'll skip the | ``AuthorInterestForm`` available to the template. We'll skip the | ||||||
| :meth:`get_object()` override from before for clarity. | :meth:`get_object()` override from before for clarity. | ||||||
|  |  | ||||||
| .. code-block:: python | .. code-block:: python | ||||||
| @@ -533,11 +532,11 @@ write our own :meth:`get_context_data()` to make the | |||||||
|             context.update(kwargs) |             context.update(kwargs) | ||||||
|             return super(AuthorDisplay, self).get_context_data(**context) |             return super(AuthorDisplay, self).get_context_data(**context) | ||||||
|  |  | ||||||
| Then the :class:`AuthorInterest` is a simple :class:`FormView`, but we | Then the ``AuthorInterest`` is a simple :class:`FormView`, but we | ||||||
| have to bring in :class:`SingleObjectMixin` so we can find the author | have to bring in :class:`SingleObjectMixin` so we can find the author | ||||||
| we're talking about, and we have to remember to set | we're talking about, and we have to remember to set | ||||||
| :attr:`template_name` to ensure that form errors will render the same | :attr:`template_name` to ensure that form errors will render the same | ||||||
| template as :class:`AuthorDisplay` is using on ``GET``. | template as ``AuthorDisplay`` is using on ``GET``. | ||||||
|  |  | ||||||
| .. code-block:: python | .. code-block:: python | ||||||
|  |  | ||||||
| @@ -568,14 +567,14 @@ template as :class:`AuthorDisplay` is using on ``GET``. | |||||||
|             # record the interest using the message in form.cleaned_data |             # record the interest using the message in form.cleaned_data | ||||||
|             return super(AuthorInterest, self).form_valid(form) |             return super(AuthorInterest, self).form_valid(form) | ||||||
|  |  | ||||||
| Finally we bring this together in a new :class:`AuthorDetail` view. We | Finally we bring this together in a new ``AuthorDetail`` view. We | ||||||
| already know that calling :meth:`as_view()` on a class-based view | already know that calling :meth:`as_view()` on a class-based view | ||||||
| gives us something that behaves exactly like a function based view, so | gives us something that behaves exactly like a function based view, so | ||||||
| we can do that at the point we choose between the two subviews. | we can do that at the point we choose between the two subviews. | ||||||
|  |  | ||||||
| You can of course pass through keyword arguments to :meth:`as_view()` | You can of course pass through keyword arguments to :meth:`as_view()` | ||||||
| in the same way you would in your URLconf, such as if you wanted the | in the same way you would in your URLconf, such as if you wanted the | ||||||
| :class:`AuthorInterest` behaviour to also appear at another URL but | ``AuthorInterest`` behaviour to also appear at another URL but | ||||||
| using a different template. | using a different template. | ||||||
|  |  | ||||||
| .. code-block:: python | .. code-block:: python | ||||||
|   | |||||||
| @@ -601,6 +601,8 @@ relation may end up filtering on different linked objects. | |||||||
| Filters can reference fields on the model | Filters can reference fields on the model | ||||||
| ----------------------------------------- | ----------------------------------------- | ||||||
|  |  | ||||||
|  | .. class:: F | ||||||
|  |  | ||||||
| In the examples given so far, we have constructed filters that compare | In the examples given so far, we have constructed filters that compare | ||||||
| the value of a model field with a constant. But what if you want to compare | the value of a model field with a constant. But what if you want to compare | ||||||
| the value of a model field with another field on the same model? | the value of a model field with another field on the same model? | ||||||
| @@ -755,6 +757,8 @@ To avoid this problem, simply save the | |||||||
| Complex lookups with Q objects | Complex lookups with Q objects | ||||||
| ============================== | ============================== | ||||||
|  |  | ||||||
|  | .. class:: Q | ||||||
|  |  | ||||||
| Keyword argument queries -- in :meth:`~django.db.models.query.QuerySet.filter`, | Keyword argument queries -- in :meth:`~django.db.models.query.QuerySet.filter`, | ||||||
| etc. -- are "AND"ed together. If you need to execute more complex queries (for | etc. -- are "AND"ed together. If you need to execute more complex queries (for | ||||||
| example, queries with ``OR`` statements), you can use ``Q`` objects. | example, queries with ``OR`` statements), you can use ``Q`` objects. | ||||||
|   | |||||||
| @@ -37,7 +37,7 @@ display two blank forms:: | |||||||
|  |  | ||||||
| Iterating over the ``formset`` will render the forms in the order they were | Iterating over the ``formset`` will render the forms in the order they were | ||||||
| created. You can change this order by providing an alternate implementation for | created. You can change this order by providing an alternate implementation for | ||||||
| the :meth:`__iter__()` method. | the ``__iter__()`` method. | ||||||
|  |  | ||||||
| Formsets can also be indexed into, which returns the corresponding form. If you | Formsets can also be indexed into, which returns the corresponding form. If you | ||||||
| override ``__iter__``, you will need to also override ``__getitem__`` to have | override ``__iter__``, you will need to also override ``__getitem__`` to have | ||||||
|   | |||||||
| @@ -300,9 +300,9 @@ loop:: | |||||||
|         <p><input type="submit" value="Send message" /></p> |         <p><input type="submit" value="Send message" /></p> | ||||||
|     </form> |     </form> | ||||||
|  |  | ||||||
| Within this loop, ``{{ field }}`` is an instance of :class:`BoundField`. | Within this loop, ``{{ field }}`` is an instance of | ||||||
| ``BoundField`` also has the following attributes, which can be useful in your | :class:`~django.forms.BoundField`. ``BoundField`` also has the following | ||||||
| templates: | attributes, which can be useful in your templates: | ||||||
|  |  | ||||||
| ``{{ field.label }}`` | ``{{ field.label }}`` | ||||||
|     The label of the field, e.g. ``Email address``. |     The label of the field, e.g. ``Email address``. | ||||||
|   | |||||||
| @@ -549,6 +549,8 @@ model's ``clean()`` hook. | |||||||
| Model formsets | Model formsets | ||||||
| ============== | ============== | ||||||
|  |  | ||||||
|  | .. class:: models.BaseModelFormSet | ||||||
|  |  | ||||||
| Like :doc:`regular formsets </topics/forms/formsets>`, Django provides a couple | Like :doc:`regular formsets </topics/forms/formsets>`, Django provides a couple | ||||||
| of enhanced formset classes that make it easy to work with Django models. Let's | of enhanced formset classes that make it easy to work with Django models. Let's | ||||||
| reuse the ``Author`` model from above:: | reuse the ``Author`` model from above:: | ||||||
|   | |||||||
| @@ -264,7 +264,7 @@ You can edit it multiple times. | |||||||
|       - ``modification``: last modification of the session, as a |       - ``modification``: last modification of the session, as a | ||||||
|         :class:`~datetime.datetime` object. Defaults to the current time. |         :class:`~datetime.datetime` object. Defaults to the current time. | ||||||
|       - ``expiry``: expiry information for the session, as a |       - ``expiry``: expiry information for the session, as a | ||||||
|         :class:`~datetime.datetime` object, an :class:`int` (in seconds), or |         :class:`~datetime.datetime` object, an :func:`int` (in seconds), or | ||||||
|         ``None``. Defaults to the value stored in the session by |         ``None``. Defaults to the value stored in the session by | ||||||
|         :meth:`set_expiry`, if there is one, or ``None``. |         :meth:`set_expiry`, if there is one, or ``None``. | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1248,6 +1248,8 @@ The ``set_language`` redirect view | |||||||
|  |  | ||||||
| .. highlightlang:: python | .. highlightlang:: python | ||||||
|  |  | ||||||
|  | .. currentmodule:: django.views.i18n | ||||||
|  |  | ||||||
| .. function:: set_language(request) | .. function:: set_language(request) | ||||||
|  |  | ||||||
| As a convenience, Django comes with a view, :func:`django.views.i18n.set_language`, | As a convenience, Django comes with a view, :func:`django.views.i18n.set_language`, | ||||||
|   | |||||||
| @@ -205,8 +205,8 @@ Attributes | |||||||
|  |  | ||||||
| .. exception:: InvalidPage | .. exception:: InvalidPage | ||||||
|  |  | ||||||
| 	A base class for exceptions raised when a paginator is passed an invalid |     A base class for exceptions raised when a paginator is passed an invalid | ||||||
| 	page number. |     page number. | ||||||
|  |  | ||||||
| The :meth:`Paginator.page` method raises an exception if the requested page is | The :meth:`Paginator.page` method raises an exception if the requested page is | ||||||
| invalid (i.e., not an integer) or contains no objects. Generally, it's enough | invalid (i.e., not an integer) or contains no objects. Generally, it's enough | ||||||
|   | |||||||
| @@ -853,7 +853,7 @@ Normal Python unit test classes extend a base class of | |||||||
|    Hierarchy of Django unit testing classes |    Hierarchy of Django unit testing classes | ||||||
|  |  | ||||||
| Regardless of the version of Python you're using, if you've installed | Regardless of the version of Python you're using, if you've installed | ||||||
| :mod:`unittest2`, :mod:`django.utils.unittest` will point to that library. | ``unittest2``, :mod:`django.utils.unittest` will point to that library. | ||||||
|  |  | ||||||
| SimpleTestCase | SimpleTestCase | ||||||
| ~~~~~~~~~~~~~~ | ~~~~~~~~~~~~~~ | ||||||
| @@ -1376,7 +1376,7 @@ in the ``with`` block and reset its value to the previous state afterwards. | |||||||
| .. function:: override_settings | .. function:: override_settings | ||||||
|  |  | ||||||
| In case you want to override a setting for just one test method or even the | In case you want to override a setting for just one test method or even the | ||||||
| whole :class:`TestCase` class, Django provides the | whole :class:`~django.test.TestCase` class, Django provides the | ||||||
| :func:`~django.test.utils.override_settings` decorator (see :pep:`318`). It's | :func:`~django.test.utils.override_settings` decorator (see :pep:`318`). It's | ||||||
| used like this:: | used like this:: | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user