mirror of https://github.com/django/django.git
Django coding style fixes.
git-svn-id: http://code.djangoproject.com/svn/django/trunk@6528 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
parent
73f495158c
commit
088cb3c2f3
|
@ -1,31 +1,35 @@
|
||||||
import django
|
|
||||||
from django.core.management.base import BaseCommand, CommandError, handle_default_options
|
|
||||||
from optparse import OptionParser
|
|
||||||
import os
|
import os
|
||||||
import sys
|
import sys
|
||||||
|
from optparse import OptionParser
|
||||||
from imp import find_module
|
from imp import find_module
|
||||||
|
|
||||||
|
import django
|
||||||
|
from django.core.management.base import BaseCommand, CommandError, handle_default_options
|
||||||
|
|
||||||
# For backwards compatibility: get_version() used to be in this module.
|
# For backwards compatibility: get_version() used to be in this module.
|
||||||
get_version = django.get_version
|
get_version = django.get_version
|
||||||
|
|
||||||
# A cache of loaded commands, so that call_command
|
# A cache of loaded commands, so that call_command
|
||||||
# doesn't have to reload every time it is called
|
# doesn't have to reload every time it is called
|
||||||
_commands = None
|
_commands = None
|
||||||
|
|
||||||
def find_commands(management_dir):
|
def find_commands(management_dir):
|
||||||
"""
|
"""
|
||||||
Given a path to a management directory, return a list of all the command names
|
Given a path to a management directory, returns a list of all the command
|
||||||
that are available. Returns an empty list if no commands are defined.
|
names that are available.
|
||||||
|
|
||||||
|
Returns an empty list if no commands are defined.
|
||||||
"""
|
"""
|
||||||
command_dir = os.path.join(management_dir,'commands')
|
command_dir = os.path.join(management_dir, 'commands')
|
||||||
try:
|
try:
|
||||||
return [f[:-3] for f in os.listdir(command_dir) if not f.startswith('_') and f.endswith('.py')]
|
return [f[:-3] for f in os.listdir(command_dir)
|
||||||
|
if not f.startswith('_') and f.endswith('.py')]
|
||||||
except OSError:
|
except OSError:
|
||||||
return []
|
return []
|
||||||
|
|
||||||
def find_management_module(app_name):
|
def find_management_module(app_name):
|
||||||
"""
|
"""
|
||||||
Determine the path to the management module for the application named,
|
Determines the path to the management module for the application named,
|
||||||
without acutally importing the application or the management module.
|
without acutally importing the application or the management module.
|
||||||
|
|
||||||
Raises ImportError if the management module cannot be found for any reason.
|
Raises ImportError if the management module cannot be found for any reason.
|
||||||
|
@ -36,23 +40,23 @@ def find_management_module(app_name):
|
||||||
path = None
|
path = None
|
||||||
while parts:
|
while parts:
|
||||||
part = parts.pop()
|
part = parts.pop()
|
||||||
f,path,descr = find_module(part, path and [path] or None)
|
f, path, descr = find_module(part, path and [path] or None)
|
||||||
return path
|
return path
|
||||||
|
|
||||||
def load_command_class(app_name, name):
|
def load_command_class(app_name, name):
|
||||||
"""
|
"""
|
||||||
Given a command name and an application name, returns the Command
|
Given a command name and an application name, returns the Command
|
||||||
class instance. All errors raised by the importation process
|
class instance. All errors raised by the importation process
|
||||||
(ImportError, AttributeError) are allowed to propagate.
|
(ImportError, AttributeError) are allowed to propagate.
|
||||||
"""
|
"""
|
||||||
return getattr(__import__('%s.management.commands.%s' % (app_name, name),
|
return getattr(__import__('%s.management.commands.%s' % (app_name, name),
|
||||||
{}, {}, ['Command']), 'Command')()
|
{}, {}, ['Command']), 'Command')()
|
||||||
|
|
||||||
def get_commands(load_user_commands=True, project_directory=None):
|
def get_commands(load_user_commands=True, project_directory=None):
|
||||||
"""
|
"""
|
||||||
Returns a dictionary of commands against the application in which
|
Returns a dictionary of commands against the application in which
|
||||||
those commands can be found. This works by looking for a
|
those commands can be found. This works by looking for a
|
||||||
management.commands package in django.core, and in each installed
|
management.commands package in django.core, and in each installed
|
||||||
application -- if a commands package exists, all commands in that
|
application -- if a commands package exists, all commands in that
|
||||||
package are registered.
|
package are registered.
|
||||||
|
|
||||||
|
@ -62,38 +66,38 @@ def get_commands(load_user_commands=True, project_directory=None):
|
||||||
startapp command will be modified to use that directory.
|
startapp command will be modified to use that directory.
|
||||||
|
|
||||||
The dictionary is in the format {command_name: app_name}. Key-value
|
The dictionary is in the format {command_name: app_name}. Key-value
|
||||||
pairs from this dictionary can then be used in calls to
|
pairs from this dictionary can then be used in calls to
|
||||||
load_command_class(app_name, command_name)
|
load_command_class(app_name, command_name)
|
||||||
|
|
||||||
If a specific version of a command must be loaded (e.g., with the
|
If a specific version of a command must be loaded (e.g., with the
|
||||||
startapp command), the instantiated module can be placed in the
|
startapp command), the instantiated module can be placed in the
|
||||||
dictionary in place of the application name.
|
dictionary in place of the application name.
|
||||||
|
|
||||||
The dictionary is cached on the first call, and reused on subsequent
|
The dictionary is cached on the first call, and reused on subsequent
|
||||||
calls.
|
calls.
|
||||||
"""
|
"""
|
||||||
global _commands
|
global _commands
|
||||||
if _commands is None:
|
if _commands is None:
|
||||||
_commands = dict([(name, 'django.core')
|
_commands = dict([(name, 'django.core')
|
||||||
for name in find_commands(__path__[0])])
|
for name in find_commands(__path__[0])])
|
||||||
if load_user_commands:
|
if load_user_commands:
|
||||||
# Get commands from all installed apps
|
# Get commands from all installed apps.
|
||||||
from django.conf import settings
|
from django.conf import settings
|
||||||
for app_name in settings.INSTALLED_APPS:
|
for app_name in settings.INSTALLED_APPS:
|
||||||
try:
|
try:
|
||||||
path = find_management_module(app_name)
|
path = find_management_module(app_name)
|
||||||
_commands.update(dict([(name, app_name)
|
_commands.update(dict([(name, app_name)
|
||||||
for name in find_commands(path)]))
|
for name in find_commands(path)]))
|
||||||
except ImportError:
|
except ImportError:
|
||||||
pass # No management module - ignore this app
|
pass # No management module - ignore this app
|
||||||
|
|
||||||
if project_directory:
|
if project_directory:
|
||||||
# Remove the "startproject" command from self.commands, because
|
# Remove the "startproject" command from self.commands, because
|
||||||
# that's a django-admin.py command, not a manage.py command.
|
# that's a django-admin.py command, not a manage.py command.
|
||||||
del _commands['startproject']
|
del _commands['startproject']
|
||||||
|
|
||||||
# Override the startapp command so that it always uses the
|
# Override the startapp command so that it always uses the
|
||||||
# project_directory, not the current working directory
|
# project_directory, not the current working directory
|
||||||
# (which is default).
|
# (which is default).
|
||||||
from django.core.management.commands.startapp import ProjectCommand
|
from django.core.management.commands.startapp import ProjectCommand
|
||||||
_commands['startapp'] = ProjectCommand(project_directory)
|
_commands['startapp'] = ProjectCommand(project_directory)
|
||||||
|
@ -113,7 +117,7 @@ def call_command(name, *args, **options):
|
||||||
"""
|
"""
|
||||||
try:
|
try:
|
||||||
app_name = get_commands()[name]
|
app_name = get_commands()[name]
|
||||||
if isinstance(app_name, BaseCommand):
|
if isinstance(app_name, BaseCommand):
|
||||||
# If the command is already loaded, use it directly.
|
# If the command is already loaded, use it directly.
|
||||||
klass = app_name
|
klass = app_name
|
||||||
else:
|
else:
|
||||||
|
@ -121,16 +125,16 @@ def call_command(name, *args, **options):
|
||||||
except KeyError:
|
except KeyError:
|
||||||
raise CommandError, "Unknown command: %r" % name
|
raise CommandError, "Unknown command: %r" % name
|
||||||
return klass.execute(*args, **options)
|
return klass.execute(*args, **options)
|
||||||
|
|
||||||
class LaxOptionParser(OptionParser):
|
class LaxOptionParser(OptionParser):
|
||||||
"""
|
"""
|
||||||
An option parser that doesn't raise any errors on unknown options.
|
An option parser that doesn't raise any errors on unknown options.
|
||||||
|
|
||||||
This is needed because the --settings and --pythonpath options affect
|
This is needed because the --settings and --pythonpath options affect
|
||||||
the commands (and thus the options) that are available to the user.
|
the commands (and thus the options) that are available to the user.
|
||||||
"""
|
"""
|
||||||
def error(self, msg):
|
def error(self, msg):
|
||||||
pass
|
pass
|
||||||
|
|
||||||
class ManagementUtility(object):
|
class ManagementUtility(object):
|
||||||
"""
|
"""
|
||||||
|
@ -144,16 +148,19 @@ class ManagementUtility(object):
|
||||||
self.prog_name = os.path.basename(self.argv[0])
|
self.prog_name = os.path.basename(self.argv[0])
|
||||||
self.project_directory = None
|
self.project_directory = None
|
||||||
self.user_commands = False
|
self.user_commands = False
|
||||||
|
|
||||||
def main_help_text(self):
|
def main_help_text(self):
|
||||||
"""
|
"""
|
||||||
Returns the script's main help text, as a string.
|
Returns the script's main help text, as a string.
|
||||||
"""
|
"""
|
||||||
usage = ['%s <subcommand> [options] [args]' % self.prog_name]
|
usage = ['%s <subcommand> [options] [args]' % self.prog_name]
|
||||||
usage.append('Django command line tool, version %s' % django.get_version())
|
usage.append('Django command line tool,'
|
||||||
usage.append("Type '%s help <subcommand>' for help on a specific subcommand." % self.prog_name)
|
' version %s' % django.get_version())
|
||||||
|
usage.append("Type '%s help <subcommand>' for help on a specific"
|
||||||
|
" subcommand." % self.prog_name)
|
||||||
usage.append('Available subcommands:')
|
usage.append('Available subcommands:')
|
||||||
commands = get_commands(self.user_commands, self.project_directory).keys()
|
commands = get_commands(self.user_commands,
|
||||||
|
self.project_directory).keys()
|
||||||
commands.sort()
|
commands.sort()
|
||||||
for cmd in commands:
|
for cmd in commands:
|
||||||
usage.append(' %s' % cmd)
|
usage.append(' %s' % cmd)
|
||||||
|
@ -166,33 +173,35 @@ class ManagementUtility(object):
|
||||||
django-admin.py or manage.py) if it can't be found.
|
django-admin.py or manage.py) if it can't be found.
|
||||||
"""
|
"""
|
||||||
try:
|
try:
|
||||||
app_name = get_commands(self.user_commands, self.project_directory)[subcommand]
|
app_name = get_commands(self.user_commands,
|
||||||
if isinstance(app_name, BaseCommand):
|
self.project_directory)[subcommand]
|
||||||
|
if isinstance(app_name, BaseCommand):
|
||||||
# If the command is already loaded, use it directly.
|
# If the command is already loaded, use it directly.
|
||||||
klass = app_name
|
klass = app_name
|
||||||
else:
|
else:
|
||||||
klass = load_command_class(app_name, subcommand)
|
klass = load_command_class(app_name, subcommand)
|
||||||
except KeyError:
|
except KeyError:
|
||||||
sys.stderr.write("Unknown command: %r\nType '%s help' for usage.\n" % (subcommand, self.prog_name))
|
sys.stderr.write("Unknown command: %r\nType '%s help' for"
|
||||||
|
" usage.\n" % (subcommand, self.prog_name))
|
||||||
sys.exit(1)
|
sys.exit(1)
|
||||||
return klass
|
return klass
|
||||||
|
|
||||||
def execute(self):
|
def execute(self):
|
||||||
"""
|
"""
|
||||||
Given the command-line arguments, this figures out which subcommand is
|
Given the command-line arguments, this figures out which subcommand is
|
||||||
being run, creates a parser appropriate to that command, and runs it.
|
being run, creates a parser appropriate to that command, and runs it.
|
||||||
"""
|
"""
|
||||||
# Preprocess options to extract --settings and --pythonpath. These options
|
# Preprocess options to extract --settings and --pythonpath.
|
||||||
# could affect the commands that are available, so they must be processed
|
# These options could affect the commands that are available, so they
|
||||||
# early
|
# must be processed early.
|
||||||
parser = LaxOptionParser(version=get_version(),
|
parser = LaxOptionParser(version=get_version(),
|
||||||
option_list=BaseCommand.option_list)
|
option_list=BaseCommand.option_list)
|
||||||
try:
|
try:
|
||||||
options, args = parser.parse_args(self.argv)
|
options, args = parser.parse_args(self.argv)
|
||||||
handle_default_options(options)
|
handle_default_options(options)
|
||||||
except:
|
except:
|
||||||
pass # Ignore any option errors at this point.
|
pass # Ignore any option errors at this point.
|
||||||
|
|
||||||
try:
|
try:
|
||||||
subcommand = self.argv[1]
|
subcommand = self.argv[1]
|
||||||
except IndexError:
|
except IndexError:
|
||||||
|
@ -227,10 +236,10 @@ class ProjectManagementUtility(ManagementUtility):
|
||||||
super(ProjectManagementUtility, self).__init__(argv)
|
super(ProjectManagementUtility, self).__init__(argv)
|
||||||
self.project_directory = project_directory
|
self.project_directory = project_directory
|
||||||
self.user_commands = True
|
self.user_commands = True
|
||||||
|
|
||||||
def setup_environ(settings_mod):
|
def setup_environ(settings_mod):
|
||||||
"""
|
"""
|
||||||
Configure the runtime environment. This can also be used by external
|
Configures the runtime environment. This can also be used by external
|
||||||
scripts wanting to set up a similar environment to manage.py.
|
scripts wanting to set up a similar environment to manage.py.
|
||||||
"""
|
"""
|
||||||
# Add this project to sys.path so that it's importable in the conventional
|
# Add this project to sys.path so that it's importable in the conventional
|
||||||
|
@ -244,7 +253,8 @@ def setup_environ(settings_mod):
|
||||||
sys.path.pop()
|
sys.path.pop()
|
||||||
|
|
||||||
# Set DJANGO_SETTINGS_MODULE appropriately.
|
# Set DJANGO_SETTINGS_MODULE appropriately.
|
||||||
os.environ['DJANGO_SETTINGS_MODULE'] = '%s.%s' % (project_name, settings_name)
|
os.environ['DJANGO_SETTINGS_MODULE'] = '%s.%s' % (project_name,
|
||||||
|
settings_name)
|
||||||
return project_directory
|
return project_directory
|
||||||
|
|
||||||
def execute_from_command_line(argv=None):
|
def execute_from_command_line(argv=None):
|
||||||
|
|
|
@ -42,22 +42,25 @@ class MergeDict(object):
|
||||||
if key in dict:
|
if key in dict:
|
||||||
return True
|
return True
|
||||||
return False
|
return False
|
||||||
|
|
||||||
__contains__ = has_key
|
__contains__ = has_key
|
||||||
|
|
||||||
def copy(self):
|
def copy(self):
|
||||||
""" returns a copy of this object"""
|
"""Returns a copy of this object."""
|
||||||
return self.__copy__()
|
return self.__copy__()
|
||||||
|
|
||||||
class SortedDict(dict):
|
class SortedDict(dict):
|
||||||
"A dictionary that keeps its keys in the order in which they're inserted."
|
"""
|
||||||
|
A dictionary that keeps its keys in the order in which they're inserted.
|
||||||
|
"""
|
||||||
def __init__(self, data=None):
|
def __init__(self, data=None):
|
||||||
if data is None: data = {}
|
if data is None:
|
||||||
|
data = {}
|
||||||
dict.__init__(self, data)
|
dict.__init__(self, data)
|
||||||
if isinstance(data, dict):
|
if isinstance(data, dict):
|
||||||
self.keyOrder = data.keys()
|
self.keyOrder = data.keys()
|
||||||
else:
|
else:
|
||||||
self.keyOrder=[key for key, value in data]
|
self.keyOrder = [key for key, value in data]
|
||||||
|
|
||||||
def __setitem__(self, key, value):
|
def __setitem__(self, key, value):
|
||||||
dict.__setitem__(self, key, value)
|
dict.__setitem__(self, key, value)
|
||||||
|
@ -102,20 +105,21 @@ class SortedDict(dict):
|
||||||
return dict.setdefault(self, key, default)
|
return dict.setdefault(self, key, default)
|
||||||
|
|
||||||
def value_for_index(self, index):
|
def value_for_index(self, index):
|
||||||
"Returns the value of the item at the given zero-based index."
|
"""Returns the value of the item at the given zero-based index."""
|
||||||
return self[self.keyOrder[index]]
|
return self[self.keyOrder[index]]
|
||||||
|
|
||||||
def insert(self, index, key, value):
|
def insert(self, index, key, value):
|
||||||
"Inserts the key, value pair before the item with the given index."
|
"""Inserts the key, value pair before the item with the given index."""
|
||||||
if key in self.keyOrder:
|
if key in self.keyOrder:
|
||||||
n = self.keyOrder.index(key)
|
n = self.keyOrder.index(key)
|
||||||
del self.keyOrder[n]
|
del self.keyOrder[n]
|
||||||
if n < index: index -= 1
|
if n < index:
|
||||||
|
index -= 1
|
||||||
self.keyOrder.insert(index, key)
|
self.keyOrder.insert(index, key)
|
||||||
dict.__setitem__(self, key, value)
|
dict.__setitem__(self, key, value)
|
||||||
|
|
||||||
def copy(self):
|
def copy(self):
|
||||||
"Returns a copy of this object."
|
"""Returns a copy of this object."""
|
||||||
# This way of initializing the copy means it works for subclasses, too.
|
# This way of initializing the copy means it works for subclasses, too.
|
||||||
obj = self.__class__(self)
|
obj = self.__class__(self)
|
||||||
obj.keyOrder = self.keyOrder
|
obj.keyOrder = self.keyOrder
|
||||||
|
@ -133,7 +137,8 @@ class MultiValueDictKeyError(KeyError):
|
||||||
|
|
||||||
class MultiValueDict(dict):
|
class MultiValueDict(dict):
|
||||||
"""
|
"""
|
||||||
A subclass of dictionary customized to handle multiple values for the same key.
|
A subclass of dictionary customized to handle multiple values for the
|
||||||
|
same key.
|
||||||
|
|
||||||
>>> d = MultiValueDict({'name': ['Adrian', 'Simon'], 'position': ['Developer']})
|
>>> d = MultiValueDict({'name': ['Adrian', 'Simon'], 'position': ['Developer']})
|
||||||
>>> d['name']
|
>>> d['name']
|
||||||
|
@ -176,15 +181,17 @@ class MultiValueDict(dict):
|
||||||
|
|
||||||
def __deepcopy__(self, memo=None):
|
def __deepcopy__(self, memo=None):
|
||||||
import copy
|
import copy
|
||||||
if memo is None: memo = {}
|
if memo is None:
|
||||||
|
memo = {}
|
||||||
result = self.__class__()
|
result = self.__class__()
|
||||||
memo[id(self)] = result
|
memo[id(self)] = result
|
||||||
for key, value in dict.items(self):
|
for key, value in dict.items(self):
|
||||||
dict.__setitem__(result, copy.deepcopy(key, memo), copy.deepcopy(value, memo))
|
dict.__setitem__(result, copy.deepcopy(key, memo),
|
||||||
|
copy.deepcopy(value, memo))
|
||||||
return result
|
return result
|
||||||
|
|
||||||
def get(self, key, default=None):
|
def get(self, key, default=None):
|
||||||
"Returns the default value if the requested data doesn't exist"
|
"""Returns the default value if the requested data doesn't exist."""
|
||||||
try:
|
try:
|
||||||
val = self[key]
|
val = self[key]
|
||||||
except KeyError:
|
except KeyError:
|
||||||
|
@ -194,7 +201,7 @@ class MultiValueDict(dict):
|
||||||
return val
|
return val
|
||||||
|
|
||||||
def getlist(self, key):
|
def getlist(self, key):
|
||||||
"Returns an empty list if the requested data doesn't exist"
|
"""Returns an empty list if the requested data doesn't exist."""
|
||||||
try:
|
try:
|
||||||
return dict.__getitem__(self, key)
|
return dict.__getitem__(self, key)
|
||||||
except KeyError:
|
except KeyError:
|
||||||
|
@ -214,7 +221,7 @@ class MultiValueDict(dict):
|
||||||
return self.getlist(key)
|
return self.getlist(key)
|
||||||
|
|
||||||
def appendlist(self, key, value):
|
def appendlist(self, key, value):
|
||||||
"Appends an item to the internal list associated with key"
|
"""Appends an item to the internal list associated with key."""
|
||||||
self.setlistdefault(key, [])
|
self.setlistdefault(key, [])
|
||||||
dict.__setitem__(self, key, self.getlist(key) + [value])
|
dict.__setitem__(self, key, self.getlist(key) + [value])
|
||||||
|
|
||||||
|
@ -226,19 +233,22 @@ class MultiValueDict(dict):
|
||||||
return [(key, self[key]) for key in self.keys()]
|
return [(key, self[key]) for key in self.keys()]
|
||||||
|
|
||||||
def lists(self):
|
def lists(self):
|
||||||
"Returns a list of (key, list) pairs."
|
"""Returns a list of (key, list) pairs."""
|
||||||
return dict.items(self)
|
return dict.items(self)
|
||||||
|
|
||||||
def values(self):
|
def values(self):
|
||||||
"Returns a list of the last value on every key list."
|
"""Returns a list of the last value on every key list."""
|
||||||
return [self[key] for key in self.keys()]
|
return [self[key] for key in self.keys()]
|
||||||
|
|
||||||
def copy(self):
|
def copy(self):
|
||||||
"Returns a copy of this object."
|
"""Returns a copy of this object."""
|
||||||
return self.__deepcopy__()
|
return self.__deepcopy__()
|
||||||
|
|
||||||
def update(self, *args, **kwargs):
|
def update(self, *args, **kwargs):
|
||||||
"update() extends rather than replaces existing key lists. Also accepts keyword args."
|
"""
|
||||||
|
update() extends rather than replaces existing key lists.
|
||||||
|
Also accepts keyword args.
|
||||||
|
"""
|
||||||
if len(args) > 1:
|
if len(args) > 1:
|
||||||
raise TypeError, "update expected at most 1 arguments, got %d" % len(args)
|
raise TypeError, "update expected at most 1 arguments, got %d" % len(args)
|
||||||
if args:
|
if args:
|
||||||
|
@ -299,4 +309,3 @@ class FileDict(dict):
|
||||||
d = dict(self, content='<omitted>')
|
d = dict(self, content='<omitted>')
|
||||||
return dict.__repr__(d)
|
return dict.__repr__(d)
|
||||||
return dict.__repr__(self)
|
return dict.__repr__(self)
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue