From 47a5153da4216db4a4262047c513450a2a154d62 Mon Sep 17 00:00:00 2001 From: Jannis Leidel Date: Sun, 12 Dec 2010 23:03:03 +0000 Subject: [PATCH] Fixed #12735, #14892 and #11542 -- Fixed support for the latest IPython (development) version in the shell management command and added a hook to implement additional shell runners (by subclassing django.core.management.commands.shell.Command, extending the ``shells`` attribute and implement a method with the same name). git-svn-id: http://code.djangoproject.com/svn/django/trunk@14895 bcc190cf-cafb-0310-a4f2-bffc1f526a37 --- django/core/management/commands/shell.py | 33 +++++++++++++++++++----- 1 file changed, 27 insertions(+), 6 deletions(-) diff --git a/django/core/management/commands/shell.py b/django/core/management/commands/shell.py index 96169020e5c..f08de4e8928 100644 --- a/django/core/management/commands/shell.py +++ b/django/core/management/commands/shell.py @@ -8,9 +8,34 @@ class Command(NoArgsCommand): help='Tells Django to use plain Python, not IPython.'), ) help = "Runs a Python interactive interpreter. Tries to use IPython, if it's available." - + shells = ['ipython'] requires_model_validation = False + def ipython(self): + try: + from IPython.frontend.terminal.embed import TerminalInteractiveShell + shell = TerminalInteractiveShell() + shell.mainloop() + except ImportError: + # IPython < 0.11 + # Explicitly pass an empty list as arguments, because otherwise + # IPython would use sys.argv from this script. + try: + from IPython.Shell import IPShell + shell = IPShell(argv=[]) + shell.mainloop() + except ImportError: + # IPython not found at all, raise ImportError + raise + + def run_shell(self): + for shell in self.shells: + try: + return getattr(self, shell)() + except ImportError: + pass + raise ImportError + def handle_noargs(self, **options): # XXX: (Temporary) workaround for ticket #1796: force early loading of all # models from installed apps. @@ -23,11 +48,7 @@ class Command(NoArgsCommand): if use_plain: # Don't bother loading IPython, because the user wants plain Python. raise ImportError - import IPython - # Explicitly pass an empty list as arguments, because otherwise IPython - # would use sys.argv from this script. - shell = IPython.Shell.IPShell(argv=[]) - shell.mainloop() + self.run_shell() except ImportError: import code # Set up a dictionary to serve as the environment for the shell, so