mirror of
https://github.com/django/django.git
synced 2025-01-18 14:24:39 +00:00
Prevented (and corrected) single backtick usage in docs.
This commit is contained in:
parent
4a6f2b63d7
commit
1cdfe8d912
@ -11,10 +11,11 @@ from docutils.statemachine import ViewList
|
||||
from sphinx import addnodes
|
||||
from sphinx.builders.html import StandaloneHTMLBuilder
|
||||
from sphinx.directives import CodeBlock
|
||||
from sphinx.errors import SphinxError
|
||||
from sphinx.domains.std import Cmdoption
|
||||
from sphinx.errors import ExtensionError
|
||||
from sphinx.util import logging
|
||||
from sphinx.util.console import bold
|
||||
from sphinx.util.console import bold, red
|
||||
from sphinx.writers.html import HTMLTranslator
|
||||
|
||||
logger = logging.getLogger(__name__)
|
||||
@ -67,6 +68,7 @@ def setup(app):
|
||||
)
|
||||
app.add_directive('console', ConsoleDirective)
|
||||
app.connect('html-page-context', html_page_context_hook)
|
||||
app.add_role('default-role-error', default_role_error)
|
||||
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
|
||||
# the ConsoleDirective is used.
|
||||
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']
|
||||
|
||||
# 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.
|
||||
add_function_parentheses = True
|
||||
|
@ -36,7 +36,7 @@ your choice of words.
|
||||
|
||||
.. _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
|
||||
|
@ -10,7 +10,7 @@ during the development of Django applications.
|
||||
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
|
||||
|
@ -38,7 +38,7 @@ uWSGI model
|
||||
-----------
|
||||
|
||||
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
|
||||
----------------------------------------------------
|
||||
|
@ -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``
|
||||
variables will be hidden and replaced with stars (`**********`) in the
|
||||
error reports, whereas the value of the ``name`` variable will be
|
||||
variables will be hidden and replaced with stars (``**********``)
|
||||
in the error reports, whereas the value of the ``name`` variable will be
|
||||
disclosed.
|
||||
|
||||
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
|
||||
``credit_card_number`` POST parameters will be hidden and replaced with
|
||||
stars (`**********`) in the request's representation inside the error
|
||||
reports, whereas the value of the ``name`` parameter will be disclosed.
|
||||
stars (``**********``) in the request's representation inside the
|
||||
error reports, whereas the value of the ``name`` parameter will be
|
||||
disclosed.
|
||||
|
||||
To systematically hide all POST parameters of a request in error reports,
|
||||
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:
|
||||
:class:`django.views.debug.SafeExceptionReporterFilter`. This filter uses the
|
||||
decorators' annotations to replace the corresponding values with stars
|
||||
(`**********`) when the error reports are produced. If you wish to override or
|
||||
customize this default behavior for your entire site, you need to define your
|
||||
own filter class and tell Django to use it via the
|
||||
(``**********``) when the error reports are produced. If you wish to
|
||||
override or customize this default behavior for your entire site, you need to
|
||||
define your own filter class and tell Django to use it via the
|
||||
:setting:`DEFAULT_EXCEPTION_REPORTER_FILTER` setting::
|
||||
|
||||
DEFAULT_EXCEPTION_REPORTER_FILTER = 'path.to.your.CustomExceptionReporterFilter'
|
||||
@ -271,7 +272,8 @@ following attributes and methods:
|
||||
.. versionadded:: 3.1
|
||||
|
||||
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
|
||||
|
||||
|
@ -75,8 +75,8 @@ mention:
|
||||
|
||||
* The response will automatically set the MIME type :mimetype:`application/pdf`
|
||||
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`
|
||||
binary content.
|
||||
PDF file, rather than an HTML file or a generic
|
||||
:mimetype:`application/octet-stream` binary content.
|
||||
|
||||
* When ``as_attachment=True`` is passed to ``FileResponse``, it sets the
|
||||
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
|
||||
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
|
||||
`#django-dev` IRC channel.
|
||||
``#django-dev`` IRC channel.
|
||||
|
||||
2. **I'm sure my ticket is absolutely 100% perfect, can I mark it as RFC
|
||||
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.
|
||||
|
||||
After installing `Node.js`, install the JavaScript test dependencies by running
|
||||
the following from the root of your Django checkout:
|
||||
After installing ``Node.js``, install the JavaScript test dependencies by
|
||||
running the following from the root of your Django checkout:
|
||||
|
||||
.. console::
|
||||
|
||||
|
@ -124,7 +124,7 @@ Running the JavaScript tests
|
||||
|
||||
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
|
||||
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
|
||||
``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
|
||||
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``.
|
||||
|
||||
Post-release
|
||||
|
@ -9,8 +9,8 @@ The :class:`GeoIP2` object is a wrapper for the `MaxMind geoip2 Python
|
||||
library`__. [#]_
|
||||
|
||||
In order to perform IP-based geolocation, the :class:`GeoIP2` object requires
|
||||
the `geoip2 Python library`__ and the GeoIP `Country` and/or `City` `datasets
|
||||
in binary format`__ (the CSV files will not work!). Grab the
|
||||
the `geoip2 Python library`__ and the GeoIP ``Country`` and/or ``City``
|
||||
`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
|
||||
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
|
||||
values are mandatory, and are the geometry to calculate distances to,
|
||||
and a distance value (either a number in units of the field, a
|
||||
:class:`~django.contrib.gis.measure.Distance` object, or a `query expression
|
||||
<ref/models/expressions>`). To pass a band index to the lookup, use a 3-tuple
|
||||
where the second entry is the band index.
|
||||
:class:`~django.contrib.gis.measure.Distance` object, or a :doc:`query
|
||||
expression </ref/models/expressions>`). To pass a band index to the lookup, use
|
||||
a 3-tuple where the second entry is the band index.
|
||||
|
||||
On every distance lookup except :lookup:`dwithin`, an optional element,
|
||||
``'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
|
||||
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.
|
||||
|
||||
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
|
||||
``(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
|
||||
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::
|
||||
|
||||
>>> 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
|
||||
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
|
||||
`unknown` option in this example).
|
||||
``'unknown'`` option in this example).
|
||||
|
||||
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
|
||||
|
@ -798,7 +798,8 @@ Methods
|
||||
``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
|
||||
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.
|
||||
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.
|
||||
|
||||
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
|
||||
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
|
||||
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
|
||||
<DATABASE-DISABLE_SERVER_SIDE_CURSORS>` setting in :setting:`DATABASES`.
|
||||
|
||||
|
@ -185,8 +185,8 @@ Minor features
|
||||
|
||||
* PostGIS migrations can now change field dimensions.
|
||||
|
||||
* Added the ability to pass the `size`, `shape`, and `offset` parameter when
|
||||
creating :class:`~django.contrib.gis.gdal.GDALRaster` objects.
|
||||
* Added the ability to pass the ``size``, ``shape``, and ``offset`` parameters
|
||||
when creating :class:`~django.contrib.gis.gdal.GDALRaster` objects.
|
||||
|
||||
* Added SpatiaLite support for the
|
||||
: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
|
||||
PostgreSQL prevents running Django with `pgBouncer` in transaction pooling
|
||||
mode. To reallow that, use the :setting:`DISABLE_SERVER_SIDE_CURSORS
|
||||
PostgreSQL prevents running Django with pgBouncer in transaction pooling mode.
|
||||
To reallow that, use the :setting:`DISABLE_SERVER_SIDE_CURSORS
|
||||
<DATABASE-DISABLE_SERVER_SIDE_CURSORS>` setting (added in Django 1.11.1) in
|
||||
:setting:`DATABASES`.
|
||||
|
||||
|
@ -811,16 +811,16 @@ This affects the following settings:
|
||||
========================================= ==========================
|
||||
Old setting New Setting
|
||||
========================================= ==========================
|
||||
`DATABASE_ENGINE` :setting:`ENGINE <DATABASE-ENGINE>`
|
||||
`DATABASE_HOST` :setting:`HOST`
|
||||
`DATABASE_NAME` :setting:`NAME`
|
||||
`DATABASE_OPTIONS` :setting:`OPTIONS`
|
||||
`DATABASE_PASSWORD` :setting:`PASSWORD`
|
||||
`DATABASE_PORT` :setting:`PORT`
|
||||
`DATABASE_USER` :setting:`USER`
|
||||
`TEST_DATABASE_CHARSET` :setting:`TEST_CHARSET`
|
||||
`TEST_DATABASE_COLLATION` :setting:`TEST_COLLATION`
|
||||
`TEST_DATABASE_NAME` :setting:`TEST_NAME`
|
||||
``DATABASE_ENGINE`` :setting:`ENGINE <DATABASE-ENGINE>`
|
||||
``DATABASE_HOST`` :setting:`HOST`
|
||||
``DATABASE_NAME`` :setting:`NAME`
|
||||
``DATABASE_OPTIONS`` :setting:`OPTIONS`
|
||||
``DATABASE_PASSWORD`` :setting:`PASSWORD`
|
||||
``DATABASE_PORT`` :setting:`PORT`
|
||||
``DATABASE_USER`` :setting:`USER`
|
||||
``TEST_DATABASE_CHARSET`` :setting:`TEST_CHARSET`
|
||||
``TEST_DATABASE_COLLATION`` :setting:`TEST_COLLATION`
|
||||
``TEST_DATABASE_NAME`` :setting:`TEST_NAME`
|
||||
========================================= ==========================
|
||||
|
||||
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.
|
||||
The security checks for these redirects (namely
|
||||
``django.utils.http.is_safe_url()``) did not correctly validate some malformed
|
||||
URLs, such as `http:\\\\\\djangoproject.com`, which are accepted by some browsers
|
||||
with more liberal URL parsing.
|
||||
URLs, such as ``http:\\\\\\djangoproject.com``, which are accepted by some
|
||||
browsers with more liberal URL parsing.
|
||||
|
||||
To remedy this, the validation in ``is_safe_url()`` has been tightened to be able
|
||||
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
|
||||
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
|
||||
``request.META`` dictionary).
|
||||
|
||||
|
@ -634,9 +634,9 @@ Django 1.4 also includes several smaller improvements worth noting:
|
||||
:meth:`~django.db.models.query.QuerySet.distinct`.
|
||||
|
||||
* 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
|
||||
password reset mechanism and making it available is now much easier. For
|
||||
details, see :ref:`auth_password_reset`.
|
||||
the name ``'admin_password_reset'`` in your urls.py, so plugging in the
|
||||
built-in password reset mechanism and making it available is now much easier.
|
||||
For details, see :ref:`auth_password_reset`.
|
||||
|
||||
* 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.
|
||||
@ -671,9 +671,9 @@ vulnerabilities. No Django site should ever be run without a
|
||||
:setting:`SECRET_KEY`.
|
||||
|
||||
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
|
||||
refuse to start. This is slightly accelerated from the usual deprecation path
|
||||
due to the severity of the consequences of running Django with no
|
||||
``DeprecationWarning``. In Django 1.5, it will raise an exception and Django
|
||||
will refuse to start. This is slightly accelerated from the usual deprecation
|
||||
path due to the severity of the consequences of running Django with no
|
||||
:setting:`SECRET_KEY`.
|
||||
|
||||
``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.
|
||||
Check their documentation for details.
|
||||
|
||||
`COMMENTS_BANNED_USERS_GROUP` setting
|
||||
-------------------------------------
|
||||
``COMMENTS_BANNED_USERS_GROUP`` setting
|
||||
---------------------------------------
|
||||
|
||||
Django's comments has historically
|
||||
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()
|
||||
|
||||
`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
|
||||
: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.
|
||||
|
||||
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
|
||||
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.
|
||||
The security checks for these redirects (namely
|
||||
``django.utils.http.is_safe_url()``) did not correctly validate some malformed
|
||||
URLs, such as `http:\\\\\\djangoproject.com`, which are accepted by some browsers
|
||||
with more liberal URL parsing.
|
||||
URLs, such as ``http:\\\\\\djangoproject.com``, which are accepted by some
|
||||
browsers with more liberal URL parsing.
|
||||
|
||||
To remedy this, the validation in ``is_safe_url()`` has been tightened to be able
|
||||
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
|
||||
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
|
||||
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
|
||||
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
|
||||
``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.
|
||||
The security checks for these redirects (namely
|
||||
``django.utils.http.is_safe_url()``) did not correctly validate some malformed
|
||||
URLs, such as `http:\\\\\\djangoproject.com`, which are accepted by some browsers
|
||||
with more liberal URL parsing.
|
||||
URLs, such as ``http:\\\\\\djangoproject.com``, which are accepted by some
|
||||
browsers with more liberal URL parsing.
|
||||
|
||||
To remedy this, the validation in ``is_safe_url()`` has been tightened to be able
|
||||
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
|
||||
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
|
||||
rely on the previous URLs. If you want to revert to the original behavior you
|
||||
can set the
|
||||
@ -924,7 +924,7 @@ Miscellaneous
|
||||
|
||||
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.
|
||||
|
||||
* 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
|
||||
``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`).
|
||||
|
||||
* 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
|
||||
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
|
||||
``request.META`` dictionary).
|
||||
|
||||
|
@ -479,7 +479,7 @@ Minor features
|
||||
|
||||
* The ``"django.contrib.sessions.backends.cached_db"`` session backend now
|
||||
respects :setting:`SESSION_CACHE_ALIAS`. In previous versions, it always used
|
||||
the `default` cache.
|
||||
the ``default`` cache.
|
||||
|
||||
:mod:`django.contrib.sitemaps`
|
||||
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||
@ -1121,9 +1121,9 @@ as ``error_list``; ``error_dict``; or the return value of
|
||||
would have previously found strings.
|
||||
|
||||
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
|
||||
simple `list`, an ``ErrorList`` knows how to handle instances of
|
||||
simple ``list``, an ``ErrorList`` knows how to handle instances of
|
||||
``ValidationError``.
|
||||
|
||||
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
|
||||
(:ticket:`24676`).
|
||||
|
||||
* Fixed `AttributeError: function 'GDALAllRegister' not found` error when
|
||||
* Fixed ``AttributeError: function 'GDALAllRegister' not found`` error when
|
||||
initializing ``contrib.gis`` on Windows.
|
||||
|
||||
Optimizations
|
||||
|
@ -152,4 +152,4 @@ Bugfixes
|
||||
* Fixed a regression in ``URLValidator`` that invalidated Punycode TLDs
|
||||
(: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
|
||||
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`).
|
||||
|
||||
* 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
|
||||
------------------------------------------------------------
|
||||
|
||||
The method to add custom arguments to the `test` management command through the
|
||||
test runner has changed. Previously, you could provide an `option_list` class
|
||||
variable on the test runner to add more arguments (à la :py:mod:`optparse`).
|
||||
Now to implement the same behavior, you have to create an
|
||||
The method to add custom arguments to the ``test`` management command through
|
||||
the test runner has changed. Previously, you could provide an ``option_list``
|
||||
class variable on the test runner to add more arguments (à la
|
||||
: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
|
||||
``parser.add_argument`` to add any custom arguments, as parser is now an
|
||||
:py:class:`argparse.ArgumentParser` instance.
|
||||
|
@ -1115,7 +1115,7 @@ Miscellaneous
|
||||
:attr:`~django.forms.CharField.strip` argument to ``False``.
|
||||
|
||||
* 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
|
||||
marked ``"#, python-format"``.
|
||||
|
||||
@ -1506,7 +1506,7 @@ remove usage of these features.
|
||||
* Database test settings as independent entries in the database settings,
|
||||
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.
|
||||
|
||||
* The default value of the
|
||||
|
@ -12,8 +12,8 @@ Bugfixes
|
||||
* Fixed a crash when filtering with an ``Exists()`` annotation of a queryset
|
||||
containing a single field (:ticket:`29195`).
|
||||
|
||||
* Fixed admin autocomplete widget's translations for `zh-hans` and `zh-hant`
|
||||
languages (:ticket:`29213`).
|
||||
* Fixed admin autocomplete widget's translations for ``zh-hans`` and
|
||||
``zh-hant`` languages (:ticket:`29213`).
|
||||
|
||||
* Corrected admin's autocomplete widget to add a space after custom classes
|
||||
(:ticket:`29221`).
|
||||
|
@ -49,7 +49,7 @@ Bugfixes
|
||||
|
||||
* Fixed a data loss possibility in the admin changelist view when a custom
|
||||
: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
|
||||
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
|
||||
``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
|
||||
:class:`~django.db.models.Variance` aggregate functions now return a
|
||||
|
@ -446,6 +446,7 @@ permalink
|
||||
pessimization
|
||||
Peucker
|
||||
pgAdmin
|
||||
pgBouncer
|
||||
PGRaster
|
||||
phishing
|
||||
php
|
||||
|
@ -124,7 +124,7 @@ The following path converters are available by default:
|
||||
* ``str`` - Matches any non-empty string, excluding the path separator, ``'/'``.
|
||||
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,
|
||||
plus the hyphen and underscore characters. For example,
|
||||
|
Loading…
x
Reference in New Issue
Block a user