mirror of
https://github.com/django/django.git
synced 2025-10-24 06:06:09 +00:00
Fixed #27305 -- Removed BaseCommand.can_import_settings unused attribute
Thanks Tim Graham for the review.
This commit is contained in:
@@ -151,12 +151,6 @@ class BaseCommand(object):
|
|||||||
|
|
||||||
Several attributes affect behavior at various steps along the way:
|
Several attributes affect behavior at various steps along the way:
|
||||||
|
|
||||||
``can_import_settings``
|
|
||||||
A boolean indicating whether the command needs to be able to
|
|
||||||
import Django settings; if ``True``, ``execute()`` will verify
|
|
||||||
that this is possible before proceeding. Default value is
|
|
||||||
``True``.
|
|
||||||
|
|
||||||
``help``
|
``help``
|
||||||
A short description of the command, which will be printed in
|
A short description of the command, which will be printed in
|
||||||
help messages.
|
help messages.
|
||||||
@@ -192,17 +186,12 @@ class BaseCommand(object):
|
|||||||
that is locale-sensitive and such content shouldn't contain any
|
that is locale-sensitive and such content shouldn't contain any
|
||||||
translations (like it happens e.g. with django.contrib.auth
|
translations (like it happens e.g. with django.contrib.auth
|
||||||
permissions) as activating any locale might cause unintended effects.
|
permissions) as activating any locale might cause unintended effects.
|
||||||
|
|
||||||
This option can't be False when the can_import_settings option is set
|
|
||||||
to False too because attempting to deactivate translations needs access
|
|
||||||
to settings. This condition will generate a CommandError.
|
|
||||||
"""
|
"""
|
||||||
# Metadata about this command.
|
# Metadata about this command.
|
||||||
help = ''
|
help = ''
|
||||||
|
|
||||||
# Configuration shortcuts that alter various logic.
|
# Configuration shortcuts that alter various logic.
|
||||||
_called_from_command_line = False
|
_called_from_command_line = False
|
||||||
can_import_settings = True
|
|
||||||
output_transaction = False # Whether to wrap the output in a "BEGIN; COMMIT;"
|
output_transaction = False # Whether to wrap the output in a "BEGIN; COMMIT;"
|
||||||
leave_locale_alone = False
|
leave_locale_alone = False
|
||||||
requires_migrations_checks = False
|
requires_migrations_checks = False
|
||||||
@@ -326,15 +315,6 @@ class BaseCommand(object):
|
|||||||
|
|
||||||
saved_locale = None
|
saved_locale = None
|
||||||
if not self.leave_locale_alone:
|
if not self.leave_locale_alone:
|
||||||
# Only mess with locales if we can assume we have a working
|
|
||||||
# settings file, because django.utils.translation requires settings
|
|
||||||
# (The final saying about whether the i18n machinery is active will be
|
|
||||||
# found in the value of the USE_I18N setting)
|
|
||||||
if not self.can_import_settings:
|
|
||||||
raise CommandError("Incompatible values of 'leave_locale_alone' "
|
|
||||||
"(%s) and 'can_import_settings' (%s) command "
|
|
||||||
"options." % (self.leave_locale_alone,
|
|
||||||
self.can_import_settings))
|
|
||||||
# Deactivate translations, because django-admin creates database
|
# Deactivate translations, because django-admin creates database
|
||||||
# content like permissions, and those shouldn't contain any
|
# content like permissions, and those shouldn't contain any
|
||||||
# translations.
|
# translations.
|
||||||
|
@@ -35,9 +35,6 @@ class TemplateCommand(BaseCommand):
|
|||||||
:param options: The additional variables passed to project or app templates
|
:param options: The additional variables passed to project or app templates
|
||||||
"""
|
"""
|
||||||
requires_system_checks = False
|
requires_system_checks = False
|
||||||
# Can't import settings during this command, because they haven't
|
|
||||||
# necessarily been created.
|
|
||||||
can_import_settings = False
|
|
||||||
# The supported URL schemes
|
# The supported URL schemes
|
||||||
url_schemes = ['http', 'https', 'ftp']
|
url_schemes = ['http', 'https', 'ftp']
|
||||||
# Can't perform any active locale changes during this command, because
|
# Can't perform any active locale changes during this command, because
|
||||||
|
@@ -148,7 +148,6 @@ support code::
|
|||||||
|
|
||||||
class Command(BaseCommand):
|
class Command(BaseCommand):
|
||||||
...
|
...
|
||||||
can_import_settings = True
|
|
||||||
|
|
||||||
def handle(self, *args, **options):
|
def handle(self, *args, **options):
|
||||||
|
|
||||||
@@ -208,13 +207,6 @@ Attributes
|
|||||||
All attributes can be set in your derived class and can be used in
|
All attributes can be set in your derived class and can be used in
|
||||||
:class:`BaseCommand`’s :ref:`subclasses<ref-basecommand-subclasses>`.
|
:class:`BaseCommand`’s :ref:`subclasses<ref-basecommand-subclasses>`.
|
||||||
|
|
||||||
.. attribute:: BaseCommand.can_import_settings
|
|
||||||
|
|
||||||
A boolean indicating whether the command needs to be able to
|
|
||||||
import Django settings; if ``True``, ``execute()`` will verify
|
|
||||||
that this is possible before proceeding. Default value is
|
|
||||||
``True``.
|
|
||||||
|
|
||||||
.. attribute:: BaseCommand.help
|
.. attribute:: BaseCommand.help
|
||||||
|
|
||||||
A short description of the command, which will be printed in the
|
A short description of the command, which will be printed in the
|
||||||
@@ -261,11 +253,6 @@ All attributes can be set in your derived class and can be used in
|
|||||||
effects. Seethe `Management commands and locales`_ section above for
|
effects. Seethe `Management commands and locales`_ section above for
|
||||||
further details.
|
further details.
|
||||||
|
|
||||||
This option can't be ``False`` when the
|
|
||||||
:data:`~BaseCommand.can_import_settings` option is set to ``False`` too
|
|
||||||
because attempting to set the locale needs access to settings. This
|
|
||||||
condition will generate a :exc:`CommandError`.
|
|
||||||
|
|
||||||
.. attribute:: BaseCommand.style
|
.. attribute:: BaseCommand.style
|
||||||
|
|
||||||
An instance attribute that helps create colored output when writing to
|
An instance attribute that helps create colored output when writing to
|
||||||
|
@@ -278,6 +278,8 @@ Management Commands
|
|||||||
* The new :option:`loaddata --exclude` option allows excluding models and apps
|
* The new :option:`loaddata --exclude` option allows excluding models and apps
|
||||||
while loading data from fixtures.
|
while loading data from fixtures.
|
||||||
|
|
||||||
|
* The unused ``BaseCommand.can_import_settings`` attribute is removed.
|
||||||
|
|
||||||
Migrations
|
Migrations
|
||||||
~~~~~~~~~~
|
~~~~~~~~~~
|
||||||
|
|
||||||
|
@@ -189,7 +189,7 @@ Minor features
|
|||||||
|
|
||||||
* For custom management commands: Verification of the presence of valid
|
* For custom management commands: Verification of the presence of valid
|
||||||
settings in commands that ask for it by using the
|
settings in commands that ask for it by using the
|
||||||
:attr:`~django.core.management.BaseCommand.can_import_settings` internal
|
``BaseCommand.can_import_settings`` internal
|
||||||
option is now performed independently from handling of the locale that
|
option is now performed independently from handling of the locale that
|
||||||
should be active during the execution of the command. The latter can now be
|
should be active during the execution of the command. The latter can now be
|
||||||
influenced by the new
|
influenced by the new
|
||||||
|
@@ -4,7 +4,6 @@ from django.utils import translation
|
|||||||
|
|
||||||
class Command(BaseCommand):
|
class Command(BaseCommand):
|
||||||
|
|
||||||
can_import_settings = True
|
|
||||||
leave_locale_alone = False
|
leave_locale_alone = False
|
||||||
|
|
||||||
def handle(self, *args, **options):
|
def handle(self, *args, **options):
|
||||||
|
@@ -4,7 +4,6 @@ from django.utils import translation
|
|||||||
|
|
||||||
class Command(BaseCommand):
|
class Command(BaseCommand):
|
||||||
|
|
||||||
can_import_settings = True
|
|
||||||
leave_locale_alone = True
|
leave_locale_alone = True
|
||||||
|
|
||||||
def handle(self, *args, **options):
|
def handle(self, *args, **options):
|
||||||
|
Reference in New Issue
Block a user