1
0
mirror of https://github.com/django/django.git synced 2025-10-25 22:56:12 +00:00

[1.7.x] Removed simplejson inventory file from docs/conf.py.

Backport of 695956376f from master
This commit is contained in:
Berker Peksag
2014-10-24 22:35:20 +03:00
committed by Tim Graham
parent 03a20e5abd
commit 7227ec8ecc
2 changed files with 14 additions and 15 deletions

View File

@@ -129,7 +129,6 @@ intersphinx_mapping = {
'python': ('http://docs.python.org/3/', None), 'python': ('http://docs.python.org/3/', None),
'sphinx': ('http://sphinx-doc.org/', None), 'sphinx': ('http://sphinx-doc.org/', None),
'six': ('http://pythonhosted.org/six/', None), 'six': ('http://pythonhosted.org/six/', None),
'simplejson': ('http://simplejson.readthedocs.org/en/latest/', None),
} }
# Python's docs don't change every week. # Python's docs don't change every week.

View File

@@ -474,44 +474,44 @@ client and set the ``content_type`` argument.
.. _simplejson-incompatibilities: .. _simplejson-incompatibilities:
System version of :mod:`simplejson` no longer used System version of ``simplejson`` no longer used
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
:ref:`As explained below <simplejson-deprecation>`, Django 1.5 deprecates :ref:`As explained below <simplejson-deprecation>`, Django 1.5 deprecates
``django.utils.simplejson`` in favor of Python 2.6's built-in :mod:`json` ``django.utils.simplejson`` in favor of Python 2.6's built-in :mod:`json`
module. In theory, this change is harmless. Unfortunately, because of module. In theory, this change is harmless. Unfortunately, because of
incompatibilities between versions of :mod:`simplejson`, it may trigger errors incompatibilities between versions of ``simplejson``, it may trigger errors
in some circumstances. in some circumstances.
JSON-related features in Django 1.4 always used ``django.utils.simplejson``. JSON-related features in Django 1.4 always used ``django.utils.simplejson``.
This module was actually: This module was actually:
- A system version of :mod:`simplejson`, if one was available (ie. ``import - A system version of ``simplejson``, if one was available (ie. ``import
simplejson`` works), if it was more recent than Django's built-in copy or it simplejson`` works), if it was more recent than Django's built-in copy or it
had the C speedups, or had the C speedups, or
- The :mod:`json` module from the standard library, if it was available (ie. - The :mod:`json` module from the standard library, if it was available (ie.
Python 2.6 or greater), or Python 2.6 or greater), or
- A built-in copy of version 2.0.7 of :mod:`simplejson`. - A built-in copy of version 2.0.7 of ``simplejson``.
In Django 1.5, those features use Python's :mod:`json` module, which is based In Django 1.5, those features use Python's :mod:`json` module, which is based
on version 2.0.9 of :mod:`simplejson`. on version 2.0.9 of ``simplejson``.
There are no known incompatibilities between Django's copy of version 2.0.7 and There are no known incompatibilities between Django's copy of version 2.0.7 and
Python's copy of version 2.0.9. However, there are some incompatibilities Python's copy of version 2.0.9. However, there are some incompatibilities
between other versions of :mod:`simplejson`: between other versions of ``simplejson``:
- While the :mod:`simplejson` API is documented as always returning unicode - While the ``simplejson`` API is documented as always returning unicode
strings, the optional C implementation can return a byte string. This was strings, the optional C implementation can return a byte string. This was
fixed in Python 2.7. fixed in Python 2.7.
- :class:`simplejson.JSONEncoder` gained a ``namedtuple_as_object`` keyword - ``simplejson.JSONEncoder`` gained a ``namedtuple_as_object`` keyword
argument in version 2.2. argument in version 2.2.
More information on these incompatibilities is available in `ticket #18023`_. More information on these incompatibilities is available in `ticket #18023`_.
The net result is that, if you have installed :mod:`simplejson` and your code The net result is that, if you have installed ``simplejson`` and your code
uses Django's serialization internals directly -- for instance uses Django's serialization internals directly -- for instance
``django.core.serializers.json.DjangoJSONEncoder``, the switch from ``django.core.serializers.json.DjangoJSONEncoder``, the switch from
:mod:`simplejson` to :mod:`json` could break your code. (In general, changes to ``simplejson`` to :mod:`json` could break your code. (In general, changes to
internals aren't documented; we're making an exception here.) internals aren't documented; we're making an exception here.)
At this point, the maintainers of Django believe that using :mod:`json` from At this point, the maintainers of Django believe that using :mod:`json` from
@@ -771,14 +771,14 @@ In Django 1.7 and above, the iterator will be consumed immediately by
Since Django 1.5 drops support for Python 2.5, we can now rely on the Since Django 1.5 drops support for Python 2.5, we can now rely on the
:mod:`json` module being available in Python's standard library, so we've :mod:`json` module being available in Python's standard library, so we've
removed our own copy of :mod:`simplejson`. You should now import :mod:`json` removed our own copy of ``simplejson``. You should now import :mod:`json`
instead of ``django.utils.simplejson``. instead of ``django.utils.simplejson``.
Unfortunately, this change might have unwanted side-effects, because of Unfortunately, this change might have unwanted side-effects, because of
incompatibilities between versions of :mod:`simplejson` -- see the incompatibilities between versions of ``simplejson`` -- see the
:ref:`backwards-incompatible changes <simplejson-incompatibilities>` section. :ref:`backwards-incompatible changes <simplejson-incompatibilities>` section.
If you rely on features added to :mod:`simplejson` after it became Python's If you rely on features added to ``simplejson`` after it became Python's
:mod:`json`, you should import :mod:`simplejson` explicitly. :mod:`json`, you should import ``simplejson`` explicitly.
``django.utils.encoding.StrAndUnicode`` ``django.utils.encoding.StrAndUnicode``
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~