|
@@ -1,20 +1,23 @@
|
|
|
import os
|
|
|
+import warnings
|
|
|
|
|
|
from django.core.management.base import BaseCommand
|
|
|
+from django.utils.deprecation import RemovedInDjango20Warning
|
|
|
|
|
|
|
|
|
class Command(BaseCommand):
|
|
|
help = "Runs a Python interactive interpreter. Tries to use IPython or bpython, if one of them is available."
|
|
|
requires_system_checks = False
|
|
|
- shells = ['ipython', 'bpython']
|
|
|
+ shells = ['ipython', 'bpython', 'python']
|
|
|
|
|
|
def add_arguments(self, parser):
|
|
|
parser.add_argument('--plain', action='store_true', dest='plain',
|
|
|
- help='Tells Django to use plain Python, not IPython or bpython.')
|
|
|
+ help='Tells Django to use plain Python, not IPython or bpython. '
|
|
|
+ 'Deprecated, use the `-i python` or `--interface python` option instead.')
|
|
|
parser.add_argument('--no-startup', action='store_true', dest='no_startup',
|
|
|
help='When using plain Python, ignore the PYTHONSTARTUP environment variable and ~/.pythonrc.py script.')
|
|
|
parser.add_argument('-i', '--interface', choices=self.shells, dest='interface',
|
|
|
- help='Specify an interactive interpreter interface. Available options: "ipython" and "bpython"')
|
|
|
+ help='Specify an interactive interpreter interface. Available options: "ipython", "bpython", and "python"')
|
|
|
|
|
|
def _ipython_pre_011(self):
|
|
|
"""Start IPython pre-0.11"""
|
|
@@ -34,7 +37,7 @@ class Command(BaseCommand):
|
|
|
from IPython import start_ipython
|
|
|
start_ipython(argv=[])
|
|
|
|
|
|
- def ipython(self):
|
|
|
+ def ipython(self, options):
|
|
|
"""Start any version of IPython"""
|
|
|
for ip in (self._ipython, self._ipython_pre_100, self._ipython_pre_011):
|
|
|
try:
|
|
@@ -46,56 +49,55 @@ class Command(BaseCommand):
|
|
|
|
|
|
raise ImportError("No IPython")
|
|
|
|
|
|
- def bpython(self):
|
|
|
+ def bpython(self, options):
|
|
|
import bpython
|
|
|
bpython.embed()
|
|
|
|
|
|
- def run_shell(self, shell=None):
|
|
|
- available_shells = [shell] if shell else self.shells
|
|
|
+ def python(self, options):
|
|
|
+ import code
|
|
|
+
|
|
|
+
|
|
|
+ imported_objects = {}
|
|
|
+ try:
|
|
|
+ import readline
|
|
|
+ except ImportError:
|
|
|
+ pass
|
|
|
+ else:
|
|
|
+
|
|
|
+
|
|
|
+ import rlcompleter
|
|
|
+ readline.set_completer(rlcompleter.Completer(imported_objects).complete)
|
|
|
+ readline.parse_and_bind("tab:complete")
|
|
|
|
|
|
- for shell in available_shells:
|
|
|
- try:
|
|
|
- return getattr(self, shell)()
|
|
|
- except ImportError:
|
|
|
- pass
|
|
|
- raise ImportError
|
|
|
+
|
|
|
+
|
|
|
+ if not options['no_startup']:
|
|
|
+ for pythonrc in (os.environ.get("PYTHONSTARTUP"), '~/.pythonrc.py'):
|
|
|
+ if not pythonrc:
|
|
|
+ continue
|
|
|
+ pythonrc = os.path.expanduser(pythonrc)
|
|
|
+ if not os.path.isfile(pythonrc):
|
|
|
+ continue
|
|
|
+ try:
|
|
|
+ with open(pythonrc) as handle:
|
|
|
+ exec(compile(handle.read(), pythonrc, 'exec'), imported_objects)
|
|
|
+ except NameError:
|
|
|
+ pass
|
|
|
+ code.interact(local=imported_objects)
|
|
|
|
|
|
def handle(self, **options):
|
|
|
- try:
|
|
|
- if options['plain']:
|
|
|
-
|
|
|
- raise ImportError
|
|
|
+ if options['plain']:
|
|
|
+ warnings.warn(
|
|
|
+ "The --plain option is deprecated in favor of the -i python or --interface python option.",
|
|
|
+ RemovedInDjango20Warning
|
|
|
+ )
|
|
|
+ options['interface'] = 'python'
|
|
|
|
|
|
- self.run_shell(shell=options['interface'])
|
|
|
- except ImportError:
|
|
|
- import code
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
- imported_objects = {}
|
|
|
- try:
|
|
|
- import readline
|
|
|
+ available_shells = [options['interface']] if options['interface'] else self.shells
|
|
|
+
|
|
|
+ for shell in available_shells:
|
|
|
+ try:
|
|
|
+ return getattr(self, shell)(options)
|
|
|
except ImportError:
|
|
|
pass
|
|
|
- else:
|
|
|
-
|
|
|
-
|
|
|
- import rlcompleter
|
|
|
- readline.set_completer(rlcompleter.Completer(imported_objects).complete)
|
|
|
- readline.parse_and_bind("tab:complete")
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
- if not options['no_startup']:
|
|
|
- for pythonrc in (os.environ.get("PYTHONSTARTUP"), '~/.pythonrc.py'):
|
|
|
- if not pythonrc:
|
|
|
- continue
|
|
|
- pythonrc = os.path.expanduser(pythonrc)
|
|
|
- if not os.path.isfile(pythonrc):
|
|
|
- continue
|
|
|
- try:
|
|
|
- with open(pythonrc) as handle:
|
|
|
- exec(compile(handle.read(), pythonrc, 'exec'), imported_objects)
|
|
|
- except NameError:
|
|
|
- pass
|
|
|
- code.interact(local=imported_objects)
|
|
|
+ raise ImportError("Couldn't load any of the specified interfaces.")
|