mirror of
https://github.com/django/django.git
synced 2025-10-24 14:16:09 +00:00
Added release notes for app loading changes.
This commit is contained in:
@@ -124,8 +124,8 @@ Application registry
|
|||||||
.. method:: django.apps.apps.get_app_config(app_label, only_with_models_module=False)
|
.. method:: django.apps.apps.get_app_config(app_label, only_with_models_module=False)
|
||||||
|
|
||||||
Returns an :class:`~django.apps.AppConfig` for the application with the
|
Returns an :class:`~django.apps.AppConfig` for the application with the
|
||||||
given ``app_label``. Raises :exc:`LookupError` if no such application
|
given ``app_label``. Raises :exc:`~exceptions.LookupError` if no such
|
||||||
exists.
|
application exists.
|
||||||
|
|
||||||
If only applications containing a models module are of interest, this method
|
If only applications containing a models module are of interest, this method
|
||||||
can be called with ``only_with_models_module=True``.
|
can be called with ``only_with_models_module=True``.
|
||||||
|
@@ -1290,6 +1290,15 @@ Django installation. Each string should be a full Python path to an
|
|||||||
application configuration class or to a Python package containing a
|
application configuration class or to a Python package containing a
|
||||||
application. :ref:` Learn more about applications </ref/applications>`.
|
application. :ref:` Learn more about applications </ref/applications>`.
|
||||||
|
|
||||||
|
.. versionchanged:: 1.7
|
||||||
|
|
||||||
|
:setting:`INSTALLED_APPS` now supports application configurations.
|
||||||
|
|
||||||
|
.. admonition:: Use the application registry for introspection
|
||||||
|
|
||||||
|
Your code should never access :setting:`INSTALLED_APPS` directly. Use the
|
||||||
|
app registry, :attr:`~django.apps.apps`, instead.
|
||||||
|
|
||||||
.. admonition:: Application labels must be unique
|
.. admonition:: Application labels must be unique
|
||||||
|
|
||||||
Application labels (that is, the final part of the dotted path to
|
Application labels (that is, the final part of the dotted path to
|
||||||
|
@@ -58,6 +58,27 @@ but a few of the key features are:
|
|||||||
will still work, but that method name is deprecated and you should change
|
will still work, but that method name is deprecated and you should change
|
||||||
it as soon as possible (nothing more than renaming is required).
|
it as soon as possible (nothing more than renaming is required).
|
||||||
|
|
||||||
|
App-loading refactor
|
||||||
|
~~~~~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
|
Historically, Django applications were tightly linked to models. A singleton
|
||||||
|
known as the "app cache" dealt with both installed applications and models.
|
||||||
|
The models module was used as an identifier for applications in many APIs.
|
||||||
|
|
||||||
|
As the concept of :doc:`Django applications </ref/applications>` matured, this
|
||||||
|
code showed some shortcomings. It was refactored into an "app registry" where
|
||||||
|
models modules no longer have a central role models and where it's possible to
|
||||||
|
attach configuration data to applications.
|
||||||
|
|
||||||
|
Not only does this prepare the ground for further improvements, but it also
|
||||||
|
brings some concrete improvements:
|
||||||
|
|
||||||
|
* It is possible to omit ``models.py`` entirely if an application doesn't
|
||||||
|
have any models.
|
||||||
|
|
||||||
|
* The name of applications can be customized in the admin with the
|
||||||
|
:attr:`~django.apps.AppConfig.verbose_name` of application configurations.
|
||||||
|
|
||||||
New method on Field subclasses
|
New method on Field subclasses
|
||||||
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
@@ -570,6 +591,22 @@ For apps with migrations, ``allow_migrate`` will now get passed
|
|||||||
without custom attributes, methods or managers. Make sure your ``allow_migrate``
|
without custom attributes, methods or managers. Make sure your ``allow_migrate``
|
||||||
methods are only referring to fields or other items in ``model._meta``.
|
methods are only referring to fields or other items in ``model._meta``.
|
||||||
|
|
||||||
|
App-loading changes
|
||||||
|
~~~~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
|
Since :setting:`INSTALLED_APPS` now supports application configuration classes
|
||||||
|
in addition to application modules, you should review code that accesses this
|
||||||
|
setting directly and use the app registry (:attr:`django.apps.apps`) instead.
|
||||||
|
|
||||||
|
The "app registry" that manages the list of installed applications doesn't
|
||||||
|
have the same features as the old "app cache". However, even though the "app
|
||||||
|
cache" was a private API, most of its methods were temporarily preserved and
|
||||||
|
will go through a deprecation path.
|
||||||
|
|
||||||
|
While the new implementation is believed to be more robust, regressions cannot
|
||||||
|
be ruled out, especially during the import sequence. Circular imports that
|
||||||
|
didn't happen with previous versions of Django might appear.
|
||||||
|
|
||||||
Behavior of ``LocMemCache`` regarding pickle errors
|
Behavior of ``LocMemCache`` regarding pickle errors
|
||||||
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user