mirror of
				https://github.com/django/django.git
				synced 2025-10-25 06:36:07 +00:00 
			
		
		
		
	[1.6.x] Fixed #20852 - Fixed incorrectly generated left quotes in docs.
Sphinx generates left single quotes for apostrophes after
code markup, when right single quotes are required. The
easiest way to fix this is just by inserting the unicode
character for a right single quote.
Instances of the problem were found by looking for
">‘" in the generated HTML.
Backport of c33d1ca1d9 from master.
			
			
This commit is contained in:
		
				
					committed by
					
						 Baptiste Mispelon
						Baptiste Mispelon
					
				
			
			
				
	
			
			
			
						parent
						
							2b03d53438
						
					
				
				
					commit
					a9c50fccf2
				
			| @@ -193,7 +193,7 @@ Attributes | |||||||
| ---------- | ---------- | ||||||
|  |  | ||||||
| All attributes can be set in your derived class and can be used in | All attributes can be set in your derived class and can be used in | ||||||
| :class:`BaseCommand`'s :ref:`subclasses<ref-basecommand-subclasses>`. | :class:`BaseCommand`’s :ref:`subclasses<ref-basecommand-subclasses>`. | ||||||
|  |  | ||||||
| .. attribute:: BaseCommand.args | .. attribute:: BaseCommand.args | ||||||
|  |  | ||||||
| @@ -267,7 +267,7 @@ the :meth:`~BaseCommand.handle` method must be implemented. | |||||||
| .. admonition:: Implementing a constructor in a subclass | .. admonition:: Implementing a constructor in a subclass | ||||||
|  |  | ||||||
|   If you implement ``__init__`` in your subclass of :class:`BaseCommand`, |   If you implement ``__init__`` in your subclass of :class:`BaseCommand`, | ||||||
|   you must call :class:`BaseCommand`'s ``__init__``. |   you must call :class:`BaseCommand`’s ``__init__``. | ||||||
|  |  | ||||||
|   .. code-block:: python |   .. code-block:: python | ||||||
|  |  | ||||||
|   | |||||||
| @@ -122,8 +122,8 @@ Filtering sensitive information | |||||||
| Error reports are really helpful for debugging errors, so it is generally | 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:`~django.http.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 | ||||||
| @@ -166,7 +166,7 @@ production environment (that is, where :setting:`DEBUG` is set to ``False``): | |||||||
|     .. admonition:: When using mutiple decorators |     .. admonition:: When using mutiple decorators | ||||||
|  |  | ||||||
|         If the variable you want to hide is also a function argument (e.g. |         If the variable you want to hide is also a function argument (e.g. | ||||||
|         '``user``' in the following example), and if the decorated function has |         '``user``’ in the following example), and if the decorated function has | ||||||
|         mutiple decorators, then make sure to place ``@sensitive_variables`` at |         mutiple decorators, then make sure to place ``@sensitive_variables`` at | ||||||
|         the top of the decorator chain. This way it will also hide the function |         the top of the decorator chain. This way it will also hide the function | ||||||
|         argument as it gets passed through the other decorators:: |         argument as it gets passed through the other decorators:: | ||||||
| @@ -234,7 +234,7 @@ own filter class and tell Django to use it via the | |||||||
|     DEFAULT_EXCEPTION_REPORTER_FILTER = 'path.to.your.CustomExceptionReporterFilter' |     DEFAULT_EXCEPTION_REPORTER_FILTER = 'path.to.your.CustomExceptionReporterFilter' | ||||||
|  |  | ||||||
| You may also control in a more granular way which filter to use within any | You may also control in a more granular way which filter to use within any | ||||||
| given view by setting the ``HttpRequest``'s ``exception_reporter_filter`` | given view by setting the ``HttpRequest``’s ``exception_reporter_filter`` | ||||||
| attribute:: | attribute:: | ||||||
|  |  | ||||||
|     def my_view(request): |     def my_view(request): | ||||||
|   | |||||||
| @@ -132,7 +132,7 @@ We identify a bug | |||||||
| Fortunately, there's a little bug in the ``polls`` application for us to fix | Fortunately, there's a little bug in the ``polls`` application for us to fix | ||||||
| right away: the ``Poll.was_published_recently()`` method returns ``True`` if | right away: the ``Poll.was_published_recently()`` method returns ``True`` if | ||||||
| the ``Poll`` was published within the last day (which is correct) but also if | the ``Poll`` was published within the last day (which is correct) but also if | ||||||
| the ``Poll``'s ``pub_date`` field is in the future (which certainly isn't). | the ``Poll``’s ``pub_date`` field is in the future (which certainly isn't). | ||||||
|  |  | ||||||
| You can see this in the Admin; create a poll whose date lies in the future; | You can see this in the Admin; create a poll whose date lies in the future; | ||||||
| you'll see that the ``Poll`` change list claims it was published recently. | you'll see that the ``Poll`` change list claims it was published recently. | ||||||
|   | |||||||
| @@ -230,7 +230,7 @@ DateMixin | |||||||
|     .. attribute:: date_field |     .. attribute:: date_field | ||||||
|  |  | ||||||
|         The name of the ``DateField`` or ``DateTimeField`` in the |         The name of the ``DateField`` or ``DateTimeField`` in the | ||||||
|         ``QuerySet``'s model that the date-based archive should use to |         ``QuerySet``’s model that the date-based archive should use to | ||||||
|         determine the list of objects to display on the page. |         determine the list of objects to display on the page. | ||||||
|  |  | ||||||
|         When :doc:`time zone support </topics/i18n/timezones>` is enabled and |         When :doc:`time zone support </topics/i18n/timezones>` is enabled and | ||||||
|   | |||||||
| @@ -1590,7 +1590,7 @@ in your own admin JavaScript without including a second copy, you can use the | |||||||
|     The embedded jQuery has been upgraded from 1.4.2 to 1.9.1. |     The embedded jQuery has been upgraded from 1.4.2 to 1.9.1. | ||||||
|  |  | ||||||
| The :class:`ModelAdmin` class requires jQuery by default, so there is no need | The :class:`ModelAdmin` class requires jQuery by default, so there is no need | ||||||
| to add jQuery to your ``ModelAdmin``'s list of media resources unless you have | to add jQuery to your ``ModelAdmin``’s list of media resources unless you have | ||||||
| a specifc need. For example, if you require the jQuery library to be in the | a specifc need. For example, if you require the jQuery library to be in the | ||||||
| global namespace (for example when using third-party jQuery plugins) or if you | global namespace (for example when using third-party jQuery plugins) or if you | ||||||
| need a newer version of jQuery, you will have to include your own copy. | need a newer version of jQuery, you will have to include your own copy. | ||||||
|   | |||||||
| @@ -259,7 +259,7 @@ Manager methods | |||||||
|         be called. |         be called. | ||||||
|  |  | ||||||
|         The ``extra_fields`` keyword arguments are passed through to the |         The ``extra_fields`` keyword arguments are passed through to the | ||||||
|         :class:`~django.contrib.auth.models.User`'s ``__init__`` method to |         :class:`~django.contrib.auth.models.User`’s ``__init__`` method to | ||||||
|         allow setting arbitrary fields on a :ref:`custom User model |         allow setting arbitrary fields on a :ref:`custom User model | ||||||
|         <auth-custom-user>`. |         <auth-custom-user>`. | ||||||
|  |  | ||||||
|   | |||||||
| @@ -54,7 +54,7 @@ following model, which would represent entries in a Weblog:: | |||||||
| Now, suppose that we want the following steps to be applied whenever a | Now, suppose that we want the following steps to be applied whenever a | ||||||
| new comment is posted on an ``Entry``: | new comment is posted on an ``Entry``: | ||||||
|  |  | ||||||
| 1. If the ``Entry``'s ``enable_comments`` field is ``False``, the | 1. If the ``Entry``’s ``enable_comments`` field is ``False``, the | ||||||
|    comment will simply be disallowed (i.e., immediately deleted). |    comment will simply be disallowed (i.e., immediately deleted). | ||||||
|  |  | ||||||
| 2. If the ``enable_comments`` field is ``True``, the comment will be | 2. If the ``enable_comments`` field is ``True``, the comment will be | ||||||
|   | |||||||
| @@ -572,7 +572,7 @@ several lines in language files. | |||||||
|  |  | ||||||
| .. django-admin-option:: --no-location | .. django-admin-option:: --no-location | ||||||
|  |  | ||||||
| Use the ``--no-location`` option to not write '``#: filename:line``' | Use the ``--no-location`` option to not write '``#: filename:line``’ | ||||||
| comment lines in language files. Note that using this option makes it harder | comment lines in language files. Note that using this option makes it harder | ||||||
| for technically skilled translators to understand each message's context. | for technically skilled translators to understand each message's context. | ||||||
|  |  | ||||||
|   | |||||||
| @@ -97,7 +97,7 @@ Django quotes column and table names behind the scenes. | |||||||
|  |  | ||||||
|     The name of an orderable field in the model, typically a :class:`DateField`, |     The name of an orderable field in the model, typically a :class:`DateField`, | ||||||
|     :class:`DateTimeField`, or :class:`IntegerField`. This specifies the default |     :class:`DateTimeField`, or :class:`IntegerField`. This specifies the default | ||||||
|     field to use in your model :class:`Manager`'s |     field to use in your model :class:`Manager`’s | ||||||
|     :meth:`~django.db.models.query.QuerySet.latest` and |     :meth:`~django.db.models.query.QuerySet.latest` and | ||||||
|     :meth:`~django.db.models.query.QuerySet.earliest` methods. |     :meth:`~django.db.models.query.QuerySet.earliest` methods. | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1752,7 +1752,7 @@ Default:: | |||||||
|  |  | ||||||
| A tuple of template loader classes, specified as strings. Each ``Loader`` class | A tuple of template loader classes, specified as strings. Each ``Loader`` class | ||||||
| knows how to import templates from a particular source. Optionally, a tuple can be | knows how to import templates from a particular source. Optionally, a tuple can be | ||||||
| used instead of a string. The first item in the tuple should be the ``Loader``'s | used instead of a string. The first item in the tuple should be the ``Loader``’s | ||||||
| module, subsequent items are passed to the ``Loader`` during initialization. See | module, subsequent items are passed to the ``Loader`` during initialization. See | ||||||
| :doc:`/ref/templates/api`. | :doc:`/ref/templates/api`. | ||||||
|  |  | ||||||
| @@ -2528,7 +2528,7 @@ files</howto/static-files/index>` for more details about usage. | |||||||
|     your static files from their permanent locations into one directory for |     your static files from their permanent locations into one directory for | ||||||
|     ease of deployment; it is **not** a place to store your static files |     ease of deployment; it is **not** a place to store your static files | ||||||
|     permanently. You should do that in directories that will be found by |     permanently. You should do that in directories that will be found by | ||||||
|     :doc:`staticfiles</ref/contrib/staticfiles>`'s |     :doc:`staticfiles</ref/contrib/staticfiles>`’s | ||||||
|     :setting:`finders<STATICFILES_FINDERS>`, which by default, are |     :setting:`finders<STATICFILES_FINDERS>`, which by default, are | ||||||
|     ``'static/'`` app sub-directories and any directories you include in |     ``'static/'`` app sub-directories and any directories you include in | ||||||
|     :setting:`STATICFILES_DIRS`). |     :setting:`STATICFILES_DIRS`). | ||||||
|   | |||||||
| @@ -683,7 +683,7 @@ class. Here are the template loaders that come with Django: | |||||||
|     with your own ``admin/base_site.html`` in ``myproject.polls``. You must |     with your own ``admin/base_site.html`` in ``myproject.polls``. You must | ||||||
|     then make sure that your ``myproject.polls`` comes *before* |     then make sure that your ``myproject.polls`` comes *before* | ||||||
|     ``django.contrib.admin`` in :setting:`INSTALLED_APPS`, otherwise |     ``django.contrib.admin`` in :setting:`INSTALLED_APPS`, otherwise | ||||||
|     ``django.contrib.admin``'s will be loaded first and yours will be ignored. |     ``django.contrib.admin``’s will be loaded first and yours will be ignored. | ||||||
|  |  | ||||||
|     Note that the loader performs an optimization when it is first imported: |     Note that the loader performs an optimization when it is first imported: | ||||||
|     it caches a list of which :setting:`INSTALLED_APPS` packages have a |     it caches a list of which :setting:`INSTALLED_APPS` packages have a | ||||||
|   | |||||||
| @@ -365,7 +365,7 @@ In earlier Django versions, when a model instance containing a | |||||||
| file from the backend storage. This opened the door to several data-loss | file from the backend storage. This opened the door to several data-loss | ||||||
| scenarios, including rolled-back transactions and fields on different models | scenarios, including rolled-back transactions and fields on different models | ||||||
| referencing the same file. In Django 1.3, when a model is deleted the | referencing the same file. In Django 1.3, when a model is deleted the | ||||||
| :class:`~django.db.models.FileField`'s ``delete()`` method won't be called. If | :class:`~django.db.models.FileField`’s ``delete()`` method won't be called. If | ||||||
| you need cleanup of orphaned files, you'll need to handle it yourself (for | you need cleanup of orphaned files, you'll need to handle it yourself (for | ||||||
| instance, with a custom management command that can be run manually or | instance, with a custom management command that can be run manually or | ||||||
| scheduled to run periodically via e.g. cron). | scheduled to run periodically via e.g. cron). | ||||||
| @@ -654,7 +654,7 @@ Password reset view now accepts ``from_email`` | |||||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||||
|  |  | ||||||
| The :func:`django.contrib.auth.views.password_reset` view now accepts a | The :func:`django.contrib.auth.views.password_reset` view now accepts a | ||||||
| ``from_email`` parameter, which is passed to the ``password_reset_form``'s | ``from_email`` parameter, which is passed to the ``password_reset_form``’s | ||||||
| ``save()`` method as a keyword argument. If you are using this view with a | ``save()`` method as a keyword argument. If you are using this view with a | ||||||
| custom password reset form, then you will need to ensure your form's ``save()`` | custom password reset form, then you will need to ensure your form's ``save()`` | ||||||
| method accepts this keyword argument. | method accepts this keyword argument. | ||||||
|   | |||||||
| @@ -201,7 +201,7 @@ Minor features | |||||||
|  |  | ||||||
| * The :attr:`~django.views.generic.edit.DeletionMixin.success_url` of | * The :attr:`~django.views.generic.edit.DeletionMixin.success_url` of | ||||||
|   :class:`~django.views.generic.edit.DeletionMixin` is now interpolated with |   :class:`~django.views.generic.edit.DeletionMixin` is now interpolated with | ||||||
|   its ``object``\'s ``__dict__``. |   its ``object``’s ``__dict__``. | ||||||
|  |  | ||||||
| * :class:`~django.http.HttpResponseRedirect` and | * :class:`~django.http.HttpResponseRedirect` and | ||||||
|   :class:`~django.http.HttpResponsePermanentRedirect` now provide an ``url`` |   :class:`~django.http.HttpResponsePermanentRedirect` now provide an ``url`` | ||||||
| @@ -344,7 +344,7 @@ Minor features | |||||||
|  |  | ||||||
| * :class:`~django.forms.ModelForm` fields can now override error messages | * :class:`~django.forms.ModelForm` fields can now override error messages | ||||||
|   defined in model fields by using the |   defined in model fields by using the | ||||||
|   :attr:`~django.forms.Field.error_messages` argument of a ``Field``'s |   :attr:`~django.forms.Field.error_messages` argument of a ``Field``’s | ||||||
|   constructor. To take advantage of this new feature with your custom fields, |   constructor. To take advantage of this new feature with your custom fields, | ||||||
|   :ref:`see the updated recommendation <raising-validation-error>` for raising |   :ref:`see the updated recommendation <raising-validation-error>` for raising | ||||||
|   a ``ValidationError``. |   a ``ValidationError``. | ||||||
|   | |||||||
| @@ -288,7 +288,7 @@ object. In order to do this, we need to have two different querysets: | |||||||
|  |  | ||||||
| ``Book`` queryset for use by :class:`~django.views.generic.list.ListView` | ``Book`` queryset for use by :class:`~django.views.generic.list.ListView` | ||||||
|     Since we have access to the ``Publisher`` whose books we want to list, we |     Since we have access to the ``Publisher`` whose books we want to list, we | ||||||
|     simply override ``get_queryset()`` and use the ``Publisher``'s |     simply override ``get_queryset()`` and use the ``Publisher``’s | ||||||
|     :ref:`reverse foreign key manager<backwards-related-objects>`. |     :ref:`reverse foreign key manager<backwards-related-objects>`. | ||||||
|  |  | ||||||
| ``Publisher`` queryset for use in :meth:`~django.views.generic.detail.SingleObjectMixin.get_object()` | ``Publisher`` queryset for use in :meth:`~django.views.generic.detail.SingleObjectMixin.get_object()` | ||||||
|   | |||||||
| @@ -100,7 +100,7 @@ access ``self.model`` to get the model class to which they're attached. | |||||||
| Modifying initial Manager QuerySets | Modifying initial Manager QuerySets | ||||||
| ----------------------------------- | ----------------------------------- | ||||||
|  |  | ||||||
| A ``Manager``'s base ``QuerySet`` returns all objects in the system. For | A ``Manager``’s base ``QuerySet`` returns all objects in the system. For | ||||||
| example, using this model:: | example, using this model:: | ||||||
|  |  | ||||||
|     from django.db import models |     from django.db import models | ||||||
| @@ -111,7 +111,7 @@ example, using this model:: | |||||||
|  |  | ||||||
| ...the statement ``Book.objects.all()`` will return all books in the database. | ...the statement ``Book.objects.all()`` will return all books in the database. | ||||||
|  |  | ||||||
| You can override a ``Manager``\'s base ``QuerySet`` by overriding the | You can override a ``Manager``’s base ``QuerySet`` by overriding the | ||||||
| ``Manager.get_queryset()`` method. ``get_queryset()`` should return a | ``Manager.get_queryset()`` method. ``get_queryset()`` should return a | ||||||
| ``QuerySet`` with the properties you require. | ``QuerySet`` with the properties you require. | ||||||
|  |  | ||||||
|   | |||||||
| @@ -724,7 +724,7 @@ efficient code. | |||||||
| In a newly created :class:`~django.db.models.query.QuerySet`, the cache is | In a newly created :class:`~django.db.models.query.QuerySet`, the cache is | ||||||
| empty. The first time a :class:`~django.db.models.query.QuerySet` is evaluated | empty. The first time a :class:`~django.db.models.query.QuerySet` is evaluated | ||||||
| -- and, hence, a database query happens -- Django saves the query results in | -- and, hence, a database query happens -- Django saves the query results in | ||||||
| the :class:`~django.db.models.query.QuerySet`\'s cache and returns the results | the :class:`~django.db.models.query.QuerySet`’s cache and returns the results | ||||||
| that have been explicitly requested (e.g., the next element, if the | that have been explicitly requested (e.g., the next element, if the | ||||||
| :class:`~django.db.models.query.QuerySet` is being iterated over). Subsequent | :class:`~django.db.models.query.QuerySet` is being iterated over). Subsequent | ||||||
| evaluations of the :class:`~django.db.models.query.QuerySet` reuse the cached | evaluations of the :class:`~django.db.models.query.QuerySet` reuse the cached | ||||||
|   | |||||||
| @@ -30,7 +30,7 @@ Declaring tablespaces for indexes | |||||||
| --------------------------------- | --------------------------------- | ||||||
|  |  | ||||||
| You can pass the :attr:`~django.db.models.Field.db_tablespace` option to a | You can pass the :attr:`~django.db.models.Field.db_tablespace` option to a | ||||||
| ``Field`` constructor to specify an alternate tablespace for the ``Field``'s | ``Field`` constructor to specify an alternate tablespace for the ``Field``’s | ||||||
| column index. If no index would be created for the column, the option is | column index. If no index would be created for the column, the option is | ||||||
| ignored. | ignored. | ||||||
|  |  | ||||||
|   | |||||||
| @@ -392,7 +392,7 @@ these security concerns do not apply to you: | |||||||
|                model = Author |                model = Author | ||||||
|                fields = '__all__' |                fields = '__all__' | ||||||
|  |  | ||||||
| 2. Set the ``exclude`` attribute of the ``ModelForm``'s inner ``Meta`` class to | 2. Set the ``exclude`` attribute of the ``ModelForm``’s inner ``Meta`` class to | ||||||
|    a list of fields to be excluded from the form. |    a list of fields to be excluded from the form. | ||||||
|  |  | ||||||
|    For example:: |    For example:: | ||||||
| @@ -768,7 +768,7 @@ Specifying widgets to use in the form with ``widgets`` | |||||||
| .. versionadded:: 1.6 | .. versionadded:: 1.6 | ||||||
|  |  | ||||||
| Using the ``widgets`` parameter, you can specify a dictionary of values to | Using the ``widgets`` parameter, you can specify a dictionary of values to | ||||||
| customize the ``ModelForm``'s widget class for a particular field. This | customize the ``ModelForm``’s widget class for a particular field. This | ||||||
| works the same way as the ``widgets`` dictionary on the inner ``Meta`` | works the same way as the ``widgets`` dictionary on the inner ``Meta`` | ||||||
| class of a ``ModelForm`` works:: | class of a ``ModelForm`` works:: | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user