mirror of
				https://github.com/django/django.git
				synced 2025-10-24 22:26:08 +00:00 
			
		
		
		
	Prevented (and corrected) single backtick usage in docs.
This commit is contained in:
		
				
					committed by
					
						 Carlton Gibson
						Carlton Gibson
					
				
			
			
				
	
			
			
			
						parent
						
							4a6f2b63d7
						
					
				
				
					commit
					1cdfe8d912
				
			| @@ -11,10 +11,11 @@ from docutils.statemachine import ViewList | |||||||
| from sphinx import addnodes | from sphinx import addnodes | ||||||
| from sphinx.builders.html import StandaloneHTMLBuilder | from sphinx.builders.html import StandaloneHTMLBuilder | ||||||
| from sphinx.directives import CodeBlock | from sphinx.directives import CodeBlock | ||||||
|  | from sphinx.errors import SphinxError | ||||||
| from sphinx.domains.std import Cmdoption | from sphinx.domains.std import Cmdoption | ||||||
| from sphinx.errors import ExtensionError | from sphinx.errors import ExtensionError | ||||||
| from sphinx.util import logging | from sphinx.util import logging | ||||||
| from sphinx.util.console import bold | from sphinx.util.console import bold, red | ||||||
| from sphinx.writers.html import HTMLTranslator | from sphinx.writers.html import HTMLTranslator | ||||||
|  |  | ||||||
| logger = logging.getLogger(__name__) | logger = logging.getLogger(__name__) | ||||||
| @@ -67,6 +68,7 @@ def setup(app): | |||||||
|     ) |     ) | ||||||
|     app.add_directive('console', ConsoleDirective) |     app.add_directive('console', ConsoleDirective) | ||||||
|     app.connect('html-page-context', html_page_context_hook) |     app.connect('html-page-context', html_page_context_hook) | ||||||
|  |     app.add_role('default-role-error', default_role_error) | ||||||
|     return {'parallel_read_safe': True} |     return {'parallel_read_safe': True} | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -371,3 +373,14 @@ def html_page_context_hook(app, pagename, templatename, context, doctree): | |||||||
|     # This way it's include only from HTML files rendered from reST files where |     # This way it's include only from HTML files rendered from reST files where | ||||||
|     # the ConsoleDirective is used. |     # the ConsoleDirective is used. | ||||||
|     context['include_console_assets'] = getattr(doctree, '_console_directive_used_flag', False) |     context['include_console_assets'] = getattr(doctree, '_console_directive_used_flag', False) | ||||||
|  |  | ||||||
|  |  | ||||||
|  | def default_role_error( | ||||||
|  |     name, rawtext, text, lineno, inliner, options=None, content=None | ||||||
|  | ): | ||||||
|  |     msg = ( | ||||||
|  |         "Default role used (`single backticks`) at line %s: %s. Did you mean " | ||||||
|  |         "to use two backticks for ``code``, or miss an underscore for a " | ||||||
|  |         "`link`_ ?" % (lineno, rawtext) | ||||||
|  |     ) | ||||||
|  |     raise SphinxError(red(msg)) | ||||||
|   | |||||||
| @@ -127,7 +127,7 @@ today_fmt = '%B %d, %Y' | |||||||
| exclude_patterns = ['_build', '_theme'] | exclude_patterns = ['_build', '_theme'] | ||||||
|  |  | ||||||
| # The reST default role (used for this markup: `text`) to use for all documents. | # The reST default role (used for this markup: `text`) to use for all documents. | ||||||
| # default_role = None | default_role = "default-role-error" | ||||||
|  |  | ||||||
| # If true, '()' will be appended to :func: etc. cross-reference text. | # If true, '()' will be appended to :func: etc. cross-reference text. | ||||||
| add_function_parentheses = True | add_function_parentheses = True | ||||||
|   | |||||||
| @@ -36,7 +36,7 @@ your choice of words. | |||||||
|  |  | ||||||
| .. _message-does-not-appear-on-django-users: | .. _message-does-not-appear-on-django-users: | ||||||
|  |  | ||||||
| Why hasn't my message appeared on `django-users`? | Why hasn't my message appeared on *django-users*? | ||||||
| ================================================= | ================================================= | ||||||
|  |  | ||||||
| |django-users| has a lot of subscribers. This is good for the community, as | |django-users| has a lot of subscribers. This is good for the community, as | ||||||
|   | |||||||
| @@ -10,7 +10,7 @@ during the development of Django applications. | |||||||
| Problems running ``django-admin`` | Problems running ``django-admin`` | ||||||
| ================================= | ================================= | ||||||
|  |  | ||||||
| "command not found: `django-admin`" | ``command not found: django-admin`` | ||||||
| ----------------------------------- | ----------------------------------- | ||||||
|  |  | ||||||
| :doc:`django-admin </ref/django-admin>` should be on your system path if you | :doc:`django-admin </ref/django-admin>` should be on your system path if you | ||||||
|   | |||||||
| @@ -38,7 +38,7 @@ uWSGI model | |||||||
| ----------- | ----------- | ||||||
|  |  | ||||||
| uWSGI operates on a client-server model. Your Web server (e.g., nginx, Apache) | uWSGI operates on a client-server model. Your Web server (e.g., nginx, Apache) | ||||||
| communicates with a `django-uwsgi` "worker" process to serve dynamic content. | communicates with a ``django-uwsgi`` "worker" process to serve dynamic content. | ||||||
|  |  | ||||||
| Configuring and starting the uWSGI server for Django | Configuring and starting the uWSGI server for Django | ||||||
| ---------------------------------------------------- | ---------------------------------------------------- | ||||||
|   | |||||||
| @@ -166,8 +166,8 @@ filtered out of error reports in a production environment (that is, where | |||||||
|             ... |             ... | ||||||
|  |  | ||||||
|     In the above example, the values for the ``user``, ``pw`` and ``cc`` |     In the above example, the values for the ``user``, ``pw`` and ``cc`` | ||||||
|     variables will be hidden and replaced with stars (`**********`) in the |     variables will be hidden and replaced with stars (``**********``) | ||||||
|     error reports, whereas the value of the ``name`` variable will be |     in the error reports, whereas the value of the ``name`` variable will be | ||||||
|     disclosed. |     disclosed. | ||||||
|  |  | ||||||
|     To systematically hide all local variables of a function from error logs, |     To systematically hide all local variables of a function from error logs, | ||||||
| @@ -213,8 +213,9 @@ filtered out of error reports in a production environment (that is, where | |||||||
|  |  | ||||||
|     In the above example, the values for the ``pass_word`` and |     In the above example, the values for the ``pass_word`` and | ||||||
|     ``credit_card_number`` POST parameters will be hidden and replaced with |     ``credit_card_number`` POST parameters will be hidden and replaced with | ||||||
|     stars (`**********`) in the request's representation inside the error |     stars (``**********``) in the request's representation inside the | ||||||
|     reports, whereas the value of the ``name`` parameter will be disclosed. |     error reports, whereas the value of the ``name`` parameter will be | ||||||
|  |     disclosed. | ||||||
|  |  | ||||||
|     To systematically hide all POST parameters of a request in error reports, |     To systematically hide all POST parameters of a request in error reports, | ||||||
|     do not provide any argument to the ``sensitive_post_parameters`` decorator:: |     do not provide any argument to the ``sensitive_post_parameters`` decorator:: | ||||||
| @@ -242,9 +243,9 @@ of reports when an error occurs. The actual filtering is done by Django's | |||||||
| default error reporter filter: | default error reporter filter: | ||||||
| :class:`django.views.debug.SafeExceptionReporterFilter`. This filter uses the | :class:`django.views.debug.SafeExceptionReporterFilter`. This filter uses the | ||||||
| decorators' annotations to replace the corresponding values with stars | decorators' annotations to replace the corresponding values with stars | ||||||
| (`**********`) when the error reports are produced. If you wish to override or | (``**********``) when the error reports are produced. If you wish to | ||||||
| customize this default behavior for your entire site, you need to define your | override or customize this default behavior for your entire site, you need to | ||||||
| own filter class and tell Django to use it via the | define your own filter class and tell Django to use it via the | ||||||
| :setting:`DEFAULT_EXCEPTION_REPORTER_FILTER` setting:: | :setting:`DEFAULT_EXCEPTION_REPORTER_FILTER` setting:: | ||||||
|  |  | ||||||
|     DEFAULT_EXCEPTION_REPORTER_FILTER = 'path.to.your.CustomExceptionReporterFilter' |     DEFAULT_EXCEPTION_REPORTER_FILTER = 'path.to.your.CustomExceptionReporterFilter' | ||||||
| @@ -271,7 +272,8 @@ following attributes and methods: | |||||||
|         .. versionadded:: 3.1 |         .. versionadded:: 3.1 | ||||||
|  |  | ||||||
|         The string value to replace sensitive value with. By default it |         The string value to replace sensitive value with. By default it | ||||||
|         replaces the values of sensitive variables with stars (`**********`). |         replaces the values of sensitive variables with stars | ||||||
|  |         (``**********``). | ||||||
|  |  | ||||||
|     .. attribute:: hidden_settings |     .. attribute:: hidden_settings | ||||||
|  |  | ||||||
|   | |||||||
| @@ -75,8 +75,8 @@ mention: | |||||||
|  |  | ||||||
| * The response will automatically set the MIME type :mimetype:`application/pdf` | * The response will automatically set the MIME type :mimetype:`application/pdf` | ||||||
|   based on the filename extension. This tells browsers that the document is a |   based on the filename extension. This tells browsers that the document is a | ||||||
|   PDF file, rather than an HTML file or a generic `application/octet-stream` |   PDF file, rather than an HTML file or a generic | ||||||
|   binary content. |   :mimetype:`application/octet-stream` binary content. | ||||||
|  |  | ||||||
| * When ``as_attachment=True`` is passed to ``FileResponse``, it sets the | * When ``as_attachment=True`` is passed to ``FileResponse``, it sets the | ||||||
|   appropriate ``Content-Disposition`` header and that tells Web browsers to |   appropriate ``Content-Disposition`` header and that tells Web browsers to | ||||||
|   | |||||||
| @@ -146,7 +146,7 @@ FAQ | |||||||
|    (except the Django fellow), and sometimes folks just don't have time. The |    (except the Django fellow), and sometimes folks just don't have time. The | ||||||
|    best thing to do is to send a gentle reminder to the |django-developers| |    best thing to do is to send a gentle reminder to the |django-developers| | ||||||
|    mailing list asking for review on the ticket, or to bring it up in the |    mailing list asking for review on the ticket, or to bring it up in the | ||||||
|    `#django-dev` IRC channel. |    ``#django-dev`` IRC channel. | ||||||
|  |  | ||||||
| 2. **I'm sure my ticket is absolutely 100% perfect, can I mark it as RFC | 2. **I'm sure my ticket is absolutely 100% perfect, can I mark it as RFC | ||||||
|    myself?** |    myself?** | ||||||
|   | |||||||
| @@ -131,8 +131,8 @@ Testing from the command line | |||||||
|  |  | ||||||
| To run the tests from the command line, you need to have `Node.js`_ installed. | To run the tests from the command line, you need to have `Node.js`_ installed. | ||||||
|  |  | ||||||
| After installing `Node.js`, install the JavaScript test dependencies by running | After installing ``Node.js``, install the JavaScript test dependencies by | ||||||
| the following from the root of your Django checkout: | running the following from the root of your Django checkout: | ||||||
|  |  | ||||||
| .. console:: | .. console:: | ||||||
|  |  | ||||||
|   | |||||||
| @@ -124,7 +124,7 @@ Running the JavaScript tests | |||||||
|  |  | ||||||
| Django includes a set of :ref:`JavaScript unit tests <javascript-tests>` for | Django includes a set of :ref:`JavaScript unit tests <javascript-tests>` for | ||||||
| functions in certain contrib apps. The JavaScript tests aren't run by default | functions in certain contrib apps. The JavaScript tests aren't run by default | ||||||
| using ``tox`` because they require `Node.js` to be installed and aren't | using ``tox`` because they require ``Node.js`` to be installed and aren't | ||||||
| necessary for the majority of patches. To run the JavaScript tests using | necessary for the majority of patches. To run the JavaScript tests using | ||||||
| ``tox``: | ``tox``: | ||||||
|  |  | ||||||
|   | |||||||
| @@ -379,7 +379,7 @@ Now you're ready to actually put the release out there. To do this: | |||||||
|    message body should include the vulnerability details, for example, the |    message body should include the vulnerability details, for example, the | ||||||
|    announcement blog post text. Include a link to the announcement blog post. |    announcement blog post text. Include a link to the announcement blog post. | ||||||
|  |  | ||||||
| #. Add a link to the blog post in the topic of the `#django` IRC channel: | #. Add a link to the blog post in the topic of the ``#django`` IRC channel: | ||||||
|    ``/msg chanserv TOPIC #django new topic goes here``. |    ``/msg chanserv TOPIC #django new topic goes here``. | ||||||
|  |  | ||||||
| Post-release | Post-release | ||||||
|   | |||||||
| @@ -9,8 +9,8 @@ The :class:`GeoIP2` object is a wrapper for the `MaxMind geoip2 Python | |||||||
| library`__. [#]_ | library`__. [#]_ | ||||||
|  |  | ||||||
| In order to perform IP-based geolocation, the :class:`GeoIP2` object requires | In order to perform IP-based geolocation, the :class:`GeoIP2` object requires | ||||||
| the `geoip2 Python library`__ and the GeoIP `Country` and/or `City` `datasets | the `geoip2 Python library`__ and the GeoIP ``Country`` and/or ``City`` | ||||||
| in binary format`__ (the CSV files will not work!). Grab the | `datasets in binary format`__ (the CSV files will not work!). Grab the | ||||||
| ``GeoLite2-Country.mmdb.gz`` and ``GeoLite2-City.mmdb.gz`` files and unzip them | ``GeoLite2-Country.mmdb.gz`` and ``GeoLite2-City.mmdb.gz`` files and unzip them | ||||||
| in a directory corresponding to the :setting:`GEOIP_PATH` setting. | in a directory corresponding to the :setting:`GEOIP_PATH` setting. | ||||||
|  |  | ||||||
|   | |||||||
| @@ -743,9 +743,9 @@ Distance lookups take the following form:: | |||||||
| The value passed into a distance lookup is a tuple; the first two | The value passed into a distance lookup is a tuple; the first two | ||||||
| values are mandatory, and are the geometry to calculate distances to, | values are mandatory, and are the geometry to calculate distances to, | ||||||
| and a distance value (either a number in units of the field, a | and a distance value (either a number in units of the field, a | ||||||
| :class:`~django.contrib.gis.measure.Distance` object, or a `query expression | :class:`~django.contrib.gis.measure.Distance` object, or a :doc:`query | ||||||
| <ref/models/expressions>`). To pass a band index to the lookup, use a 3-tuple | expression </ref/models/expressions>`). To pass a band index to the lookup, use | ||||||
| where the second entry is the band index. | a 3-tuple where the second entry is the band index. | ||||||
|  |  | ||||||
| On every distance lookup except :lookup:`dwithin`, an optional element, | On every distance lookup except :lookup:`dwithin`, an optional element, | ||||||
| ``'spheroid'``, may be included to use the more accurate spheroid distance | ``'spheroid'``, may be included to use the more accurate spheroid distance | ||||||
|   | |||||||
| @@ -531,7 +531,7 @@ Is it a problem that Django's CSRF protection isn't linked to a session by defau | |||||||
| ----------------------------------------------------------------------------------- | ----------------------------------------------------------------------------------- | ||||||
|  |  | ||||||
| No, this is by design. Not linking CSRF protection to a session allows using | No, this is by design. Not linking CSRF protection to a session allows using | ||||||
| the protection on sites such as a `pastebin` that allow submissions from | the protection on sites such as a *pastebin* that allow submissions from | ||||||
| anonymous users which don't have a session. | anonymous users which don't have a session. | ||||||
|  |  | ||||||
| If you wish to store the CSRF token in the user's session, use the | If you wish to store the CSRF token in the user's session, use the | ||||||
|   | |||||||
| @@ -365,7 +365,7 @@ foundation for custom widgets. | |||||||
|         the ``name`` attribute on each subwidget. In this case, for each |         the ``name`` attribute on each subwidget. In this case, for each | ||||||
|         ``(key, widget)`` pair, the key will be appended to the ``name`` of the |         ``(key, widget)`` pair, the key will be appended to the ``name`` of the | ||||||
|         widget in order to generate the attribute value. You may provide the |         widget in order to generate the attribute value. You may provide the | ||||||
|         empty string (`''`) for a single key, in order to suppress the suffix |         empty string (``''``) for a single key, in order to suppress the suffix | ||||||
|         for one widget. For example:: |         for one widget. For example:: | ||||||
|  |  | ||||||
|             >>> widget = MultiWidget(widgets={'': TextInput, 'last': TextInput}) |             >>> widget = MultiWidget(widgets={'': TextInput, 'last': TextInput}) | ||||||
|   | |||||||
| @@ -153,7 +153,7 @@ The first element in each tuple is the name to apply to the group. The | |||||||
| second element is an iterable of 2-tuples, with each 2-tuple containing | second element is an iterable of 2-tuples, with each 2-tuple containing | ||||||
| a value and a human-readable name for an option. Grouped options may be | a value and a human-readable name for an option. Grouped options may be | ||||||
| combined with ungrouped options within a single list (such as the | combined with ungrouped options within a single list (such as the | ||||||
| `unknown` option in this example). | ``'unknown'`` option in this example). | ||||||
|  |  | ||||||
| For each model field that has :attr:`~Field.choices` set, Django will add a | For each model field that has :attr:`~Field.choices` set, Django will add a | ||||||
| method to retrieve the human-readable name for the field's current value. See | method to retrieve the human-readable name for the field's current value. See | ||||||
|   | |||||||
| @@ -798,7 +798,8 @@ Methods | |||||||
|     ``content_type`` is the MIME type optionally completed by a character set |     ``content_type`` is the MIME type optionally completed by a character set | ||||||
|     encoding and is used to fill the HTTP ``Content-Type`` header. If not |     encoding and is used to fill the HTTP ``Content-Type`` header. If not | ||||||
|     specified, it is formed by ``'text/html'`` and the |     specified, it is formed by ``'text/html'`` and the | ||||||
|     :setting:`DEFAULT_CHARSET` settings, by default: "`text/html; charset=utf-8`". |     :setting:`DEFAULT_CHARSET` settings, by default: | ||||||
|  |     ``"text/html; charset=utf-8"``. | ||||||
|  |  | ||||||
|     ``status`` is the :rfc:`HTTP status code <7231#section-6>` for the response. |     ``status`` is the :rfc:`HTTP status code <7231#section-6>` for the response. | ||||||
|     You can use Python's :py:class:`http.HTTPStatus` for meaningful aliases, |     You can use Python's :py:class:`http.HTTPStatus` for meaningful aliases, | ||||||
|   | |||||||
| @@ -109,7 +109,7 @@ many common questions appear with some regularity, and any particular problem | |||||||
| may already have been answered. | may already have been answered. | ||||||
|  |  | ||||||
| Finally, for those who prefer the more immediate feedback offered by IRC, | Finally, for those who prefer the more immediate feedback offered by IRC, | ||||||
| there's a `#django` channel on irc.freenode.net that is regularly populated | there's a ``#django`` channel on irc.freenode.net that is regularly populated | ||||||
| by Django users and developers from around the world. Friendly people are | by Django users and developers from around the world. Friendly people are | ||||||
| usually available at any hour of the day -- to help, or just to chat. | usually available at any hour of the day -- to help, or just to chat. | ||||||
|  |  | ||||||
|   | |||||||
| @@ -10,7 +10,7 @@ Allowed disabling server-side cursors on PostgreSQL | |||||||
| =================================================== | =================================================== | ||||||
|  |  | ||||||
| The change in Django 1.11 to make :meth:`.QuerySet.iterator()` use server-side | The change in Django 1.11 to make :meth:`.QuerySet.iterator()` use server-side | ||||||
| cursors on PostgreSQL prevents running Django with `pgBouncer` in transaction | cursors on PostgreSQL prevents running Django with pgBouncer in transaction | ||||||
| pooling mode. To reallow that, use the :setting:`DISABLE_SERVER_SIDE_CURSORS | pooling mode. To reallow that, use the :setting:`DISABLE_SERVER_SIDE_CURSORS | ||||||
| <DATABASE-DISABLE_SERVER_SIDE_CURSORS>` setting in :setting:`DATABASES`. | <DATABASE-DISABLE_SERVER_SIDE_CURSORS>` setting in :setting:`DATABASES`. | ||||||
|  |  | ||||||
|   | |||||||
| @@ -185,8 +185,8 @@ Minor features | |||||||
|  |  | ||||||
| * PostGIS migrations can now change field dimensions. | * PostGIS migrations can now change field dimensions. | ||||||
|  |  | ||||||
| * Added the ability to pass the `size`, `shape`, and `offset` parameter when | * Added the ability to pass the ``size``, ``shape``, and ``offset`` parameters | ||||||
|   creating :class:`~django.contrib.gis.gdal.GDALRaster` objects. |   when creating :class:`~django.contrib.gis.gdal.GDALRaster` objects. | ||||||
|  |  | ||||||
| * Added SpatiaLite support for the | * Added SpatiaLite support for the | ||||||
|   :class:`~django.contrib.gis.db.models.functions.IsValid` function, |   :class:`~django.contrib.gis.db.models.functions.IsValid` function, | ||||||
| @@ -644,8 +644,8 @@ Server-side cursors on PostgreSQL | |||||||
| --------------------------------- | --------------------------------- | ||||||
|  |  | ||||||
| The change to make :meth:`.QuerySet.iterator()` use server-side cursors on | The change to make :meth:`.QuerySet.iterator()` use server-side cursors on | ||||||
| PostgreSQL prevents running Django with `pgBouncer` in transaction pooling | PostgreSQL prevents running Django with pgBouncer in transaction pooling mode. | ||||||
| mode. To reallow that, use the :setting:`DISABLE_SERVER_SIDE_CURSORS | To reallow that, use the :setting:`DISABLE_SERVER_SIDE_CURSORS | ||||||
| <DATABASE-DISABLE_SERVER_SIDE_CURSORS>` setting (added in Django 1.11.1) in | <DATABASE-DISABLE_SERVER_SIDE_CURSORS>` setting (added in Django 1.11.1) in | ||||||
| :setting:`DATABASES`. | :setting:`DATABASES`. | ||||||
|  |  | ||||||
|   | |||||||
| @@ -811,16 +811,16 @@ This affects the following settings: | |||||||
| =========================================  ========================== | =========================================  ========================== | ||||||
|  Old setting                                New Setting |  Old setting                                New Setting | ||||||
| =========================================  ========================== | =========================================  ========================== | ||||||
| `DATABASE_ENGINE`                          :setting:`ENGINE <DATABASE-ENGINE>` | ``DATABASE_ENGINE``                        :setting:`ENGINE <DATABASE-ENGINE>` | ||||||
| `DATABASE_HOST`                            :setting:`HOST` | ``DATABASE_HOST``                          :setting:`HOST` | ||||||
| `DATABASE_NAME`                            :setting:`NAME` | ``DATABASE_NAME``                          :setting:`NAME` | ||||||
| `DATABASE_OPTIONS`                         :setting:`OPTIONS` | ``DATABASE_OPTIONS``                       :setting:`OPTIONS` | ||||||
| `DATABASE_PASSWORD`                        :setting:`PASSWORD` | ``DATABASE_PASSWORD``                      :setting:`PASSWORD` | ||||||
| `DATABASE_PORT`                            :setting:`PORT` | ``DATABASE_PORT``                          :setting:`PORT` | ||||||
| `DATABASE_USER`                            :setting:`USER` | ``DATABASE_USER``                          :setting:`USER` | ||||||
| `TEST_DATABASE_CHARSET`                    :setting:`TEST_CHARSET` | ``TEST_DATABASE_CHARSET``                  :setting:`TEST_CHARSET` | ||||||
| `TEST_DATABASE_COLLATION`                  :setting:`TEST_COLLATION` | ``TEST_DATABASE_COLLATION``                :setting:`TEST_COLLATION` | ||||||
| `TEST_DATABASE_NAME`                       :setting:`TEST_NAME` | ``TEST_DATABASE_NAME``                     :setting:`TEST_NAME` | ||||||
| =========================================  ========================== | =========================================  ========================== | ||||||
|  |  | ||||||
| These changes are also required if you have manually created a database | These changes are also required if you have manually created a database | ||||||
|   | |||||||
| @@ -40,8 +40,8 @@ Django relies on user input in some cases (e.g. | |||||||
| :doc:`i18n </topics/i18n/index>`) to redirect the user to an "on success" URL. | :doc:`i18n </topics/i18n/index>`) to redirect the user to an "on success" URL. | ||||||
| The security checks for these redirects (namely | The security checks for these redirects (namely | ||||||
| ``django.utils.http.is_safe_url()``) did not correctly validate some malformed | ``django.utils.http.is_safe_url()``) did not correctly validate some malformed | ||||||
| URLs, such as `http:\\\\\\djangoproject.com`, which are accepted by some browsers | URLs, such as ``http:\\\\\\djangoproject.com``, which are accepted by some | ||||||
| with more liberal URL parsing. | browsers with more liberal URL parsing. | ||||||
|  |  | ||||||
| To remedy this, the validation in ``is_safe_url()`` has been tightened to be able | To remedy this, the validation in ``is_safe_url()`` has been tightened to be able | ||||||
| to handle and correctly validate these malformed URLs. | to handle and correctly validate these malformed URLs. | ||||||
|   | |||||||
| @@ -12,7 +12,7 @@ WSGI header spoofing via underscore/dash conflation | |||||||
|  |  | ||||||
| When HTTP headers are placed into the WSGI environ, they are normalized by | When HTTP headers are placed into the WSGI environ, they are normalized by | ||||||
| converting to uppercase, converting all dashes to underscores, and prepending | converting to uppercase, converting all dashes to underscores, and prepending | ||||||
| `HTTP_`. For instance, a header ``X-Auth-User`` would become | ``HTTP_``. For instance, a header ``X-Auth-User`` would become | ||||||
| ``HTTP_X_AUTH_USER`` in the WSGI environ (and thus also in Django's | ``HTTP_X_AUTH_USER`` in the WSGI environ (and thus also in Django's | ||||||
| ``request.META`` dictionary). | ``request.META`` dictionary). | ||||||
|  |  | ||||||
|   | |||||||
| @@ -634,9 +634,9 @@ Django 1.4 also includes several smaller improvements worth noting: | |||||||
|   :meth:`~django.db.models.query.QuerySet.distinct`. |   :meth:`~django.db.models.query.QuerySet.distinct`. | ||||||
|  |  | ||||||
| * The admin login page will add a password reset link if you include a URL with | * The admin login page will add a password reset link if you include a URL with | ||||||
|   the name `'admin_password_reset'` in your urls.py, so plugging in the built-in |   the name ``'admin_password_reset'`` in your urls.py, so plugging in the | ||||||
|   password reset mechanism and making it available is now much easier. For |   built-in password reset mechanism and making it available is now much easier. | ||||||
|   details, see :ref:`auth_password_reset`. |   For details, see :ref:`auth_password_reset`. | ||||||
|  |  | ||||||
| * The MySQL database backend can now make use of the savepoint feature | * The MySQL database backend can now make use of the savepoint feature | ||||||
|   implemented by MySQL version 5.0.3 or newer with the InnoDB storage engine. |   implemented by MySQL version 5.0.3 or newer with the InnoDB storage engine. | ||||||
| @@ -671,9 +671,9 @@ vulnerabilities. No Django site should ever be run without a | |||||||
| :setting:`SECRET_KEY`. | :setting:`SECRET_KEY`. | ||||||
|  |  | ||||||
| In Django 1.4, starting Django with an empty :setting:`SECRET_KEY` will raise a | In Django 1.4, starting Django with an empty :setting:`SECRET_KEY` will raise a | ||||||
| `DeprecationWarning`. In Django 1.5, it will raise an exception and Django will | ``DeprecationWarning``. In Django 1.5, it will raise an exception and Django | ||||||
| refuse to start. This is slightly accelerated from the usual deprecation path | will refuse to start. This is slightly accelerated from the usual deprecation | ||||||
| due to the severity of the consequences of running Django with no | path due to the severity of the consequences of running Django with no | ||||||
| :setting:`SECRET_KEY`. | :setting:`SECRET_KEY`. | ||||||
|  |  | ||||||
| ``django.contrib.admin`` | ``django.contrib.admin`` | ||||||
| @@ -909,8 +909,8 @@ doesn't make any effort to synchronize access to the underlying backend. | |||||||
| Concurrency behavior is defined by the underlying backend implementation. | Concurrency behavior is defined by the underlying backend implementation. | ||||||
| Check their documentation for details. | Check their documentation for details. | ||||||
|  |  | ||||||
| `COMMENTS_BANNED_USERS_GROUP` setting | ``COMMENTS_BANNED_USERS_GROUP`` setting | ||||||
| ------------------------------------- | --------------------------------------- | ||||||
|  |  | ||||||
| Django's comments has historically | Django's comments has historically | ||||||
| supported excluding the comments of a special user group, but we've never | supported excluding the comments of a special user group, but we've never | ||||||
| @@ -946,8 +946,8 @@ Save this model manager in your custom comment app (e.g., in | |||||||
|  |  | ||||||
|         objects = BanningCommentManager() |         objects = BanningCommentManager() | ||||||
|  |  | ||||||
| `IGNORABLE_404_STARTS` and `IGNORABLE_404_ENDS` settings | ``IGNORABLE_404_STARTS`` and ``IGNORABLE_404_ENDS`` settings | ||||||
| -------------------------------------------------------- | ------------------------------------------------------------ | ||||||
|  |  | ||||||
| Until Django 1.3, it was possible to exclude some URLs from Django's | Until Django 1.3, it was possible to exclude some URLs from Django's | ||||||
| :doc:`404 error reporting</howto/error-reporting>` by adding prefixes to | :doc:`404 error reporting</howto/error-reporting>` by adding prefixes to | ||||||
| @@ -1294,8 +1294,8 @@ Now, the flags are keyword arguments of :meth:`@register.filter | |||||||
|  |  | ||||||
| See :ref:`filters and auto-escaping <filters-auto-escaping>` for more information. | See :ref:`filters and auto-escaping <filters-auto-escaping>` for more information. | ||||||
|  |  | ||||||
| Wildcard expansion of application names in `INSTALLED_APPS` | Wildcard expansion of application names in ``INSTALLED_APPS`` | ||||||
| ----------------------------------------------------------- | ------------------------------------------------------------- | ||||||
|  |  | ||||||
| Until Django 1.3, :setting:`INSTALLED_APPS` accepted wildcards in application | Until Django 1.3, :setting:`INSTALLED_APPS` accepted wildcards in application | ||||||
| names, like ``django.contrib.*``. The expansion was performed by a | names, like ``django.contrib.*``. The expansion was performed by a | ||||||
|   | |||||||
| @@ -40,8 +40,8 @@ Django relies on user input in some cases (e.g. | |||||||
| :doc:`i18n </topics/i18n/index>`) to redirect the user to an "on success" URL. | :doc:`i18n </topics/i18n/index>`) to redirect the user to an "on success" URL. | ||||||
| The security checks for these redirects (namely | The security checks for these redirects (namely | ||||||
| ``django.utils.http.is_safe_url()``) did not correctly validate some malformed | ``django.utils.http.is_safe_url()``) did not correctly validate some malformed | ||||||
| URLs, such as `http:\\\\\\djangoproject.com`, which are accepted by some browsers | URLs, such as ``http:\\\\\\djangoproject.com``, which are accepted by some | ||||||
| with more liberal URL parsing. | browsers with more liberal URL parsing. | ||||||
|  |  | ||||||
| To remedy this, the validation in ``is_safe_url()`` has been tightened to be able | To remedy this, the validation in ``is_safe_url()`` has been tightened to be able | ||||||
| to handle and correctly validate these malformed URLs. | to handle and correctly validate these malformed URLs. | ||||||
|   | |||||||
| @@ -615,8 +615,8 @@ database state behind or unit tests that rely on some form of state being | |||||||
| preserved after the execution of other tests. Such tests are already very | preserved after the execution of other tests. Such tests are already very | ||||||
| fragile, and must now be changed to be able to run independently. | fragile, and must now be changed to be able to run independently. | ||||||
|  |  | ||||||
| `cleaned_data` dictionary kept for invalid forms | ``cleaned_data`` dictionary kept for invalid forms | ||||||
| ------------------------------------------------ | -------------------------------------------------- | ||||||
|  |  | ||||||
| The :attr:`~django.forms.Form.cleaned_data` dictionary is now always present | The :attr:`~django.forms.Form.cleaned_data` dictionary is now always present | ||||||
| after form validation. When the form doesn't validate, it contains only the | after form validation. When the form doesn't validate, it contains only the | ||||||
|   | |||||||
| @@ -11,7 +11,7 @@ WSGI header spoofing via underscore/dash conflation | |||||||
|  |  | ||||||
| When HTTP headers are placed into the WSGI environ, they are normalized by | When HTTP headers are placed into the WSGI environ, they are normalized by | ||||||
| converting to uppercase, converting all dashes to underscores, and prepending | converting to uppercase, converting all dashes to underscores, and prepending | ||||||
| `HTTP_`. For instance, a header ``X-Auth-User`` would become | ``HTTP_``. For instance, a header ``X-Auth-User`` would become | ||||||
| ``HTTP_X_AUTH_USER`` in the WSGI environ (and thus also in Django's | ``HTTP_X_AUTH_USER`` in the WSGI environ (and thus also in Django's | ||||||
| ``request.META`` dictionary). | ``request.META`` dictionary). | ||||||
|  |  | ||||||
|   | |||||||
| @@ -40,8 +40,8 @@ Django relies on user input in some cases (e.g. | |||||||
| :doc:`i18n </topics/i18n/index>`) to redirect the user to an "on success" URL. | :doc:`i18n </topics/i18n/index>`) to redirect the user to an "on success" URL. | ||||||
| The security checks for these redirects (namely | The security checks for these redirects (namely | ||||||
| ``django.utils.http.is_safe_url()``) did not correctly validate some malformed | ``django.utils.http.is_safe_url()``) did not correctly validate some malformed | ||||||
| URLs, such as `http:\\\\\\djangoproject.com`, which are accepted by some browsers | URLs, such as ``http:\\\\\\djangoproject.com``, which are accepted by some | ||||||
| with more liberal URL parsing. | browsers with more liberal URL parsing. | ||||||
|  |  | ||||||
| To remedy this, the validation in ``is_safe_url()`` has been tightened to be able | To remedy this, the validation in ``is_safe_url()`` has been tightened to be able | ||||||
| to handle and correctly validate these malformed URLs. | to handle and correctly validate these malformed URLs. | ||||||
|   | |||||||
| @@ -731,7 +731,7 @@ Admin views ``_changelist_filters`` GET parameter | |||||||
| ------------------------------------------------- | ------------------------------------------------- | ||||||
|  |  | ||||||
| To achieve preserving and restoring list view filters, admin views now | To achieve preserving and restoring list view filters, admin views now | ||||||
| pass around the `_changelist_filters` GET parameter. It's important that you | pass around the ``_changelist_filters`` GET parameter. It's important that you | ||||||
| account for that change if you have custom admin templates or if your tests | account for that change if you have custom admin templates or if your tests | ||||||
| rely on the previous URLs. If you want to revert to the original behavior you | rely on the previous URLs. If you want to revert to the original behavior you | ||||||
| can set the | can set the | ||||||
| @@ -924,7 +924,7 @@ Miscellaneous | |||||||
|  |  | ||||||
|     url(r'^reset/done/$', 'django.contrib.auth.views.password_reset_complete', name='password_reset_complete') |     url(r'^reset/done/$', 'django.contrib.auth.views.password_reset_complete', name='password_reset_complete') | ||||||
|  |  | ||||||
| * :class:`~django.views.generic.base.RedirectView` now has a `pattern_name` | * :class:`~django.views.generic.base.RedirectView` now has a ``pattern_name`` | ||||||
|   attribute which allows it to choose the target by reversing the URL. |   attribute which allows it to choose the target by reversing the URL. | ||||||
|  |  | ||||||
| * In Django 1.4 and 1.5, a blank string was unintentionally not considered to | * In Django 1.4 and 1.5, a blank string was unintentionally not considered to | ||||||
|   | |||||||
| @@ -38,7 +38,7 @@ Bugfixes | |||||||
|   adds a ``get_absolute_url()`` method to any model that appears in |   adds a ``get_absolute_url()`` method to any model that appears in | ||||||
|   ``ABSOLUTE_URL_OVERRIDES`` but doesn't define ``get_absolute_url()``. |   ``ABSOLUTE_URL_OVERRIDES`` but doesn't define ``get_absolute_url()``. | ||||||
|  |  | ||||||
| * Avoided masking some `ImportError` exceptions during application loading | * Avoided masking some ``ImportError`` exceptions during application loading | ||||||
|   (:ticket:`22920`). |   (:ticket:`22920`). | ||||||
|  |  | ||||||
| * Empty ``index_together`` or ``unique_together`` model options no longer | * Empty ``index_together`` or ``unique_together`` model options no longer | ||||||
|   | |||||||
| @@ -11,7 +11,7 @@ WSGI header spoofing via underscore/dash conflation | |||||||
|  |  | ||||||
| When HTTP headers are placed into the WSGI environ, they are normalized by | When HTTP headers are placed into the WSGI environ, they are normalized by | ||||||
| converting to uppercase, converting all dashes to underscores, and prepending | converting to uppercase, converting all dashes to underscores, and prepending | ||||||
| `HTTP_`. For instance, a header ``X-Auth-User`` would become | ``HTTP_``. For instance, a header ``X-Auth-User`` would become | ||||||
| ``HTTP_X_AUTH_USER`` in the WSGI environ (and thus also in Django's | ``HTTP_X_AUTH_USER`` in the WSGI environ (and thus also in Django's | ||||||
| ``request.META`` dictionary). | ``request.META`` dictionary). | ||||||
|  |  | ||||||
|   | |||||||
| @@ -479,7 +479,7 @@ Minor features | |||||||
|  |  | ||||||
| * The ``"django.contrib.sessions.backends.cached_db"`` session backend now | * The ``"django.contrib.sessions.backends.cached_db"`` session backend now | ||||||
|   respects :setting:`SESSION_CACHE_ALIAS`. In previous versions, it always used |   respects :setting:`SESSION_CACHE_ALIAS`. In previous versions, it always used | ||||||
|   the `default` cache. |   the ``default`` cache. | ||||||
|  |  | ||||||
| :mod:`django.contrib.sitemaps` | :mod:`django.contrib.sitemaps` | ||||||
| ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ||||||
| @@ -1121,9 +1121,9 @@ as ``error_list``; ``error_dict``; or the return value of | |||||||
| would have previously found strings. | would have previously found strings. | ||||||
|  |  | ||||||
| Also if you directly assigned the return value of ``update_error_dict()`` | Also if you directly assigned the return value of ``update_error_dict()`` | ||||||
| to ``Form._errors`` you may inadvertently add `list` instances where | to ``Form._errors`` you may inadvertently add ``list`` instances where | ||||||
| ``ErrorList`` instances are expected. This is a problem because unlike a | ``ErrorList`` instances are expected. This is a problem because unlike a | ||||||
| simple `list`, an ``ErrorList`` knows how to handle instances of | simple ``list``, an ``ErrorList`` knows how to handle instances of | ||||||
| ``ValidationError``. | ``ValidationError``. | ||||||
|  |  | ||||||
| Most use-cases that warranted using these private APIs are now covered by | Most use-cases that warranted using these private APIs are now covered by | ||||||
|   | |||||||
| @@ -84,7 +84,7 @@ Bugfixes | |||||||
|   ``ModelAdmin.filter_horizontal`` and ``filter_vertical`` options |   ``ModelAdmin.filter_horizontal`` and ``filter_vertical`` options | ||||||
|   (:ticket:`24676`). |   (:ticket:`24676`). | ||||||
|  |  | ||||||
| * Fixed `AttributeError: function 'GDALAllRegister' not found` error when | * Fixed ``AttributeError: function 'GDALAllRegister' not found`` error when | ||||||
|   initializing ``contrib.gis`` on Windows. |   initializing ``contrib.gis`` on Windows. | ||||||
|  |  | ||||||
| Optimizations | Optimizations | ||||||
|   | |||||||
| @@ -152,4 +152,4 @@ Bugfixes | |||||||
| * Fixed a regression in ``URLValidator`` that invalidated Punycode TLDs | * Fixed a regression in ``URLValidator`` that invalidated Punycode TLDs | ||||||
|   (:ticket:`25059`). |   (:ticket:`25059`). | ||||||
|  |  | ||||||
| * Improved `pyinotify` ``runserver`` polling (:ticket:`23882`). | * Improved ``pyinotify`` ``runserver`` polling (:ticket:`23882`). | ||||||
|   | |||||||
| @@ -36,7 +36,7 @@ Bugfixes | |||||||
|   migrations using ``QuerySet.defer()`` from leaking to test and application |   migrations using ``QuerySet.defer()`` from leaking to test and application | ||||||
|   code. |   code. | ||||||
|  |  | ||||||
| * Fixed a typo in the name of the `strictly_above` PostGIS lookup | * Fixed a typo in the name of the ``strictly_above`` PostGIS lookup | ||||||
|   (:ticket:`25592`). |   (:ticket:`25592`). | ||||||
|  |  | ||||||
| * Fixed crash with ``contrib.postgres.forms.SplitArrayField`` and | * Fixed crash with ``contrib.postgres.forms.SplitArrayField`` and | ||||||
|   | |||||||
| @@ -753,10 +753,10 @@ in :doc:`/howto/custom-management-commands`. | |||||||
| Custom test management command arguments through test runner | Custom test management command arguments through test runner | ||||||
| ------------------------------------------------------------ | ------------------------------------------------------------ | ||||||
|  |  | ||||||
| The method to add custom arguments to the `test` management command through the | The method to add custom arguments to the ``test`` management command through | ||||||
| test runner has changed. Previously, you could provide an `option_list` class | the test runner has changed. Previously, you could provide an ``option_list`` | ||||||
| variable on the test runner to add more arguments (à la :py:mod:`optparse`). | class variable on the test runner to add more arguments (à la | ||||||
| Now to implement the same behavior, you have to create an | :py:mod:`optparse`). Now to implement the same behavior, you have to create an | ||||||
| ``add_arguments(cls, parser)`` class method on the test runner and call | ``add_arguments(cls, parser)`` class method on the test runner and call | ||||||
| ``parser.add_argument`` to add any custom arguments, as parser is now an | ``parser.add_argument`` to add any custom arguments, as parser is now an | ||||||
| :py:class:`argparse.ArgumentParser` instance. | :py:class:`argparse.ArgumentParser` instance. | ||||||
|   | |||||||
| @@ -1115,7 +1115,7 @@ Miscellaneous | |||||||
|   :attr:`~django.forms.CharField.strip` argument to ``False``. |   :attr:`~django.forms.CharField.strip` argument to ``False``. | ||||||
|  |  | ||||||
| * Template text that is translated and uses two or more consecutive percent | * Template text that is translated and uses two or more consecutive percent | ||||||
|   signs, e.g. ``"%%"``, may have a new `msgid` after ``makemessages`` is run |   signs, e.g. ``"%%"``, may have a new ``msgid`` after ``makemessages`` is run | ||||||
|   (most likely the translation will be marked fuzzy). The new ``msgid`` will be |   (most likely the translation will be marked fuzzy). The new ``msgid`` will be | ||||||
|   marked ``"#, python-format"``. |   marked ``"#, python-format"``. | ||||||
|  |  | ||||||
| @@ -1506,7 +1506,7 @@ remove usage of these features. | |||||||
| * Database test settings as independent entries in the database settings, | * Database test settings as independent entries in the database settings, | ||||||
|   prefixed by ``TEST_``, are no longer supported. |   prefixed by ``TEST_``, are no longer supported. | ||||||
|  |  | ||||||
| * The `cache_choices` option to :class:`~django.forms.ModelChoiceField` and | * The ``cache_choices`` option to :class:`~django.forms.ModelChoiceField` and | ||||||
|   :class:`~django.forms.ModelMultipleChoiceField` is removed. |   :class:`~django.forms.ModelMultipleChoiceField` is removed. | ||||||
|  |  | ||||||
| * The default value of the | * The default value of the | ||||||
|   | |||||||
| @@ -12,8 +12,8 @@ Bugfixes | |||||||
| * Fixed a crash when filtering with an ``Exists()`` annotation of a queryset | * Fixed a crash when filtering with an ``Exists()`` annotation of a queryset | ||||||
|   containing a single field (:ticket:`29195`). |   containing a single field (:ticket:`29195`). | ||||||
|  |  | ||||||
| * Fixed admin autocomplete widget's translations for `zh-hans` and `zh-hant` | * Fixed admin autocomplete widget's translations for ``zh-hans`` and | ||||||
|   languages (:ticket:`29213`). |   ``zh-hant`` languages (:ticket:`29213`). | ||||||
|  |  | ||||||
| * Corrected admin's autocomplete widget to add a space after custom classes | * Corrected admin's autocomplete widget to add a space after custom classes | ||||||
|   (:ticket:`29221`). |   (:ticket:`29221`). | ||||||
|   | |||||||
| @@ -49,7 +49,7 @@ Bugfixes | |||||||
|  |  | ||||||
| * Fixed a data loss possibility in the admin changelist view when a custom | * Fixed a data loss possibility in the admin changelist view when a custom | ||||||
|   :ref:`formset's prefix <formset-prefix>` contains regular expression special |   :ref:`formset's prefix <formset-prefix>` contains regular expression special | ||||||
|   characters, e.g. `'$'` (:ticket:`31031`). |   characters, e.g. ``'$'`` (:ticket:`31031`). | ||||||
|  |  | ||||||
| * Fixed a regression in Django 2.2.1 that caused a crash when migrating | * Fixed a regression in Django 2.2.1 that caused a crash when migrating | ||||||
|   permissions for proxy models with a multiple database setup if the |   permissions for proxy models with a multiple database setup if the | ||||||
|   | |||||||
| @@ -458,7 +458,7 @@ Miscellaneous | |||||||
|   :func:`~django.contrib.sitemaps.ping_google` function, set the new |   :func:`~django.contrib.sitemaps.ping_google` function, set the new | ||||||
|   ``sitemap_uses_https`` argument to ``False``. |   ``sitemap_uses_https`` argument to ``False``. | ||||||
|  |  | ||||||
| * :djadmin:`runserver` no longer supports `pyinotify` (replaced by Watchman). | * :djadmin:`runserver` no longer supports ``pyinotify`` (replaced by Watchman). | ||||||
|  |  | ||||||
| * The :class:`~django.db.models.Avg`, :class:`~django.db.models.StdDev`, and | * The :class:`~django.db.models.Avg`, :class:`~django.db.models.StdDev`, and | ||||||
|   :class:`~django.db.models.Variance` aggregate functions now return a |   :class:`~django.db.models.Variance` aggregate functions now return a | ||||||
|   | |||||||
| @@ -446,6 +446,7 @@ permalink | |||||||
| pessimization | pessimization | ||||||
| Peucker | Peucker | ||||||
| pgAdmin | pgAdmin | ||||||
|  | pgBouncer | ||||||
| PGRaster | PGRaster | ||||||
| phishing | phishing | ||||||
| php | php | ||||||
|   | |||||||
| @@ -124,7 +124,7 @@ The following path converters are available by default: | |||||||
| * ``str`` - Matches any non-empty string, excluding the path separator, ``'/'``. | * ``str`` - Matches any non-empty string, excluding the path separator, ``'/'``. | ||||||
|   This is the default if a converter isn't included in the expression. |   This is the default if a converter isn't included in the expression. | ||||||
|  |  | ||||||
| * ``int`` - Matches zero or any positive integer. Returns an `int`. | * ``int`` - Matches zero or any positive integer. Returns an ``int``. | ||||||
|  |  | ||||||
| * ``slug`` - Matches any slug string consisting of ASCII letters or numbers, | * ``slug`` - Matches any slug string consisting of ASCII letters or numbers, | ||||||
|   plus the hyphen and underscore characters. For example, |   plus the hyphen and underscore characters. For example, | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user