##// END OF EJS Templates
use global events in js tests
r17324:226af0ea
Show More
interactiveshell.py
3274 lines | 130.4 KiB | text/x-python | PythonLexer
/ IPython / core / interactiveshell.py
Ville M. Vainio
crlf -> lf
r1032 # -*- coding: utf-8 -*-
Brian Granger
First draft of refactored Component->Configurable.
r2731 """Main IPython class."""
Ville M. Vainio
crlf -> lf
r1032
Brian Granger
Massive, crazy refactoring of everything....
r2202 #-----------------------------------------------------------------------------
# Copyright (C) 2001 Janko Hauser <jhauser@zscout.de>
# Copyright (C) 2001-2007 Fernando Perez. <fperez@colorado.edu>
Fernando Perez
Improve docs and comments of some internal tools, and of testing code
r3297 # Copyright (C) 2008-2011 The IPython Development Team
Ville M. Vainio
crlf -> lf
r1032 #
# Distributed under the terms of the BSD License. The full license is in
# the file COPYING, distributed as part of this software.
Brian Granger
Massive, crazy refactoring of everything....
r2202 #-----------------------------------------------------------------------------
MinRK
make InteractiveShell.banner a property
r16595 from __future__ import absolute_import, print_function
Brian Granger
Created context manager for the things injected into __builtin__.
r2227
Fernando Perez
Move object inspection machinery out of the magics code....
r2927 import __future__
Brian Granger
Finishing work on configurables, plugins and extensions.
r2738 import abc
Thomas Kluyver
Add methods to run an IPython cell based on AST nodes. Have done basic testing manually.
r3527 import ast
Fernando Perez
Fix bug where atexit operations were only done if readline was present.
r2953 import atexit
Thomas Kluyver
Declare ip.register_magic_function at class level so that it is included in docs
r12297 import functools
Ville M. Vainio
crlf -> lf
r1032 import os
import re
Bradley M. Froehle
Add '-m mod : run library module as a script' option....
r6029 import runpy
Ville M. Vainio
crlf -> lf
r1032 import sys
import tempfile
Thomas Kluyver
Clean up deprecated code: exceptions.Exception, new.instancemethod.
r3158 import types
Théophile Studer
Use default OS shell to run system commands...
r12217 import subprocess
MinRK
fix missing imports in core.interactiveshell...
r8372 from io import open as io_open
Ville M. Vainio
crlf -> lf
r1032
Brian Granger
Made InteractiveShell a SingletonConfigurable....
r3793 from IPython.config.configurable import SingletonConfigurable
Brian Granger
OInspect.py => core/oinspect.py and imports updated.
r2037 from IPython.core import debugger, oinspect
Fernando Perez
Add proper initialization of magics to main shell instance....
r6923 from IPython.core import magic
Fernando Perez
Get naked '?' to work, and in-spec with the new inputsplitter design.
r2876 from IPython.core import page
Brian Granger
Massive, crazy refactoring of everything....
r2202 from IPython.core import prefilter
Fernando Perez
First semi-complete support for -pylab and %pylab....
r2363 from IPython.core import shadowns
from IPython.core import ultratb
MinRK
short error message on AliasError in run_cell...
r3822 from IPython.core.alias import AliasManager, AliasError
Thomas Kluyver
Replace magic exit function with exit subclassing IPyAutocall. Credit to David Warde-Farley (@dwf) for tackling this issue.
r3721 from IPython.core.autocall import ExitAutocall
Brian Granger
Created context manager for the things injected into __builtin__.
r2227 from IPython.core.builtin_trap import BuiltinTrap
Thomas Kluyver
Rename callbacks -> events (mostly), fire -> trigger
r15605 from IPython.core.events import EventManager, available_events
Thomas Kluyver
Better support compiling cells with separate __future__ environments
r9140 from IPython.core.compilerop import CachingCompiler, check_linecache_ipython
Brian Granger
sys.displayhook is now managed dynamically by display_trap.
r2231 from IPython.core.display_trap import DisplayTrap
Fernando Perez
Improvements to exception handling to transport structured tracebacks....
r2838 from IPython.core.displayhook import DisplayHook
Brian Granger
Mostly final version of display data....
r3277 from IPython.core.displaypub import DisplayPublisher
Matthias BUSSONNIER
remove unused input according to pylint
r6776 from IPython.core.error import UsageError
Brian Granger
First draft of refactored Component->Configurable.
r2731 from IPython.core.extensions import ExtensionManager
Brian Granger
Display system is fully working now....
r3278 from IPython.core.formatters import DisplayFormatter
MinRK
merge interactiveshell.py
r3122 from IPython.core.history import HistoryManager
MinRK
define ESC_FOO consts only in inputsplitter...
r7437 from IPython.core.inputsplitter import IPythonInputSplitter, ESC_MAGIC, ESC_MAGIC2
Brian Granger
Logger.py => core/logger.py and updated imports.
r2032 from IPython.core.logger import Logger
Thomas Kluyver
Move _get_some_code method to InteractiveShell object; improve docstring.
r3509 from IPython.core.macro import Macro
Brian Granger
Fixing imports and syntax errors.
r2812 from IPython.core.payload import PayloadManager
MinRK
define ESC_FOO consts only in inputsplitter...
r7437 from IPython.core.prefilter import PrefilterManager
MinRK
move ipcluster create|list to `ipython profile create|list`...
r4024 from IPython.core.profiledir import ProfileDir
Thomas Kluyver
Refactor prompt handling into new prompt manager.
r5495 from IPython.core.prompts import PromptManager
MinRK
move banner to base InteractiveShell class
r16581 from IPython.core.usage import default_banner
Takafumi Arakaki
Make lib.latextools configurable...
r7861 from IPython.lib.latextools import LaTeXTool
Thomas Kluyver
Skip doctest that can't possibly work.
r9246 from IPython.testing.skipdoctest import skip_doctest
Brian Granger
Massive, crazy refactoring of everything....
r2202 from IPython.utils import PyColorize
Fernando Perez
Improvements to exception handling to transport structured tracebacks....
r2838 from IPython.utils import io
Thomas Kluyver
Start using py3compat module.
r4731 from IPython.utils import py3compat
Matthias BUSSONNIER
make pycat and loadpy aware of history and more...
r6761 from IPython.utils import openpy
Thomas Kluyver
Add way to mark classes & functions as undocumented.
r8793 from IPython.utils.decorators import undoc
Matthias BUSSONNIER
remove unused input according to pylint
r6776 from IPython.utils.io import ask_yes_no
Fernando Perez
First semi-complete support for -pylab and %pylab....
r2363 from IPython.utils.ipstruct import Struct
MinRK
add utils.path.ensure_dir_exists...
r16486 from IPython.utils.path import get_home_dir, get_ipython_dir, get_py_filename, unquote_filename, ensure_dir_exists
Thomas Kluyver
Initial conversion of history to SQLite database.
r3388 from IPython.utils.pickleshare import PickleShareDB
Fernando Perez
Fully refactored subprocess handling on all platforms....
r2908 from IPython.utils.process import system, getoutput
Thomas Kluyver
Fixes for metaclass syntax
r13359 from IPython.utils.py3compat import (builtin_mod, unicode_type, string_types,
Thomas Kluyver
Fix references to dict.iteritems and dict.itervalues
r13361 with_metaclass, iteritems)
Brian Granger
Work on startup related things....
r2252 from IPython.utils.strdispatch import StrDispatch
from IPython.utils.syspathcontext import prepended_to_syspath
Matthias BUSSONNIER
remove unused input according to pylint
r6776 from IPython.utils.text import (format_screen, LSString, SList,
Thomas Kluyver
Use DollarFormatter to fill in names in ! shell calls....
r5355 DollarFormatter)
MinRK
add Integer traitlet...
r5344 from IPython.utils.traitlets import (Integer, CBool, CaselessStrEnum, Enum,
Fernando Perez
Improvements to exception handling to transport structured tracebacks....
r2838 List, Unicode, Instance, Type)
Matthias BUSSONNIER
remove unused input according to pylint
r6776 from IPython.utils.warn import warn, error
Fernando Perez
Improvements to exception handling to transport structured tracebacks....
r2838 import IPython.core.hooks
Brian Granger
Massive, crazy refactoring of everything....
r2202
#-----------------------------------------------------------------------------
Ville M. Vainio
crlf -> lf
r1032 # Globals
Brian Granger
Massive, crazy refactoring of everything....
r2202 #-----------------------------------------------------------------------------
Ville M. Vainio
crlf -> lf
r1032 # compiled regexps for autoindent management
dedent_re = re.compile(r'^\s+raise|^\s+return|^\s+pass')
Brian Granger
Massive, crazy refactoring of everything....
r2202 #-----------------------------------------------------------------------------
# Utilities
#-----------------------------------------------------------------------------
Thomas Kluyver
Add way to mark classes & functions as undocumented.
r8793 @undoc
Ville M. Vainio
crlf -> lf
r1032 def softspace(file, newvalue):
"""Copied from code.py, to remove the dependency"""
oldvalue = 0
try:
oldvalue = file.softspace
except AttributeError:
pass
try:
file.softspace = newvalue
except (AttributeError, TypeError):
# "attribute-less object" or "read-only attributes"
pass
return oldvalue
Thomas Kluyver
Add way to mark classes & functions as undocumented.
r8793 @undoc
Fernando Perez
Better handling of no-readline.
r2377 def no_op(*a, **kw): pass
Thomas Kluyver
Add way to mark classes & functions as undocumented.
r8793 @undoc
epatters
BUG: Don't use readline in the ZMQShell....
r4816 class NoOpContext(object):
def __enter__(self): pass
def __exit__(self, type, value, traceback): pass
no_op_context = NoOpContext()
Thomas Kluyver
Clean up deprecated code: exceptions.Exception, new.instancemethod.
r3158 class SpaceInInput(Exception): pass
Ville M. Vainio
crlf -> lf
r1032
Thomas Kluyver
Add way to mark classes & functions as undocumented.
r8793 @undoc
Ville M. Vainio
crlf -> lf
r1032 class Bunch: pass
Brian Granger
Cleaned up embedded shell and added cleanup method to InteractiveShell....
r2226
Brian Granger
Make the default colors OS dependent.
r2319 def get_default_colors():
if sys.platform=='darwin':
return "LightBG"
elif os.name=='nt':
return 'Linux'
else:
return 'Linux'
Thomas Kluyver
Eliminate Str and CStr trait types except in IPython.parallel
r4046 class SeparateUnicode(Unicode):
Thomas Kluyver
Miscellaneous docs fixes
r13597 r"""A Unicode subclass to validate separate_in, separate_out, etc.
Brian Granger
Moved a few things back to InteractiveShell....
r2766
Thomas Kluyver
Miscellaneous docs fixes
r13597 This is a Unicode based trait that converts '0'->'' and ``'\\n'->'\n'``.
Brian Granger
Moved a few things back to InteractiveShell....
r2766 """
def validate(self, obj, value):
if value == '0': value = ''
value = value.replace('\\n','\n')
Thomas Kluyver
Eliminate Str and CStr trait types except in IPython.parallel
r4046 return super(SeparateUnicode, self).validate(obj, value)
Brian Granger
Moved a few things back to InteractiveShell....
r2766
Brian Granger
Made InteractiveShell a SingletonConfigurable....
r3793
Thomas Kluyver
Add context manager to reload readline history when leaving a block.
r3474 class ReadlineNoRecord(object):
"""Context manager to execute some code, then reload readline history
so that interactive input to the code doesn't appear when pressing up."""
def __init__(self, shell):
self.shell = shell
self._nested_level = 0
Bernardo B. Marques
remove all trailling spaces
r4872
Thomas Kluyver
Add context manager to reload readline history when leaving a block.
r3474 def __enter__(self):
Thomas Kluyver
Only refill readline history if it doesn't look like it's been changed.
r3481 if self._nested_level == 0:
Thomas Kluyver
Catch errors in querying readline which occur with pyreadline.
r3760 try:
self.orig_length = self.current_length()
self.readline_tail = self.get_readline_tail()
except (AttributeError, IndexError): # Can fail with pyreadline
self.orig_length, self.readline_tail = 999999, []
Thomas Kluyver
Add context manager to reload readline history when leaving a block.
r3474 self._nested_level += 1
Bernardo B. Marques
remove all trailling spaces
r4872
Thomas Kluyver
Add context manager to reload readline history when leaving a block.
r3474 def __exit__(self, type, value, traceback):
self._nested_level -= 1
if self._nested_level == 0:
Thomas Kluyver
Improve readline resetter mechanism.
r3496 # Try clipping the end if it's got longer
Thomas Kluyver
Catch errors in querying readline which occur with pyreadline.
r3760 try:
e = self.current_length() - self.orig_length
if e > 0:
for _ in range(e):
self.shell.readline.remove_history_item(self.orig_length)
Bernardo B. Marques
remove all trailling spaces
r4872
Thomas Kluyver
Catch errors in querying readline which occur with pyreadline.
r3760 # If it still doesn't match, just reload readline history.
if self.current_length() != self.orig_length \
or self.get_readline_tail() != self.readline_tail:
self.shell.refill_readline_hist()
except (AttributeError, IndexError):
pass
Thomas Kluyver
Add context manager to reload readline history when leaving a block.
r3474 # Returning False will cause exceptions to propagate
return False
Bernardo B. Marques
remove all trailling spaces
r4872
Thomas Kluyver
Improve readline resetter mechanism.
r3496 def current_length(self):
return self.shell.readline.get_current_history_length()
Bernardo B. Marques
remove all trailling spaces
r4872
Thomas Kluyver
Only refill readline history if it doesn't look like it's been changed.
r3481 def get_readline_tail(self, n=10):
"""Get the last n items in readline history."""
end = self.shell.readline.get_current_history_length() + 1
start = max(end-n, 1)
ghi = self.shell.readline.get_history_item
return [ghi(x) for x in range(start, end)]
Brian Granger
Fixes to docs and InteractiveShell.instance()...
r2799
Mike McKerns
moved DummyMod to proper namespace to enable pickling
r12470
Mike McKerns
added undoc and made DummyMod doc more reflective of context
r12491 @undoc
Mike McKerns
moved DummyMod to proper namespace to enable pickling
r12470 class DummyMod(object):
Mike McKerns
added undoc and made DummyMod doc more reflective of context
r12491 """A dummy module used for IPython's interactive module when
a namespace must be assigned to the module's __dict__."""
Mike McKerns
moved DummyMod to proper namespace to enable pickling
r12470 pass
Brian Granger
Massive, crazy refactoring of everything....
r2202 #-----------------------------------------------------------------------------
Ville M. Vainio
crlf -> lf
r1032 # Main IPython class
Brian Granger
Massive, crazy refactoring of everything....
r2202 #-----------------------------------------------------------------------------
Ville M. Vainio
crlf -> lf
r1032
Fernando Perez
First full decoupling of magics into a standalone object.
r6906 class InteractiveShell(SingletonConfigurable):
Brian Granger
Cleaned up embedded shell and added cleanup method to InteractiveShell....
r2226 """An enhanced, interactive shell for Python."""
Ville M. Vainio
crlf -> lf
r1032
Brian Granger
Finished fixing InteractiveShell.instance().
r2802 _instance = None
Thomas Kluyver
Add framework for AST transformations of input code.
r8220
ast_transformers = List([], config=True, help=
"""
A list of ast.NodeTransformer subclass instances, which will be applied
to user input before code is run.
"""
)
Brian Granger
Started to move config docs to objects.
r3788
Fernando Perez
Disable autocall by default, after feedback on the mailing list....
r5624 autocall = Enum((0,1,2), default_value=0, config=True, help=
Brian Granger
Started to move config docs to objects.
r3788 """
Make IPython automatically call any callable object even if you didn't
type explicit parentheses. For example, 'str 43' becomes 'str(43)'
automatically. The value can be '0' to disable the feature, '1' for
'smart' autocall, where it is not applied if there are no more
Brian Granger
Starting help in InteractiveShell.
r3787 arguments on the line, and '2' for 'full' autocall, where all callable
objects are automatically called (even if no arguments are present).
Brian Granger
Started to move config docs to objects.
r3788 """
Brian Granger
Starting help in InteractiveShell.
r3787 )
Brian Granger
Moved a few things back to InteractiveShell....
r2766 # TODO: remove all autoindent logic and put into frontends.
# We can't do this yet because even runlines uses the autoindent.
Brian Granger
Started to move config docs to objects.
r3788 autoindent = CBool(True, config=True, help=
"""
Brian Granger
Ongoing work on the config system....
r3789 Autoindent IPython code entered interactively.
Brian Granger
Started to move config docs to objects.
r3788 """
)
automagic = CBool(True, config=True, help=
"""
Enable magic commands to be called without the leading %.
"""
)
MinRK
move banner to base InteractiveShell class
r16581
banner = Unicode('')
banner1 = Unicode(default_banner, config=True,
help="""The part of the banner to be printed before the profile"""
)
banner2 = Unicode('', config=True,
help="""The part of the banner to be printed after the profile"""
)
MinRK
add Integer traitlet...
r5344 cache_size = Integer(1000, config=True, help=
Brian Granger
Ongoing work on the config system....
r3789 """
Set the size of the output cache. The default is 1000, you can
change it permanently in your config file. Setting it to 0 completely
disables the caching system, and the minimum value accepted is 20 (if
you provide a value less than 20, it is reset to 0 and a warning is
issued). This limit is defined because otherwise you'll spend more
time re-flushing a too small cache than working
"""
)
color_info = CBool(True, config=True, help=
"""
Use colors for displaying information about objects. Because this
information is passed through a pager (like 'less'), and some pagers
get confused with color codes, this capability can be turned off.
"""
)
Bernardo B. Marques
remove all trailling spaces
r4872 colors = CaselessStrEnum(('NoColor','LightBG','Linux'),
MinRK
Terminal IPython working with newapp
r3963 default_value=get_default_colors(), config=True,
MinRK
minor helpstring cleanup per review.
r3967 help="Set the color scheme (NoColor, Linux, or LightBG)."
MinRK
Terminal IPython working with newapp
r3963 )
epatters
BUG: Don't use readline in the ZMQShell....
r4816 colors_force = CBool(False, help=
"""
Force use of ANSI color codes, regardless of OS and readline
availability.
"""
# FIXME: This is essentially a hack to allow ZMQShell to show colors
# without readline on Win32. When the ZMQ formatting system is
# refactored, this should be removed.
)
Brian Granger
Massive refactoring of of the core....
r2245 debug = CBool(False, config=True)
Brian Granger
Ongoing work on the config system....
r3789 deep_reload = CBool(False, config=True, help=
"""
Enable deep (recursive) reloading by default. IPython can use the
deep_reload module which reloads changes in modules recursively (it
replaces the reload() function, so you don't need to change anything to
use it). deep_reload() forces a full reload of modules whose code may
have changed, which the default reload() function does not. When
deep_reload is off, IPython will use the normal reload(), but
deep_reload will still be available as dreload().
"""
)
MinRK
Don't unregister failing post-exec callbacks automatically...
r5734 disable_failing_post_execute = CBool(False, config=True,
Takafumi Arakaki
Remove suspicious quotes in interactiveshell.py
r7363 help="Don't call post-execute functions that have failed in the past."
MinRK
Don't unregister failing post-exec callbacks automatically...
r5734 )
Brian Granger
Display system is fully working now....
r3278 display_formatter = Instance(DisplayFormatter)
Brian Granger
Initial support in ipkernel for proper displayhook handling.
r2786 displayhook_class = Type(DisplayHook)
Brian Granger
Mostly final version of display data....
r3277 display_pub_class = Type(DisplayPublisher)
MinRK
add data_pub messages...
r8102 data_pub_class = None
Brian Granger
Mostly final version of display data....
r3277
Fernando Perez
Implement exit/quit/Exit/Quit recognition....
r2950 exit_now = CBool(False)
Thomas Kluyver
Subclass exit autocallable for two process shells, with argument to keep kernel alive.
r3724 exiter = Instance(ExitAutocall)
def _exiter_default(self):
return ExitAutocall(self)
Fernando Perez
Small fixes in response to code review for gh-163.
r3136 # Monotonically increasing execution counter
MinRK
add Integer traitlet...
r5344 execution_count = Integer(1)
MinRK
fix at least some command-line unicode options
r3464 filename = Unicode("<ipython console>")
Brian Granger
Lots of work on command line options and env vars....
r2322 ipython_dir= Unicode('', config=True) # Set to get_ipython_dir() in __init__
Fernando Perez
Initialize input_splitter automatically via traitlets mechanism.
r3049
Thomas Kluyver
Separate InteractiveShell.input_splitter into two instances....
r10254 # Input splitter, to transform input line by line and detect when a block
# is ready to be executed.
Fernando Perez
Initialize input_splitter automatically via traitlets mechanism.
r3049 input_splitter = Instance('IPython.core.inputsplitter.IPythonInputSplitter',
Thomas Kluyver
Separate InteractiveShell.input_splitter into two instances....
r10254 (), {'line_input_checker': True})
# This InputSplitter instance is used to transform completed cells before
# running them. It allows cell magics to contain blank lines.
input_transformer_manager = Instance('IPython.core.inputsplitter.IPythonInputSplitter',
(), {'line_input_checker': False})
Brian Granger
Ongoing work on the config system....
r3789 logstart = CBool(False, config=True, help=
"""
Start logging to the default log file.
"""
)
logfile = Unicode('', config=True, help=
"""
The name of the logfile to use.
"""
)
logappend = Unicode('', config=True, help=
"""
Start logging to the given file in append mode.
"""
)
Brian Granger
More work on InteractiveShell and ipmaker. It works!
r2204 object_info_string_level = Enum((0,1,2), default_value=0,
Brian Granger
Massive refactoring of of the core....
r2245 config=True)
Brian Granger
Ongoing work on the config system....
r3789 pdb = CBool(False, config=True, help=
"""
Automatically call the pdb debugger after every exception.
"""
)
Fernando Perez
Make multiline history default be platform dep (false on Win32).
r5096 multiline_history = CBool(sys.platform != 'win32', config=True,
Julian Taylor
update docstring for multiline_history
r5178 help="Save multi-line entries as one entry in readline history"
Julian Taylor
reenable multiline history for terminals...
r5011 )
Fernando Perez
Add support for simultaneous interactive and inline matplotlib plots....
r2987
MinRK
PromptManager fixes...
r5548 # deprecated prompt traits:
prompt_in1 = Unicode('In [\\#]: ', config=True,
help="Deprecated, use PromptManager.in_template")
prompt_in2 = Unicode(' .\\D.: ', config=True,
help="Deprecated, use PromptManager.in2_template")
prompt_out = Unicode('Out[\\#]: ', config=True,
help="Deprecated, use PromptManager.out_template")
prompts_pad_left = CBool(True, config=True,
help="Deprecated, use PromptManager.justify")
def _prompt_trait_changed(self, name, old, new):
table = {
'prompt_in1' : 'in_template',
'prompt_in2' : 'in2_template',
'prompt_out' : 'out_template',
'prompts_pad_left' : 'justify',
}
Thomas Kluyver
Fix IPython.utils.warn API so messages are automatically displayed followed by a newline.
r8223 warn("InteractiveShell.{name} is deprecated, use PromptManager.{newname}".format(
MinRK
PromptManager fixes...
r5548 name=name, newname=table[name])
)
# protect against weird cases where self.config may not exist:
if self.config is not None:
# propagate to corresponding PromptManager trait
setattr(self.config.PromptManager, table[name], new)
_prompt_in1_changed = _prompt_trait_changed
_prompt_in2_changed = _prompt_trait_changed
_prompt_out_changed = _prompt_trait_changed
_prompt_pad_left_changed = _prompt_trait_changed
Thomas Kluyver
Make rewrite prompt non-configurable.
r5555 show_rewritten_input = CBool(True, config=True,
help="Show rewritten input, e.g. for autocall."
)
Brian Granger
Massive refactoring of of the core....
r2245 quiet = CBool(False, config=True)
MinRK
add Integer traitlet...
r5344 history_length = Integer(10000, config=True)
Bernardo B. Marques
remove all trailling spaces
r4872
Brian Granger
Complete reorganization of InteractiveShell....
r2761 # The readline stuff will eventually be moved to the terminal subclass
# but for now, we can't do that as readline is welded in everywhere.
Brian Granger
Massive refactoring of of the core....
r2245 readline_use = CBool(True, config=True)
Thomas Kluyver
Eliminate Str and CStr trait types except in IPython.parallel
r4046 readline_remove_delims = Unicode('-/~', config=True)
Thomas Kluyver
Reset readline delimiters after loading rmagic....
r9017 readline_delims = Unicode() # set by init_readline()
MinRK
Remove "\M-" readline bindings...
r3842 # don't use \M- bindings by default, because they
# conflict with 8-bit encodings. See gh-58,gh-88
Brian Granger
More work on InteractiveShell and ipmaker. It works!
r2204 readline_parse_and_bind = List([
'tab: complete',
Fernando Perez
Set Control-L to clear the screen when readline supports it....
r2567 '"\C-l": clear-screen',
Brian Granger
More work on InteractiveShell and ipmaker. It works!
r2204 'set show-all-if-ambiguous on',
'"\C-o": tab-insert',
'"\C-r": reverse-search-history',
'"\C-s": forward-search-history',
'"\C-p": history-search-backward',
'"\C-n": history-search-forward',
'"\e[A": history-search-backward',
'"\e[B": history-search-forward',
'"\C-k": kill-line',
'"\C-u": unix-line-discard',
MinRK
load inputrc after IPython readline config...
r16811 ], config=True)
_custom_readline_config = False
def _readline_parse_and_bind_changed(self, name, old, new):
# notice that readline config is customized
# indicates that it should have higher priority than inputrc
self._custom_readline_config = True
Mike Hansen
Make ast_node_interactivity trait an Enum instead of Unicode
r7034 ast_node_interactivity = Enum(['all', 'last', 'last_expr', 'none'],
default_value='last_expr', config=True,
help="""
Takafumi Arakaki
Fix help string for InteractiveShell.ast_node_interactivity...
r7550 'all', 'last', 'last_expr' or 'none', specifying which nodes should be
Mike Hansen
Make ast_node_interactivity trait an Enum instead of Unicode
r7034 run interactively (displaying output from expressions).""")
Mike Hansen
Make default value of interactivity passed to run_ast_nodes configurable
r7033
Brian Granger
Moved a few things back to InteractiveShell....
r2766 # TODO: this part of prompt management should be moved to the frontends.
# Use custom TraitTypes that convert '0'->'' and '\\n'->'\n'
Thomas Kluyver
Eliminate Str and CStr trait types except in IPython.parallel
r4046 separate_in = SeparateUnicode('\n', config=True)
separate_out = SeparateUnicode('', config=True)
separate_out2 = SeparateUnicode('', config=True)
Brian Granger
Massive refactoring of of the core....
r2245 wildcards_case_sensitive = CBool(True, config=True)
Bernardo B. Marques
remove all trailling spaces
r4872 xmode = CaselessStrEnum(('Context','Plain', 'Verbose'),
Brian Granger
Massive refactoring of of the core....
r2245 default_value='Context', config=True)
Brian Granger
More work on InteractiveShell and ipmaker. It works!
r2204
Brian Granger
First draft of refactored Component->Configurable.
r2731 # Subcomponents of InteractiveShell
alias_manager = Instance('IPython.core.alias.AliasManager')
prefilter_manager = Instance('IPython.core.prefilter.PrefilterManager')
builtin_trap = Instance('IPython.core.builtin_trap.BuiltinTrap')
display_trap = Instance('IPython.core.display_trap.DisplayTrap')
extension_manager = Instance('IPython.core.extensions.ExtensionManager')
Brian Granger
Fixing imports and syntax errors.
r2812 payload_manager = Instance('IPython.core.payload.PayloadManager')
MinRK
merge interactiveshell.py
r3122 history_manager = Instance('IPython.core.history.HistoryManager')
Fernando Perez
Major restructuring of magics, breaking them up into separate classes....
r6917 magics_manager = Instance('IPython.core.magic.MagicsManager')
Brian Granger
First draft of refactored Component->Configurable.
r2731
MinRK
rename core.newapplication -> core.application
r4023 profile_dir = Instance('IPython.core.application.ProfileDir')
MinRK
Terminal IPython working with newapp
r3963 @property
def profile(self):
if self.profile_dir is not None:
name = os.path.basename(self.profile_dir.location)
return name.replace('profile_','')
Fernando Perez
Add support for simultaneous interactive and inline matplotlib plots....
r2987 # Private interface
Fernando Perez
Make post-execution happen at the cell instead of the block level....
r3732 _post_execute = Instance(dict)
Fernando Perez
Add support for simultaneous interactive and inline matplotlib plots....
r2987
Ryan May
Implement bare %pylab switching back to appropriate GUI.
r7965 # Tracks any GUI loop loaded for pylab
pylab_gui_select = None
MinRK
use `parent=self` throughout IPython...
r11064 def __init__(self, ipython_dir=None, profile_dir=None,
Thomas Kluyver
Rename user_local_ns back to user_ns for simplicity.
r5453 user_module=None, user_ns=None,
MinRK
add manager and client as trait lets of ZMQInteractiveShell...
r10331 custom_exceptions=((), None), **kwargs):
Ville M. Vainio
crlf -> lf
r1032
Dav Clark
Final changes traitlet -> trait for review
r2385 # This is where traits with a config_key argument are updated
Brian Granger
More work on getting rid of ipmaker.
r2203 # from the values on config.
MinRK
use `parent=self` throughout IPython...
r11064 super(InteractiveShell, self).__init__(**kwargs)
MinRK
add %config magic for configuring IPython
r5225 self.configurables = [self]
Ville M. Vainio
crlf -> lf
r1032
Brian Granger
Cleaned up embedded shell and added cleanup method to InteractiveShell....
r2226 # These are relatively independent and stateless
Brian Granger
Lots of work on command line options and env vars....
r2322 self.init_ipython_dir(ipython_dir)
MinRK
Terminal IPython working with newapp
r3963 self.init_profile_dir(profile_dir)
Brian Granger
Massive, crazy refactoring of everything....
r2202 self.init_instance_attrs()
Fernando Perez
Add init_environment(), %less, %more, %man and %clear/%cls, in zmq shell....
r3005 self.init_environment()
Thomas Kluyver
Add simple support for running inside a virtualenv.
r6085
# Check if we're in a virtualenv, and set up sys.path.
self.init_virtualenv()
Brian Granger
Cleaned up embedded shell and added cleanup method to InteractiveShell....
r2226
Brian Granger
Massive refactoring of of the core....
r2245 # Create namespaces (user_ns, user_global_ns, etc.)
Thomas Kluyver
Rename user_local_ns back to user_ns for simplicity.
r5453 self.init_create_namespaces(user_module, user_ns)
Brian Granger
Cleaned up embedded shell and added cleanup method to InteractiveShell....
r2226 # This has to be done after init_create_namespaces because it uses
# something in self.user_ns, but before init_sys_modules, which
# is the first thing to modify sys.
Brian Granger
Moved init_io and init_traceback_handlers after readline_init.
r2804 # TODO: When we override sys.stdout and sys.stderr before this class
# is created, we are saving the overridden ones here. Not sure if this
# is what we want to do.
Brian Granger
Cleaned up embedded shell and added cleanup method to InteractiveShell....
r2226 self.save_sys_module_state()
self.init_sys_modules()
Bernardo B. Marques
remove all trailling spaces
r4872
Thomas Kluyver
Initial conversion of history to SQLite database.
r3388 # While we're trying to have each part of the code directly access what
# it needs without keeping redundant references to objects, we have too
# much legacy code that expects ip.db to exist.
MinRK
Terminal IPython working with newapp
r3963 self.db = PickleShareDB(os.path.join(self.profile_dir.location, 'db'))
Brian Granger
Cleaned up embedded shell and added cleanup method to InteractiveShell....
r2226
Brian Granger
Massive, crazy refactoring of everything....
r2202 self.init_history()
self.init_encoding()
Brian Granger
More work on refactoring things into components....
r2244 self.init_prefilter()
Ville M. Vainio
crlf -> lf
r1032
Brian Granger
Massive, crazy refactoring of everything....
r2202 self.init_syntax_highlighting()
self.init_hooks()
Thomas Kluyver
Rename callbacks -> events (mostly), fire -> trigger
r15605 self.init_events()
Brian Granger
Massive, crazy refactoring of everything....
r2202 self.init_pushd_popd_magic()
Brian Granger
Moved init_io and init_traceback_handlers after readline_init.
r2804 # self.init_traceback_handlers use to be here, but we moved it below
# because it and init_io have to come after init_readline.
Brian Granger
Cleaned up embedded shell and added cleanup method to InteractiveShell....
r2226 self.init_user_ns()
Brian Granger
Massive, crazy refactoring of everything....
r2202 self.init_logger()
self.init_builtins()
Brian Granger
Reenabling output trapping in the kernel.
r2767
Brian Granger
More work on getting rid of ipmaker.
r2203 # The following was in post_config_initialization
self.init_inspector()
Brian Granger
Moved init_io and init_traceback_handlers after readline_init.
r2804 # init_readline() must come before init_io(), because init_io uses
# readline related things.
Brian Granger
More work on getting rid of ipmaker.
r2203 self.init_readline()
Thomas Kluyver
Defer saving raw_input to shell initialisation, so that we pick up the modified version needed for PyPy's readline to work.
r4662 # We save this here in case user code replaces raw_input, but it needs
# to be after init_readline(), because PyPy's readline works by replacing
# raw_input.
Thomas Kluyver
Small changes towards supporting Python 3.
r4753 if py3compat.PY3:
self.raw_input_original = input
else:
self.raw_input_original = raw_input
Fernando Perez
Reorganization of readline and completion dependent code....
r2956 # init_completer must come after init_readline, because it needs to
# know whether readline is present or not system-wide to configure the
# completers, since the completion machinery can now operate
# independently of readline (e.g. over the network)
self.init_completer()
Brian Granger
Moved init_io and init_traceback_handlers after readline_init.
r2804 # TODO: init_io() needs to happen before init_traceback handlers
# because the traceback handlers hardcode the stdout/stderr streams.
# This logic in in debugger.Pdb and should eventually be changed.
self.init_io()
self.init_traceback_handlers(custom_exceptions)
Brian Granger
More work on getting rid of ipmaker.
r2203 self.init_prompts()
Brian Granger
Display system is fully working now....
r3278 self.init_display_formatter()
Brian Granger
Mostly final version of display data....
r3277 self.init_display_pub()
MinRK
add data_pub messages...
r8102 self.init_data_pub()
Brian Granger
More work on getting rid of ipmaker.
r2203 self.init_displayhook()
Takafumi Arakaki
Make lib.latextools configurable...
r7861 self.init_latextool()
Brian Granger
More work on getting rid of ipmaker.
r2203 self.init_magics()
Thomas Kluyver
Initial changes to make alias system use magics
r12595 self.init_alias()
Rui Pereira
Fix logging on interactive shell....
r7819 self.init_logstart()
Brian Granger
More work on getting rid of ipmaker.
r2203 self.init_pdb()
Brian Granger
First draft of refactored Component->Configurable.
r2731 self.init_extension_manager()
Brian Granger
Final attempt to fix init_io logic.
r2810 self.init_payload()
MinRK
s/init_widgets/init_comms
r13218 self.init_comms()
Brian Granger
More work on getting rid of ipmaker.
r2203 self.hooks.late_startup_hook()
Thomas Kluyver
Use silly American spelling for initialised
r15612 self.events.trigger('shell_initialized', self)
Fernando Perez
Fix bug where atexit operations were only done if readline was present.
r2953 atexit.register(self.atexit_operations)
Brian Granger
More work on getting rid of ipmaker.
r2203
Brian Granger
Massive refactoring of of the core....
r2245 def get_ipython(self):
Fernando Perez
A few small fixes so ipythonx works, and PEP-8 cleanups I found along the way.
r2400 """Return the currently running IPython instance."""
Brian Granger
Massive refactoring of of the core....
r2245 return self
Brian Granger
More work on getting rid of ipmaker.
r2203 #-------------------------------------------------------------------------
Dav Clark
Final changes traitlet -> trait for review
r2385 # Trait changed handlers
Brian Granger
More work on getting rid of ipmaker.
r2203 #-------------------------------------------------------------------------
Brian Granger
Lots of work on command line options and env vars....
r2322 def _ipython_dir_changed(self, name, new):
MinRK
add utils.path.ensure_dir_exists...
r16486 ensure_dir_exists(new)
Brian Granger
Massive refactoring of of the core....
r2245
Brian Granger
More re-organization of InteractiveShell.
r2242 def set_autoindent(self,value=None):
"""Set the autoindent flag, checking for readline support.
If called with no arguments, it acts as a toggle."""
MinRK
avoid missing readline warning in zmqshell...
r4828 if value != 0 and not self.has_readline:
Brian Granger
More re-organization of InteractiveShell.
r2242 if os.name == 'posix':
warn("The auto-indent feature requires the readline library")
self.autoindent = 0
return
if value is None:
self.autoindent = not self.autoindent
else:
self.autoindent = value
Brian Granger
More work on getting rid of ipmaker.
r2203 #-------------------------------------------------------------------------
# init_* methods called by __init__
#-------------------------------------------------------------------------
Brian Granger
Massive, crazy refactoring of everything....
r2202
Brian Granger
Lots of work on command line options and env vars....
r2322 def init_ipython_dir(self, ipython_dir):
if ipython_dir is not None:
self.ipython_dir = ipython_dir
Brian Granger
Minor work on how ipythondir is handled.
r2223 return
MinRK
Terminal IPython working with newapp
r3963 self.ipython_dir = get_ipython_dir()
Brian Granger
Cleaned up embedded shell and added cleanup method to InteractiveShell....
r2226
MinRK
Terminal IPython working with newapp
r3963 def init_profile_dir(self, profile_dir):
if profile_dir is not None:
self.profile_dir = profile_dir
return
self.profile_dir =\
ProfileDir.create_profile_dir_by_name(self.ipython_dir, 'default')
Brian Granger
Minor work on how ipythondir is handled.
r2223
Brian Granger
Massive, crazy refactoring of everything....
r2202 def init_instance_attrs(self):
self.more = False
Ville M. Vainio
crlf -> lf
r1032
# command compiler
Fernando Perez
Using R. Kern's code to try to get better tracebacks....
r3172 self.compile = CachingCompiler()
Ville M. Vainio
crlf -> lf
r1032
# Make an empty namespace, which extension writers can rely on both
# existing and NEVER being used by ipython itself. This gives them a
# convenient location for storing additional information and state
# their extensions may require, without fear of collisions with other
# ipython names that may develop later.
self.meta = Struct()
Brian Granger
Massive, crazy refactoring of everything....
r2202 # Temporary files used for various purposes. Deleted at exit.
self.tempfiles = []
Matthias BUSSONNIER
avoid import of nearby temporary with %edit...
r14683 self.tempdirs = []
Brian Granger
Massive, crazy refactoring of everything....
r2202
# Keep track of readline usage (later set by init_readline)
self.has_readline = False
# keep track of where we started running (mainly for crash post-mortem)
# This is not being used anywhere currently.
Thomas Kluyver
Python 3 compatibility for os.getcwdu()
r13447 self.starting_dir = py3compat.getcwd()
Brian Granger
Massive, crazy refactoring of everything....
r2202
# Indentation management
self.indent_current_nsp = 0
Fernando Perez
Make post-execution happen at the cell instead of the block level....
r3732 # Dict to track post-execution functions that have been registered
self._post_execute = {}
Fernando Perez
Add init_environment(), %less, %more, %man and %clear/%cls, in zmq shell....
r3005 def init_environment(self):
"""Any changes we need to make to the user's environment."""
pass
Brian Granger
More re-organization of InteractiveShell.
r2242 def init_encoding(self):
# Get system encoding at startup time. Certain terminals (like Emacs
# under Win32 have it set to None, and we need to have a known valid
# encoding to use in the raw_input() method
try:
self.stdin_encoding = sys.stdin.encoding or 'ascii'
except AttributeError:
self.stdin_encoding = 'ascii'
Ville M. Vainio
crlf -> lf
r1032
Brian Granger
More re-organization of InteractiveShell.
r2242 def init_syntax_highlighting(self):
# Python source parser/formatter for syntax highlighting
pyformat = PyColorize.Parser().format
self.pycolorize = lambda src: pyformat(src,'str',self.colors)
Ville M. Vainio
crlf -> lf
r1032
Brian Granger
More re-organization of InteractiveShell.
r2242 def init_pushd_popd_magic(self):
# for pushd/popd management
MinRK
allow IPython to run without writable home dir...
r5384 self.home_dir = get_home_dir()
Ville M. Vainio
crlf -> lf
r1032
Brian Granger
More re-organization of InteractiveShell.
r2242 self.dir_stack = []
Robert Kern
ENH: Allow non-dict namespaces. This involves a change in the ipapi for setting user namespaces.
r1419
Brian Granger
More re-organization of InteractiveShell.
r2242 def init_logger(self):
MinRK
merge interactiveshell.py
r3122 self.logger = Logger(self.home_dir, logfname='ipython_log.py',
logmode='rotate')
Fernando Perez
Fix https://bugs.launchpad.net/ipython/+bug/239054...
r1859
Brian Granger
More re-organization of InteractiveShell.
r2242 def init_logstart(self):
MinRK
merge interactiveshell.py
r3122 """Initialize logging in case it was requested at the command line.
"""
Brian Granger
Minor changes to make sure logging is working well....
r2265 if self.logappend:
Fernando Perez
First full decoupling of magics into a standalone object.
r6906 self.magic('logstart %s append' % self.logappend)
Brian Granger
Work on startup related things....
r2252 elif self.logfile:
Rui Pereira
Fix logging on interactive shell....
r7819 self.magic('logstart %s' % self.logfile)
Brian Granger
More re-organization of InteractiveShell.
r2242 elif self.logstart:
Fernando Perez
First full decoupling of magics into a standalone object.
r6906 self.magic('logstart')
Fernando Perez
Fix https://bugs.launchpad.net/ipython/+bug/239054...
r1859
Brian Granger
More re-organization of InteractiveShell.
r2242 def init_builtins(self):
Fernando Perez
Deprecate __IPYTHON__active for simply __IPYTHON__
r5492 # A single, static flag that we set to True. Its presence indicates
# that an IPython shell has been created, and we make no attempts at
# removing on exit or representing the existence of more than one
# IPython at a time.
builtin_mod.__dict__['__IPYTHON__'] = True
# In 0.11 we introduced '__IPYTHON__active' as an integer we'd try to
# manage on enter/exit, but with all our shells it's virtually
# impossible to get all the cases right. We're leaving the name in for
# those who adapted their codes to check for this flag, but will
# eventually remove it after a few more releases.
builtin_mod.__dict__['__IPYTHON__active'] = \
'Deprecated, check for __IPYTHON__'
Brian Granger
Adding support for HasTraits to take keyword arguments.
r2740 self.builtin_trap = BuiltinTrap(shell=self)
Ville M. Vainio
crlf -> lf
r1032
Brian Granger
More re-organization of InteractiveShell.
r2242 def init_inspector(self):
# Object inspector
self.inspector = oinspect.Inspector(oinspect.InspectColors,
PyColorize.ANSICodeColors,
'NoColor',
self.object_info_string_level)
Ville M. Vainio
crlf -> lf
r1032
Brian Granger
Changing how IPython.utils.io.Term is handled....
r2775 def init_io(self):
Fernando Perez
Fixed broken coloring on Windows....
r2974 # This will just use sys.stdout and sys.stderr. If you want to
# override sys.stdout and sys.stderr themselves, you need to do that
Bernardo B. Marques
remove all trailling spaces
r4872 # *before* instantiating this class, because io holds onto
Fernando Perez
Fixed broken coloring on Windows....
r2974 # references to the underlying streams.
Pawel Jasinski
color is supported in ironpython
r8573 if (sys.platform == 'win32' or sys.platform == 'cli') and self.has_readline:
MinRK
io.Term.cin/out/err replaced by io.stdin/out/err...
r3800 io.stdout = io.stderr = io.IOStream(self.readline._outputfile)
Brian Granger
Changing how IPython.utils.io.Term is handled....
r2775 else:
MinRK
io.Term.cin/out/err replaced by io.stdin/out/err...
r3800 io.stdout = io.IOStream(sys.stdout)
io.stderr = io.IOStream(sys.stderr)
Brian Granger
Changing how IPython.utils.io.Term is handled....
r2775
Brian Granger
More re-organization of InteractiveShell.
r2242 def init_prompts(self):
MinRK
use `parent=self` throughout IPython...
r11064 self.prompt_manager = PromptManager(shell=self, parent=self)
Thomas Kluyver
Make prompts configurable at runtime.
r5511 self.configurables.append(self.prompt_manager)
Bradley M. Froehle
Define generic sys.ps{1,2,3}, for use by scripts....
r6749 # Set system prompts, so that scripts can decide if they are running
# interactively.
sys.ps1 = 'In : '
sys.ps2 = '...: '
sys.ps3 = 'Out: '
Brian Granger
Refactor of prompts and the displayhook....
r2781
Brian Granger
Display system is fully working now....
r3278 def init_display_formatter(self):
MinRK
use `parent=self` throughout IPython...
r11064 self.display_formatter = DisplayFormatter(parent=self)
MinRK
add %config magic for configuring IPython
r5225 self.configurables.append(self.display_formatter)
Brian Granger
Display system is fully working now....
r3278
Brian Granger
Mostly final version of display data....
r3277 def init_display_pub(self):
MinRK
use `parent=self` throughout IPython...
r11064 self.display_pub = self.display_pub_class(parent=self)
MinRK
add %config magic for configuring IPython
r5225 self.configurables.append(self.display_pub)
Brian Granger
Mostly final version of display data....
r3277
MinRK
add data_pub messages...
r8102 def init_data_pub(self):
if not self.data_pub_class:
self.data_pub = None
return
MinRK
use `parent=self` throughout IPython...
r11064 self.data_pub = self.data_pub_class(parent=self)
MinRK
add data_pub messages...
r8102 self.configurables.append(self.data_pub)
Brian Granger
Refactor of prompts and the displayhook....
r2781 def init_displayhook(self):
# Initialize displayhook, set in/out prompts and printing system
Brian Granger
Initial support in ipkernel for proper displayhook handling.
r2786 self.displayhook = self.displayhook_class(
MinRK
use `parent=self` throughout IPython...
r11064 parent=self,
Brian Granger
Initial support in ipkernel for proper displayhook handling.
r2786 shell=self,
cache_size=self.cache_size,
)
MinRK
add %config magic for configuring IPython
r5225 self.configurables.append(self.displayhook)
Brian Granger
Refactor of prompts and the displayhook....
r2781 # This is a context manager that installs/revmoes the displayhook at
# the appropriate time.
self.display_trap = DisplayTrap(hook=self.displayhook)
Ville M. Vainio
crlf -> lf
r1032
Takafumi Arakaki
Make lib.latextools configurable...
r7861 def init_latextool(self):
"""Configure LaTeXTool."""
MinRK
use `parent=self` throughout IPython...
r11064 cfg = LaTeXTool.instance(parent=self)
Takafumi Arakaki
Make lib.latextools configurable...
r7861 if cfg not in self.configurables:
self.configurables.append(cfg)
Thomas Kluyver
Add simple support for running inside a virtualenv.
r6085 def init_virtualenv(self):
"""Add a virtualenv to sys.path so the user can import modules from it.
This isn't perfect: it doesn't use the Python interpreter with which the
virtualenv was built, and it ignores the --no-site-packages option. A
warning will appear suggesting the user installs IPython in the
virtualenv, but for many cases, it probably works well enough.
Adapted from code snippets online.
http://blog.ufsoft.org/2009/1/29/ipython-and-virtualenv
"""
if 'VIRTUAL_ENV' not in os.environ:
# Not in a virtualenv
return
MinRK
check every link when detecting virutalenv...
r13944 # venv detection:
# stdlib venv may symlink sys.executable, so we can't use realpath.
# but others can symlink *to* the venv Python, so we can't just use sys.executable.
# So we just check every item in the symlink tree (generally <= 3)
p = sys.executable
paths = [p]
while os.path.islink(p):
p = os.path.join(os.path.dirname(p), os.readlink(p))
paths.append(p)
if any(p.startswith(os.environ['VIRTUAL_ENV']) for p in paths):
Thomas Kluyver
Add simple support for running inside a virtualenv.
r6085 # Running properly in the virtualenv, don't need to do anything
return
warn("Attempting to work in a virtualenv. If you encounter problems, please "
Thomas Kluyver
Fix IPython.utils.warn API so messages are automatically displayed followed by a newline.
r8223 "install IPython inside the virtualenv.")
Thomas Kluyver
Add simple support for running inside a virtualenv.
r6085 if sys.platform == "win32":
virtual_env = os.path.join(os.environ['VIRTUAL_ENV'], 'Lib', 'site-packages')
else:
virtual_env = os.path.join(os.environ['VIRTUAL_ENV'], 'lib',
'python%d.%d' % sys.version_info[:2], 'site-packages')
import site
sys.path.insert(0, virtual_env)
site.addsitedir(virtual_env)
Ville M. Vainio
crlf -> lf
r1032
Brian Granger
More re-organization of InteractiveShell.
r2242 #-------------------------------------------------------------------------
# Things related to injections into the sys module
#-------------------------------------------------------------------------
Ville M. Vainio
crlf -> lf
r1032
Brian Granger
More re-organization of InteractiveShell.
r2242 def save_sys_module_state(self):
"""Save the state of hooks in the sys module.
Brian Granger
Cleaned up embedded shell and added cleanup method to InteractiveShell....
r2226
Thomas Kluyver
Rename user_local_ns back to user_ns for simplicity.
r5453 This has to be called after self.user_module is created.
Brian Granger
More re-organization of InteractiveShell.
r2242 """
self._orig_sys_module_state = {}
self._orig_sys_module_state['stdin'] = sys.stdin
self._orig_sys_module_state['stdout'] = sys.stdout
self._orig_sys_module_state['stderr'] = sys.stderr
self._orig_sys_module_state['excepthook'] = sys.excepthook
Thomas Kluyver
Rename user_local_ns back to user_ns for simplicity.
r5453 self._orig_sys_modules_main_name = self.user_module.__name__
MinRK
InteractiveShell.restore_sys_module_state actually restores main...
r6829 self._orig_sys_modules_main_mod = sys.modules.get(self.user_module.__name__)
Brian Granger
Massive, crazy refactoring of everything....
r2202
Brian Granger
More re-organization of InteractiveShell.
r2242 def restore_sys_module_state(self):
"""Restore the state of the sys module."""
try:
Thomas Kluyver
Fix references to dict.iteritems and dict.itervalues
r13361 for k, v in iteritems(self._orig_sys_module_state):
Brian Granger
More re-organization of InteractiveShell.
r2242 setattr(sys, k, v)
except AttributeError:
pass
# Reset what what done in self.init_sys_modules
MinRK
InteractiveShell.restore_sys_module_state actually restores main...
r6829 if self._orig_sys_modules_main_mod is not None:
sys.modules[self._orig_sys_modules_main_name] = self._orig_sys_modules_main_mod
Brian Granger
Continuing a massive refactor of everything.
r2205
Brian Granger
More re-organization of InteractiveShell.
r2242 #-------------------------------------------------------------------------
MinRK
move banner to base InteractiveShell class
r16581 # Things related to the banner
#-------------------------------------------------------------------------
MinRK
make InteractiveShell.banner a property
r16595 @property
def banner(self):
banner = self.banner1
MinRK
move banner to base InteractiveShell class
r16581 if self.profile and self.profile != 'default':
MinRK
make InteractiveShell.banner a property
r16595 banner += '\nIPython profile: %s\n' % self.profile
MinRK
move banner to base InteractiveShell class
r16581 if self.banner2:
MinRK
make InteractiveShell.banner a property
r16595 banner += '\n' + self.banner2
return banner
MinRK
move banner to base InteractiveShell class
r16581
def show_banner(self, banner=None):
if banner is None:
banner = self.banner
self.write(banner)
#-------------------------------------------------------------------------
Brian Granger
More re-organization of InteractiveShell.
r2242 # Things related to hooks
#-------------------------------------------------------------------------
Brian Granger
Continuing a massive refactor of everything.
r2205
Brian Granger
More re-organization of InteractiveShell.
r2242 def init_hooks(self):
# hooks holds pointers used for user-side customizations
self.hooks = Struct()
Brian Granger
Continuing a massive refactor of everything.
r2205
Brian Granger
More re-organization of InteractiveShell.
r2242 self.strdispatchers = {}
Brian Granger
Continuing a massive refactor of everything.
r2205
Brian Granger
More re-organization of InteractiveShell.
r2242 # Set all default hooks, defined in the IPython.hooks module.
hooks = IPython.core.hooks
for hook_name in hooks.__all__:
# default hooks have priority 100, i.e. low; user hooks should have
# 0-100 priority
Thomas Kluyver
Deprecate some hooks in favour of callbacks
r15602 self.set_hook(hook_name,getattr(hooks,hook_name), 100, _warn_deprecated=False)
Brian Granger
Continuing a massive refactor of everything.
r2205
Thomas Kluyver
Deprecate some hooks in favour of callbacks
r15602 def set_hook(self,name,hook, priority=50, str_key=None, re_key=None,
_warn_deprecated=True):
Brian Granger
More re-organization of InteractiveShell.
r2242 """set_hook(name,hook) -> sets an internal IPython hook.
Brian Granger
Continuing a massive refactor of everything.
r2205
Brian Granger
More re-organization of InteractiveShell.
r2242 IPython exposes some of its internal API as user-modifiable hooks. By
Bernardo B. Marques
remove all trailling spaces
r4872 adding your function to one of these hooks, you can modify IPython's
Brian Granger
More re-organization of InteractiveShell.
r2242 behavior to call at runtime your own routines."""
Brian Granger
Continuing a massive refactor of everything.
r2205
Brian Granger
More re-organization of InteractiveShell.
r2242 # At some point in the future, this should validate the hook before it
# accepts it. Probably at least check that the hook takes the number
# of args it's supposed to.
Bernardo B. Marques
remove all trailling spaces
r4872
Thomas Kluyver
Clean up deprecated code: exceptions.Exception, new.instancemethod.
r3158 f = types.MethodType(hook,self)
Ville M. Vainio
crlf -> lf
r1032
Brian Granger
More re-organization of InteractiveShell.
r2242 # check if the hook is for strdispatcher first
if str_key is not None:
sdp = self.strdispatchers.get(name, StrDispatch())
sdp.add_s(str_key, f, priority )
self.strdispatchers[name] = sdp
return
if re_key is not None:
sdp = self.strdispatchers.get(name, StrDispatch())
sdp.add_re(re.compile(re_key), f, priority )
self.strdispatchers[name] = sdp
return
Bernardo B. Marques
remove all trailling spaces
r4872
Brian Granger
More re-organization of InteractiveShell.
r2242 dp = getattr(self.hooks, name, None)
if name not in IPython.core.hooks.__all__:
Matthias BUSSONNIER
use print function in module with `print >>`
r7817 print("Warning! Hook '%s' is not one of %s" % \
(name, IPython.core.hooks.__all__ ))
Thomas Kluyver
Deprecate some hooks in favour of callbacks
r15602
if _warn_deprecated and (name in IPython.core.hooks.deprecated):
alternative = IPython.core.hooks.deprecated[name]
warn("Hook {} is deprecated. Use {} instead.".format(name, alternative))
Brian Granger
More re-organization of InteractiveShell.
r2242 if not dp:
dp = IPython.core.hooks.CommandChainDispatcher()
Bernardo B. Marques
remove all trailling spaces
r4872
Ville M. Vainio
crlf -> lf
r1032 try:
Brian Granger
More re-organization of InteractiveShell.
r2242 dp.add(f,priority)
except AttributeError:
# it was not commandchain, plain old func - replace
dp = f
Ville M. Vainio
crlf -> lf
r1032
Brian Granger
More re-organization of InteractiveShell.
r2242 setattr(self.hooks,name, dp)
Ville M. Vainio
crlf -> lf
r1032
Thomas Kluyver
Start of new callback system
r15597 #-------------------------------------------------------------------------
Thomas Kluyver
Update comment
r15665 # Things related to events
Thomas Kluyver
Start of new callback system
r15597 #-------------------------------------------------------------------------
Thomas Kluyver
Rename callbacks -> events (mostly), fire -> trigger
r15605 def init_events(self):
self.events = EventManager(self, available_events)
Thomas Kluyver
Start of new callback system
r15597
Fernando Perez
Add support for simultaneous interactive and inline matplotlib plots....
r2987 def register_post_execute(self, func):
Thomas Kluyver
Update docstrings to refer to ip.events
r15611 """DEPRECATED: Use ip.events.register('post_run_cell', func)
Thomas Kluyver
Start of new callback system
r15597
Register a function for calling after code execution.
Fernando Perez
Add support for simultaneous interactive and inline matplotlib plots....
r2987 """
Thomas Kluyver
Start of new callback system
r15597 warn("ip.register_post_execute is deprecated, use "
Thomas Kluyver
Update docstrings to refer to ip.events
r15611 "ip.events.register('post_run_cell', func) instead.")
Thomas Kluyver
Rename pre/post_execute_explicit events to pre/post_run_cell
r15607 self.events.register('post_run_cell', func)
MinRK
Don't unregister failing post-exec callbacks automatically...
r5734
Brian Granger
More re-organization of InteractiveShell.
r2242 #-------------------------------------------------------------------------
# Things related to the "main" module
#-------------------------------------------------------------------------
Brian Granger
Massive, crazy refactoring of everything....
r2202
Thomas Kluyver
Replace FakeModule with ModuleType in InteractiveShell
r12562 def new_main_mod(self, filename, modname):
Brian Granger
More re-organization of InteractiveShell.
r2242 """Return a new 'main' module object for user code execution.
Thomas Kluyver
Simplify caching of modules from %run-ing scripts....
r11207
Thomas Kluyver
Update docstring of new_main_mod() method
r11275 ``filename`` should be the path of the script which will be run in the
module. Requests with the same filename will get the same module, with
its namespace cleared.
Thomas Kluyver
Replace FakeModule with ModuleType in InteractiveShell
r12562 ``modname`` should be the module name - normally either '__main__' or
the basename of the file without the extension.
Thomas Kluyver
Update docstring of new_main_mod() method
r11275 When scripts are executed via %run, we must keep a reference to their
Thomas Kluyver
Replace FakeModule with ModuleType in InteractiveShell
r12562 __main__ module around so that Python doesn't
Thomas Kluyver
Update docstring of new_main_mod() method
r11275 clear it, rendering references to module globals useless.
Ville M. Vainio
crlf -> lf
r1032
Brian Granger
More re-organization of InteractiveShell.
r2242 This method keeps said reference in a private dict, keyed by the
Thomas Kluyver
Update docstring of new_main_mod() method
r11275 absolute path of the script. This way, for multiple executions of the
same script we only keep one copy of the namespace (the last one),
thus preventing memory leaks from old references while allowing the
objects from the last execution to be accessible.
Brian Granger
More re-organization of InteractiveShell.
r2242 """
Thomas Kluyver
Simplify caching of modules from %run-ing scripts....
r11207 filename = os.path.abspath(filename)
try:
main_mod = self._main_mod_cache[filename]
except KeyError:
Thomas Kluyver
Replace FakeModule with ModuleType in InteractiveShell
r12562 main_mod = self._main_mod_cache[filename] = types.ModuleType(modname,
doc="Module created for script run in IPython")
Thomas Kluyver
Simplify caching of modules from %run-ing scripts....
r11207 else:
Thomas Kluyver
Replace FakeModule with ModuleType in InteractiveShell
r12562 main_mod.__dict__.clear()
main_mod.__name__ = modname
main_mod.__file__ = filename
# It seems pydoc (and perhaps others) needs any module instance to
# implement a __nonzero__ method
main_mod.__nonzero__ = lambda : True
Thomas Kluyver
Simplify caching of modules from %run-ing scripts....
r11207
return main_mod
Ville M. Vainio
crlf -> lf
r1032
Brian Granger
More re-organization of InteractiveShell.
r2242 def clear_main_mod_cache(self):
"""Clear the cache of main modules.
Brian Granger
Massive, crazy refactoring of everything....
r2202
Brian Granger
More re-organization of InteractiveShell.
r2242 Mainly for use by utilities like %reset.
Brian Granger
Massive, crazy refactoring of everything....
r2202
Brian Granger
More re-organization of InteractiveShell.
r2242 Examples
--------
Ville M. Vainio
crlf -> lf
r1032
Brian Granger
More re-organization of InteractiveShell.
r2242 In [15]: import IPython
Ville M. Vainio
crlf -> lf
r1032
Thomas Kluyver
Replace FakeModule with ModuleType in InteractiveShell
r12562 In [16]: m = _ip.new_main_mod(IPython.__file__, 'IPython')
Ville M. Vainio
crlf -> lf
r1032
Thomas Kluyver
Simplify caching of modules from %run-ing scripts....
r11207 In [17]: len(_ip._main_mod_cache) > 0
Brian Granger
More re-organization of InteractiveShell.
r2242 Out[17]: True
Ville M. Vainio
crlf -> lf
r1032
Brian Granger
More re-organization of InteractiveShell.
r2242 In [18]: _ip.clear_main_mod_cache()
Fernando Perez
Fix bug: https://bugs.launchpad.net/ipython/+bug/269966...
r1856
Thomas Kluyver
Simplify caching of modules from %run-ing scripts....
r11207 In [19]: len(_ip._main_mod_cache) == 0
Brian Granger
More re-organization of InteractiveShell.
r2242 Out[19]: True
"""
Thomas Kluyver
Simplify caching of modules from %run-ing scripts....
r11207 self._main_mod_cache.clear()
Brian Granger
More work on getting rid of ipmaker.
r2203
Brian Granger
More re-organization of InteractiveShell.
r2242 #-------------------------------------------------------------------------
# Things related to debugging
#-------------------------------------------------------------------------
Brian Granger
More work on getting rid of ipmaker.
r2203
Brian Granger
More re-organization of InteractiveShell.
r2242 def init_pdb(self):
# Set calling of pdb on exceptions
# self.call_pdb is a property
self.call_pdb = self.pdb
Ville M. Vainio
crlf -> lf
r1032
Brian Granger
More re-organization of InteractiveShell.
r2242 def _get_call_pdb(self):
return self._call_pdb
def _set_call_pdb(self,val):
if val not in (0,1,False,True):
Bradley M. Froehle
Apply most 2to3 raise fixes....
r7843 raise ValueError('new call_pdb value must be boolean')
Brian Granger
More re-organization of InteractiveShell.
r2242
# store value in instance
self._call_pdb = val
# notify the actual exception handlers
self.InteractiveTB.call_pdb = val
call_pdb = property(_get_call_pdb,_set_call_pdb,None,
'Control auto-activation of pdb at exceptions')
def debugger(self,force=False):
"""Call the pydb/pdb debugger.
Keywords:
- force(False): by default, this routine checks the instance call_pdb
Thomas Kluyver
Improvements to docs formatting.
r12553 flag and does not actually invoke the debugger if the flag is false.
The 'force' option forces the debugger to activate even if the flag
is false.
Brian Granger
More re-organization of InteractiveShell.
r2242 """
if not (force or self.call_pdb):
Brian Granger
More work on getting rid of ipmaker.
r2203 return
Brian Granger
More re-organization of InteractiveShell.
r2242 if not hasattr(sys,'last_traceback'):
error('No traceback has been produced, nothing to debug.')
return
# use pydb if available
if debugger.has_pydb:
from pydb import pm
Brian Granger
More work on getting rid of ipmaker.
r2203 else:
Brian Granger
More re-organization of InteractiveShell.
r2242 # fallback to our internal debugger
pm = lambda : self.InteractiveTB.debugger(force=True)
Bernardo B. Marques
remove all trailling spaces
r4872
Thomas Kluyver
Add context manager to reload readline history when leaving a block.
r3474 with self.readline_no_record:
pm()
Brian Granger
More work on getting rid of ipmaker.
r2203
Brian Granger
More re-organization of InteractiveShell.
r2242 #-------------------------------------------------------------------------
# Things related to IPython's various namespaces
#-------------------------------------------------------------------------
Thomas Kluyver
Simplify logic for deciding when to auto-detect local namespace and module.
r5669 default_user_namespaces = True
Brian Granger
More work on getting rid of ipmaker.
r2203
Thomas Kluyver
Rename user_local_ns back to user_ns for simplicity.
r5453 def init_create_namespaces(self, user_module=None, user_ns=None):
Brian Granger
More re-organization of InteractiveShell.
r2242 # Create the namespace where the user will operate. user_ns is
# normally the only one used, and it is passed to the exec calls as
# the locals argument. But we do carry a user_global_ns namespace
# given as the exec 'globals' argument, This is useful in embedding
# situations where the ipython shell opens in a context where the
# distinction between locals and globals is meaningful. For
# non-embedded contexts, it is just the same object as the user_ns dict.
Brian Granger
More work on getting rid of ipmaker.
r2203
Brian Granger
More re-organization of InteractiveShell.
r2242 # FIXME. For some strange reason, __builtins__ is showing up at user
# level as a dict instead of a module. This is a manual fix, but I
# should really track down where the problem is coming from. Alex
# Schmolck reported this problem first.
Brian Granger
More work on getting rid of ipmaker.
r2203
Brian Granger
More re-organization of InteractiveShell.
r2242 # A useful post by Alex Martelli on this topic:
# Re: inconsistent value from __builtins__
# Von: Alex Martelli <aleaxit@yahoo.com>
# Datum: Freitag 01 Oktober 2004 04:45:34 nachmittags/abends
# Gruppen: comp.lang.python
Brian Granger
More work on getting rid of ipmaker.
r2203
Brian Granger
More re-organization of InteractiveShell.
r2242 # Michael Hohn <hohn@hooknose.lbl.gov> wrote:
# > >>> print type(builtin_check.get_global_binding('__builtins__'))
# > <type 'dict'>
# > >>> print type(__builtins__)
# > <type 'module'>
# > Is this difference in return value intentional?
# Well, it's documented that '__builtins__' can be either a dictionary
# or a module, and it's been that way for a long time. Whether it's
# intentional (or sensible), I don't know. In any case, the idea is
# that if you need to access the built-in namespace directly, you
# should start with "import __builtin__" (note, no 's') which will
# definitely give you a module. Yeah, it's somewhat confusing:-(.
Thomas Kluyver
Use user_ns as global namespace if it is passed without user_module, and add test for pickling interactively defined objects....
r5456 # These routines return a properly built module and dict as needed by
# the rest of the code, and can also be used by extension writers to
# generate properly initialized namespaces.
Thomas Kluyver
Simplify logic for deciding when to auto-detect local namespace and module.
r5669 if (user_ns is not None) or (user_module is not None):
self.default_user_namespaces = False
Thomas Kluyver
Use user_ns as global namespace if it is passed without user_module, and add test for pickling interactively defined objects....
r5456 self.user_module, self.user_ns = self.prepare_user_module(user_module, user_ns)
Brian Granger
More re-organization of InteractiveShell.
r2242
Thomas Kluyver
Use user_ns as global namespace if it is passed without user_module, and add test for pickling interactively defined objects....
r5456 # A record of hidden variables we have added to the user namespace, so
# we can list later only variables defined in actual interactive use.
Thomas Kluyver
Implement a better check for hidden values for %who etc.
r12257 self.user_ns_hidden = {}
Brian Granger
More re-organization of InteractiveShell.
r2242
# Now that FakeModule produces a real module, we've run into a nasty
# problem: after script execution (via %run), the module where the user
# code ran is deleted. Now that this object is a true module (needed
# so docetst and other tools work correctly), the Python module
# teardown mechanism runs over it, and sets to None every variable
# present in that module. Top-level references to objects from the
# script survive, because the user_ns is updated with them. However,
# calling functions defined in the script that use other things from
# the script will fail, because the function's closure had references
# to the original objects, which are now all None. So we must protect
# these modules from deletion by keeping a cache.
Bernardo B. Marques
remove all trailling spaces
r4872 #
Brian Granger
More re-organization of InteractiveShell.
r2242 # To avoid keeping stale modules around (we only need the one from the
# last run), we use a dict keyed with the full path to the script, so
# only the last version of the module is held in the cache. Note,
# however, that we must cache the module *namespace contents* (their
# __dict__). Because if we try to cache the actual modules, old ones
# (uncached) could be destroyed while still holding references (such as
# those held by GUI objects that tend to be long-lived)>
Bernardo B. Marques
remove all trailling spaces
r4872 #
Brian Granger
More re-organization of InteractiveShell.
r2242 # The %reset command will flush this cache. See the cache_main_mod()
# and clear_main_mod_cache() methods for details on use.
# This is the cache used for 'main' namespaces
Thomas Kluyver
Simplify caching of modules from %run-ing scripts....
r11207 self._main_mod_cache = {}
Brian Granger
More re-organization of InteractiveShell.
r2242
# A table holding all the namespaces IPython deals with, so that
# introspection facilities can search easily.
Thomas Kluyver
Rename user_local_ns back to user_ns for simplicity.
r5453 self.ns_table = {'user_global':self.user_module.__dict__,
Thomas Kluyver
Fix wildcard search for new namespace model....
r5550 'user_local':self.user_ns,
Thomas Kluyver
Repair various failures in the test suite.
r4734 'builtin':builtin_mod.__dict__
Brian Granger
More re-organization of InteractiveShell.
r2242 }
Thomas Kluyver
Start converting user namespace machinery to use a module.
r5452
@property
def user_global_ns(self):
return self.user_module.__dict__
Brian Granger
More work addressing review comments for Fernando's branch....
r2499
Thomas Kluyver
Use user_ns as global namespace if it is passed without user_module, and add test for pickling interactively defined objects....
r5456 def prepare_user_module(self, user_module=None, user_ns=None):
"""Prepare the module and namespace in which user code will be run.
When IPython is started normally, both parameters are None: a new module
is created automatically, and its __dict__ used as the namespace.
If only user_module is provided, its __dict__ is used as the namespace.
If only user_ns is provided, a dummy module is created, and user_ns
becomes the global namespace. If both are provided (as they may be
when embedding), user_ns is the local namespace, and user_module
provides the global namespace.
Brian Granger
More work addressing review comments for Fernando's branch....
r2499
Parameters
----------
Thomas Kluyver
Start converting user namespace machinery to use a module.
r5452 user_module : module, optional
The current user module in which IPython is being run. If None,
a clean module will be created.
Thomas Kluyver
Use user_ns as global namespace if it is passed without user_module, and add test for pickling interactively defined objects....
r5456 user_ns : dict, optional
A namespace in which to run interactive commands.
Brian Granger
More work addressing review comments for Fernando's branch....
r2499
Returns
-------
Thomas Kluyver
Use user_ns as global namespace if it is passed without user_module, and add test for pickling interactively defined objects....
r5456 A tuple of user_module and user_ns, each properly initialised.
Brian Granger
More work addressing review comments for Fernando's branch....
r2499 """
Thomas Kluyver
Use user_ns as global namespace if it is passed without user_module, and add test for pickling interactively defined objects....
r5456 if user_module is None and user_ns is not None:
user_ns.setdefault("__name__", "__main__")
user_module = DummyMod()
user_module.__dict__ = user_ns
Thomas Kluyver
Start converting user namespace machinery to use a module.
r5452 if user_module is None:
user_module = types.ModuleType("__main__",
doc="Automatically created module for IPython interactive environment")
Brian Granger
More work addressing review comments for Fernando's branch....
r2499 # We must ensure that __builtin__ (without the final 's') is always
# available and pointing to the __builtin__ *module*. For more details:
# http://mail.python.org/pipermail/python-dev/2001-April/014068.html
Thomas Kluyver
Clear up mistakes from rebasing.
r5460 user_module.__dict__.setdefault('__builtin__', builtin_mod)
user_module.__dict__.setdefault('__builtins__', builtin_mod)
Thomas Kluyver
Use user_ns as global namespace if it is passed without user_module, and add test for pickling interactively defined objects....
r5456
if user_ns is None:
user_ns = user_module.__dict__
Brian Granger
More work addressing review comments for Fernando's branch....
r2499
Thomas Kluyver
Use user_ns as global namespace if it is passed without user_module, and add test for pickling interactively defined objects....
r5456 return user_module, user_ns
Brian Granger
More work addressing review comments for Fernando's branch....
r2499
Brian Granger
More re-organization of InteractiveShell.
r2242 def init_sys_modules(self):
# We need to insert into sys.modules something that looks like a
# module but which accesses the IPython namespace, for shelve and
# pickle to work interactively. Normally they rely on getting
# everything out of __main__, but for embedding purposes each IPython
# instance has its own private namespace, so we can't go shoving
# everything into __main__.
# note, however, that we should only do this for non-embedded
# ipythons, which really mimic the __main__.__dict__ with their own
# namespace. Embedded instances, on the other hand, should not do
# this because they need to manage the user local/global namespaces
# only, but they live within a 'normal' __main__ (meaning, they
# shouldn't overtake the execution environment of the script they're
# embedded in).
Brian Granger
More work on getting rid of ipmaker.
r2203
Brian Granger
More re-organization of InteractiveShell.
r2242 # This is overridden in the InteractiveShellEmbed subclass to a no-op.
Thomas Kluyver
Start converting user namespace machinery to use a module.
r5452 main_name = self.user_module.__name__
sys.modules[main_name] = self.user_module
Ville M. Vainio
crlf -> lf
r1032
Brian Granger
Cleaned up embedded shell and added cleanup method to InteractiveShell....
r2226 def init_user_ns(self):
Fernando Perez
Fix https://bugs.launchpad.net/ipython/+bug/239054...
r1859 """Initialize all user-visible namespaces to their minimum defaults.
Certain history lists are also initialized here, as they effectively
act as user namespaces.
Brian Granger
Merging -r 1182 from lp:ipython....
r2131 Notes
-----
Fernando Perez
Fix https://bugs.launchpad.net/ipython/+bug/239054...
r1859 All data structures here are only filled in, they are NOT reset by this
method. If they were not empty before, data will simply be added to
therm.
"""
Fernando Perez
Work in multiple places to improve state of the test suite....
r2398 # This function works in two parts: first we put a few things in
Brian Granger
More work to address review comments....
r2509 # user_ns, and we sync that contents into user_ns_hidden so that these
Fernando Perez
Work in multiple places to improve state of the test suite....
r2398 # initial variables aren't shown by %who. After the sync, we add the
# rest of what we *do* want the user to see with %who even on a new
Fernando Perez
Ensure that __builtin__ is always available and compute prompts from it....
r2485 # session (probably nothing, so theye really only see their own stuff)
# The user dict must *always* have a __builtin__ reference to the
# Python standard __builtin__ namespace, which must be imported.
# This is so that certain operations in prompt evaluation can be
# reliably executed with builtins. Note that we can NOT use
# __builtins__ (note the 's'), because that can either be a dict or a
# module, and can even mutate at runtime, depending on the context
# (Python makes no guarantees on it). In contrast, __builtin__ is
# always a module object, though it must be explicitly imported.
Bernardo B. Marques
remove all trailling spaces
r4872
Fernando Perez
Ensure that __builtin__ is always available and compute prompts from it....
r2485 # For more details:
# http://mail.python.org/pipermail/python-dev/2001-April/014068.html
Thomas Kluyver
Start converting user namespace machinery to use a module.
r5452 ns = dict()
Fernando Perez
Fix https://bugs.launchpad.net/ipython/+bug/239054...
r1859 # make global variables for user access to the histories
Satrajit Ghosh
History refactored and saved to json file...
r3240 ns['_ih'] = self.history_manager.input_hist_parsed
ns['_oh'] = self.history_manager.output_hist
ns['_dh'] = self.history_manager.dir_hist
Fernando Perez
Work in multiple places to improve state of the test suite....
r2398
ns['_sh'] = shadowns
Fernando Perez
Clean up output of %who
r2472 # user aliases to input and output histories. These shouldn't show up
# in %who, as they can have very large reprs.
Satrajit Ghosh
History refactored and saved to json file...
r3240 ns['In'] = self.history_manager.input_hist_parsed
ns['Out'] = self.history_manager.output_hist
Fernando Perez
Fix https://bugs.launchpad.net/ipython/+bug/239054...
r1859
Fernando Perez
Work in multiple places to improve state of the test suite....
r2398 # Store myself as the public api!!!
ns['get_ipython'] = self.get_ipython
Thomas Kluyver
Expose InteractiveShell instance to user as _ipy.
r5457
Thomas Kluyver
Remove capitalised exit forms.
r3725 ns['exit'] = self.exiter
ns['quit'] = self.exiter
Fernando Perez
Clean up output of %who
r2472
Brian Granger
More work to address review comments....
r2509 # Sync what we've added so far to user_ns_hidden so these aren't seen
Fernando Perez
Clean up output of %who
r2472 # by %who
Brian Granger
More work to address review comments....
r2509 self.user_ns_hidden.update(ns)
Fernando Perez
Clean up output of %who
r2472
# Anything put into ns now would show up in %who. Think twice before
# putting anything here, as we really want %who to show the user their
# stuff, not our variables.
Bernardo B. Marques
remove all trailling spaces
r4872
Fernando Perez
Clean up output of %who
r2472 # Finally, update the real user's namespace
Thomas Kluyver
Rename user_local_ns back to user_ns for simplicity.
r5453 self.user_ns.update(ns)
Thomas Kluyver
Minor improvements to how namespaces are handled.
r5458
@property
def all_ns_refs(self):
"""Get a list of references to all the namespace dictionaries in which
IPython might store a user-created object.
Note that this does not include the displayhook, which also caches
objects from the output."""
Thomas Kluyver
Tweaks to interactiveshell for user_ns_hidden as dict
r12259 return [self.user_ns, self.user_global_ns, self.user_ns_hidden] + \
Thomas Kluyver
Simplify caching of modules from %run-ing scripts....
r11207 [m.__dict__ for m in self._main_mod_cache.values()]
Fernando Perez
Fix https://bugs.launchpad.net/ipython/+bug/239054...
r1859
Thomas Kluyver
ipython-qtconsole now calls the right function.
r3397 def reset(self, new_session=True):
Thomas Kluyver
Shell's reset method clears namespace from last %run command.
r3762 """Clear all internal namespaces, and attempt to release references to
user objects.
Bernardo B. Marques
remove all trailling spaces
r4872
Thomas Kluyver
ipython-qtconsole now calls the right function.
r3397 If new_session is True, a new history session will be opened.
Brian Granger
More re-organization of InteractiveShell.
r2242 """
MinRK
merge interactiveshell.py
r3122 # Clear histories
Thomas Kluyver
ipython-qtconsole now calls the right function.
r3397 self.history_manager.reset(new_session)
Thomas Kluyver
%reset doesn't reset prompt number.
r3703 # Reset counter used to index all histories
if new_session:
self.execution_count = 1
Bernardo B. Marques
remove all trailling spaces
r4872
Thomas Kluyver
Implement hard reset with '%reset -h' call....
r3521 # Flush cached output items
MinRK
don't flush displayhook if caching is disabled
r3810 if self.displayhook.do_full_cache:
self.displayhook.flush()
Bernardo B. Marques
remove all trailling spaces
r4872
Thomas Kluyver
Restore Fernando's fix for the __del__ methods on exit bug.
r3157 # The main execution namespaces must be cleared very carefully,
# skipping the deletion of the builtin-related keys, because doing so
# would cause errors in many object's __del__ methods.
Thomas Kluyver
Use user_ns as global namespace if it is passed without user_module, and add test for pickling interactively defined objects....
r5456 if self.user_ns is not self.user_global_ns:
self.user_ns.clear()
ns = self.user_global_ns
drop_keys = set(ns.keys())
drop_keys.discard('__builtin__')
drop_keys.discard('__builtins__')
drop_keys.discard('__name__')
for k in drop_keys:
del ns[k]
Thomas Kluyver
Minor improvements to how namespaces are handled.
r5458 self.user_ns_hidden.clear()
Thomas Kluyver
Restore Fernando's fix for the __del__ methods on exit bug.
r3157 # Restore the user namespaces to minimal usability
Brian Granger
More re-organization of InteractiveShell.
r2242 self.init_user_ns()
MinRK
merge interactiveshell.py
r3122
Brian Granger
Massive refactoring of of the core....
r2245 # Restore the default and user aliases
MinRK
merge interactiveshell.py
r3122 self.alias_manager.clear_aliases()
Brian Granger
Massive refactoring of of the core....
r2245 self.alias_manager.init_aliases()
Bernardo B. Marques
remove all trailling spaces
r4872
Thomas Kluyver
Implement hard reset with '%reset -h' call....
r3521 # Flush the private list of module references kept for script
# execution protection
self.clear_main_mod_cache()
Bernardo B. Marques
remove all trailling spaces
r4872
Thomas Kluyver
Implement deletion mechanism to remove references held by IPython behind the scenes. Exposed to the user as %xdel.
r3823 def del_var(self, varname, by_name=False):
"""Delete a variable from the various namespaces, so that, as
far as possible, we're not keeping any hidden references to it.
Bernardo B. Marques
remove all trailling spaces
r4872
Thomas Kluyver
Implement deletion mechanism to remove references held by IPython behind the scenes. Exposed to the user as %xdel.
r3823 Parameters
----------
varname : str
The name of the variable to delete.
by_name : bool
If True, delete variables with the given name in each
namespace. If False (default), find the variable in the user
namespace, and delete references to it.
"""
if varname in ('__builtin__', '__builtins__'):
raise ValueError("Refusing to delete %s" % varname)
Bernardo B. Marques
remove all trailling spaces
r4872
Thomas Kluyver
Minor improvements to how namespaces are handled.
r5458 ns_refs = self.all_ns_refs
Thomas Kluyver
Remove extraneous internal_ns and ns_refs_table variables.
r5454
Thomas Kluyver
Implement deletion mechanism to remove references held by IPython behind the scenes. Exposed to the user as %xdel.
r3823 if by_name: # Delete by name
for ns in ns_refs:
try:
del ns[varname]
except KeyError:
pass
else: # Delete by object
try:
obj = self.user_ns[varname]
except KeyError:
raise NameError("name '%s' is not defined" % varname)
# Also check in output history
ns_refs.append(self.history_manager.output_hist)
for ns in ns_refs:
Thomas Kluyver
Fix references to dict.iteritems and dict.itervalues
r13361 to_delete = [n for n, o in iteritems(ns) if o is obj]
Thomas Kluyver
Implement deletion mechanism to remove references held by IPython behind the scenes. Exposed to the user as %xdel.
r3823 for name in to_delete:
del ns[name]
Bernardo B. Marques
remove all trailling spaces
r4872
Thomas Kluyver
Implement deletion mechanism to remove references held by IPython behind the scenes. Exposed to the user as %xdel.
r3823 # displayhook keeps extra references, but not in a dictionary
for name in ('_', '__', '___'):
if getattr(self.displayhook, name) is obj:
setattr(self.displayhook, name, None)
Bernardo B. Marques
remove all trailling spaces
r4872
Brad Reisfeld
New magic: %reset_selective....
r2577 def reset_selective(self, regex=None):
Fernando Perez
Small cleanups, no functional changes.
r2955 """Clear selective variables from internal namespaces based on a
specified regular expression.
Brad Reisfeld
New magic: %reset_selective....
r2577
Parameters
----------
regex : string or compiled pattern, optional
Fernando Perez
Small cleanups, no functional changes.
r2955 A regular expression pattern that will be used in searching
variable names in the users namespaces.
Brad Reisfeld
New magic: %reset_selective....
r2577 """
if regex is not None:
try:
m = re.compile(regex)
except TypeError:
raise TypeError('regex must be a string or compiled pattern')
# Search for keys in each namespace that match the given regex
# If a match is found, delete the key/value pair.
Thomas Kluyver
Minor improvements to how namespaces are handled.
r5458 for ns in self.all_ns_refs:
Brad Reisfeld
New magic: %reset_selective....
r2577 for var in ns:
if m.search(var):
Bernardo B. Marques
remove all trailling spaces
r4872 del ns[var]
Brian Granger
More re-organization of InteractiveShell.
r2242 def push(self, variables, interactive=True):
"""Inject a group of variables into the IPython user namespace.
Parameters
----------
variables : dict, str or list/tuple of str
Fernando Perez
Small cleanups, no functional changes.
r2955 The variables to inject into the user's namespace. If a dict, a
simple update is done. If a str, the string is assumed to have
variable names separated by spaces. A list/tuple of str can also
be used to give the variable names. If just the variable names are
give (list/tuple/str) then the variable values looked up in the
callers frame.
Brian Granger
More re-organization of InteractiveShell.
r2242 interactive : bool
If True (default), the variables will be listed with the ``who``
magic.
"""
vdict = None
# We need a dict of name/value pairs to do namespace updates.
if isinstance(variables, dict):
vdict = variables
Thomas Kluyver
Replace references to unicode and basestring
r13353 elif isinstance(variables, string_types+(list, tuple)):
if isinstance(variables, string_types):
Brian Granger
More re-organization of InteractiveShell.
r2242 vlist = variables.split()
else:
vlist = variables
vdict = {}
cf = sys._getframe(1)
for name in vlist:
try:
vdict[name] = eval(name, cf.f_globals, cf.f_locals)
except:
Matthias BUSSONNIER
use print function in module with `print >>`
r7817 print('Could not get variable %s from %s' %
Brian Granger
More re-organization of InteractiveShell.
r2242 (name,cf.f_code.co_name))
else:
raise ValueError('variables must be a dict/str/list/tuple')
Bernardo B. Marques
remove all trailling spaces
r4872
Brian Granger
More re-organization of InteractiveShell.
r2242 # Propagate variables to user namespace
self.user_ns.update(vdict)
# And configure interactive visibility
Thomas Kluyver
Start converting user namespace machinery to use a module.
r5452 user_ns_hidden = self.user_ns_hidden
Brian Granger
More re-organization of InteractiveShell.
r2242 if interactive:
Thomas Kluyver
Implement a better check for hidden values for %who etc.
r12257 for name in vdict:
user_ns_hidden.pop(name, None)
Brian Granger
More re-organization of InteractiveShell.
r2242 else:
Thomas Kluyver
Minor improvements to how namespaces are handled.
r5458 user_ns_hidden.update(vdict)
Thomas Kluyver
Add drop_by_id method to shell, to remove variables added by extensions.
r5068
def drop_by_id(self, variables):
"""Remove a dict of variables from the user namespace, if they are the
same as the values in the dictionary.
This is intended for use by extensions: variables that they've added can
be taken back out if they are unloaded, without removing any that the
user has overwritten.
Parameters
----------
variables : dict
A dictionary mapping object names (as strings) to the objects.
"""
Thomas Kluyver
Fix references to dict.iteritems and dict.itervalues
r13361 for name, obj in iteritems(variables):
Thomas Kluyver
Add drop_by_id method to shell, to remove variables added by extensions.
r5068 if name in self.user_ns and self.user_ns[name] is obj:
del self.user_ns[name]
Thomas Kluyver
Tweaks to interactiveshell for user_ns_hidden as dict
r12259 self.user_ns_hidden.pop(name, None)
Brian Granger
More re-organization of InteractiveShell.
r2242
#-------------------------------------------------------------------------
Fernando Perez
Move object inspection machinery out of the magics code....
r2927 # Things related to object introspection
#-------------------------------------------------------------------------
Fernando Perez
Initialize input_splitter automatically via traitlets mechanism.
r3049
Fernando Perez
Move object inspection machinery out of the magics code....
r2927 def _ofind(self, oname, namespaces=None):
"""Find an object in the available namespaces.
self._ofind(oname) -> dict with keys: found,obj,ospace,ismagic
Has special code to detect magic functions.
"""
Thomas Kluyver
Start using py3compat module.
r4731 oname = oname.strip()
Fernando Perez
Continue restructuring info system, move some standalone code to utils.
r2929 #print '1- oname: <%r>' % oname # dbg
MinRK
oinfo finds cell magics with same name as line magics...
r7435 if not oname.startswith(ESC_MAGIC) and \
MinRK
define ESC_FOO consts only in inputsplitter...
r7437 not oname.startswith(ESC_MAGIC2) and \
MinRK
oinfo finds cell magics with same name as line magics...
r7435 not py3compat.isidentifier(oname, dotted=True):
Thomas Kluyver
Python 3 compatibility for identifiers.
r4740 return dict(found=False)
Fernando Perez
Continue restructuring info system, move some standalone code to utils.
r2929
Fernando Perez
Move object inspection machinery out of the magics code....
r2927 alias_ns = None
if namespaces is None:
# Namespaces to search in:
# Put them in a list. The order is important so that we
# find things in the same order that Python finds them.
Fernando Perez
Clean up unnecessary references to self.shell (which are circular)
r2928 namespaces = [ ('Interactive', self.user_ns),
Thomas Kluyver
Remove extraneous internal_ns and ns_refs_table variables.
r5454 ('Interactive (global)', self.user_global_ns),
Thomas Kluyver
Repair various failures in the test suite.
r4734 ('Python builtin', builtin_mod.__dict__),
Fernando Perez
Move object inspection machinery out of the magics code....
r2927 ]
# initialize results to 'null'
found = False; obj = None; ospace = None; ds = None;
ismagic = False; isalias = False; parent = None
# We need to special-case 'print', which as of python2.6 registers as a
# function but should only be treated as one if print_function was
# loaded with a future import. In this case, just bail.
Thomas Kluyver
Fix for looking up print function in Python 3.
r4741 if (oname == 'print' and not py3compat.PY3 and not \
(self.compile.compiler_flags & __future__.CO_FUTURE_PRINT_FUNCTION)):
Fernando Perez
Move object inspection machinery out of the magics code....
r2927 return {'found':found, 'obj':obj, 'namespace':ospace,
'ismagic':ismagic, 'isalias':isalias, 'parent':parent}
# Look for the given name by splitting it in parts. If the head is
# found, then we look for all the remaining parts as members, and only
# declare success if we can find them all.
oname_parts = oname.split('.')
oname_head, oname_rest = oname_parts[0],oname_parts[1:]
for nsname,ns in namespaces:
try:
obj = ns[oname_head]
except KeyError:
continue
else:
#print 'oname_rest:', oname_rest # dbg
immerrr
core.interactiveshell.ofind: don't evaluate property.fget (it may raise)
r17024 for idx, part in enumerate(oname_rest):
Fernando Perez
Move object inspection machinery out of the magics code....
r2927 try:
parent = obj
immerrr
core.interactiveshell.ofind: don't evaluate property.fget (it may raise)
r17024 # The last part is looked up in a special way to avoid
# descriptor invocation as it may raise or have side
# effects.
if idx == len(oname_rest) - 1:
obj = self._getattr_property(obj, part)
else:
obj = getattr(obj, part)
Fernando Perez
Move object inspection machinery out of the magics code....
r2927 except:
# Blanket except b/c some badly implemented objects
# allow __getattr__ to raise exceptions other than
# AttributeError, which then crashes IPython.
break
else:
# If we finish the for loop (no break), we got all members
found = True
ospace = nsname
break # namespace loop
# Try to see if it's magic
if not found:
MinRK
oinfo finds cell magics with same name as line magics...
r7435 obj = None
MinRK
define ESC_FOO consts only in inputsplitter...
r7437 if oname.startswith(ESC_MAGIC2):
oname = oname.lstrip(ESC_MAGIC2)
Fernando Perez
Add support for finding cell magics with ?/??....
r6997 obj = self.find_cell_magic(oname)
MinRK
oinfo finds cell magics with same name as line magics...
r7435 elif oname.startswith(ESC_MAGIC):
oname = oname.lstrip(ESC_MAGIC)
obj = self.find_line_magic(oname)
else:
# search without prefix, so run? will find %run?
obj = self.find_line_magic(oname)
if obj is None:
obj = self.find_cell_magic(oname)
Fernando Perez
Move object inspection machinery out of the magics code....
r2927 if obj is not None:
found = True
ospace = 'IPython internal'
ismagic = True
# Last try: special-case some literals like '', [], {}, etc:
if not found and oname_head in ["''",'""','[]','{}','()']:
obj = eval(oname_head)
found = True
ospace = 'Interactive'
Fernando Perez
Continue restructuring info system, move some standalone code to utils.
r2929
Fernando Perez
Move object inspection machinery out of the magics code....
r2927 return {'found':found, 'obj':obj, 'namespace':ospace,
'ismagic':ismagic, 'isalias':isalias, 'parent':parent}
immerrr
core.interactiveshell.ofind: don't evaluate property.fget (it may raise)
r17024 @staticmethod
def _getattr_property(obj, attrname):
"""Property-aware getattr to use in object finding.
If attrname represents a property, return it unevaluated (in case it has
side effects or raises an error.
"""
if not isinstance(obj, type):
try:
# `getattr(type(obj), attrname)` is not guaranteed to return
# `obj`, but does so for property:
#
# property.__get__(self, None, cls) -> self
#
# The universal alternative is to traverse the mro manually
# searching for attrname in class dicts.
attr = getattr(type(obj), attrname)
except AttributeError:
pass
else:
# This relies on the fact that data descriptors (with both
# __get__ & __set__ magic methods) take precedence over
# instance-level attributes:
#
# class A(object):
# @property
# def foobar(self): return 123
# a = A()
# a.__dict__['foobar'] = 345
# a.foobar # == 123
#
# So, a property may be returned right away.
if isinstance(attr, property):
return attr
# Nothing helped, fall back.
return getattr(obj, attrname)
Fernando Perez
Continue restructuring info system, move some standalone code to utils.
r2929
def _object_find(self, oname, namespaces=None):
"""Find an object and return a struct with info about it."""
immerrr
core.interactiveshell.ofind: don't evaluate property.fget (it may raise)
r17024 return Struct(self._ofind(oname, namespaces))
Bernardo B. Marques
remove all trailling spaces
r4872
Fernando Perez
Continue restructuring info system, move some standalone code to utils.
r2929 def _inspect(self, meth, oname, namespaces=None, **kw):
"""Generic interface to the inspector system.
This function is meant to be called by pdef, pdoc & friends."""
Bradley M. Froehle
Pass along namespaces, so that we can find objects when calling in ipdb.
r7905 info = self._object_find(oname, namespaces)
Fernando Perez
Continue restructuring info system, move some standalone code to utils.
r2929 if info.found:
pmethod = getattr(self.inspector, meth)
formatter = format_screen if info.ismagic else None
Fernando Perez
Move object inspection machinery out of the magics code....
r2927 if meth == 'pdoc':
Fernando Perez
Continue restructuring info system, move some standalone code to utils.
r2929 pmethod(info.obj, oname, formatter)
Fernando Perez
Move object inspection machinery out of the magics code....
r2927 elif meth == 'pinfo':
Fernando Perez
Continue restructuring info system, move some standalone code to utils.
r2929 pmethod(info.obj, oname, formatter, info, **kw)
Fernando Perez
Move object inspection machinery out of the magics code....
r2927 else:
Fernando Perez
Continue restructuring info system, move some standalone code to utils.
r2929 pmethod(info.obj, oname)
Fernando Perez
Move object inspection machinery out of the magics code....
r2927 else:
Matthias BUSSONNIER
use print function in module with `print >>`
r7817 print('Object `%s` not found.' % oname)
Fernando Perez
Move object inspection machinery out of the magics code....
r2927 return 'not found' # so callers can take other action
Fernando Perez
Continue restructuring info system, move some standalone code to utils.
r2929
MinRK
add detail_level to object_info requests...
r6556 def object_inspect(self, oname, detail_level=0):
MinRK
add object_inspect_text...
r16579 """Get object info about oname"""
David Warde-Farley
fix issue 337 with incorrect calltips being generated for magics
r3685 with self.builtin_trap:
info = self._object_find(oname)
if info.found:
MinRK
add detail_level to object_info requests...
r6556 return self.inspector.info(info.obj, oname, info=info,
detail_level=detail_level
)
David Warde-Farley
fix issue 337 with incorrect calltips being generated for magics
r3685 else:
return oinspect.object_info(name=oname, found=False)
Robert Kern
BUG: mk_object_info -> object_info
r3053
MinRK
add object_inspect_text...
r16579 def object_inspect_text(self, oname, detail_level=0):
"""Get object info as formatted text"""
with self.builtin_trap:
info = self._object_find(oname)
if info.found:
return self.inspector._format_info(info.obj, oname, info=info,
detail_level=detail_level
)
else:
raise KeyError(oname)
Fernando Perez
Move object inspection machinery out of the magics code....
r2927 #-------------------------------------------------------------------------
Brian Granger
More re-organization of InteractiveShell.
r2242 # Things related to history management
#-------------------------------------------------------------------------
def init_history(self):
Thomas Kluyver
Move history thread initialisation to init_history, and expand docstrings.
r3259 """Sets up the command history, and starts regular autosaves."""
MinRK
use `parent=self` throughout IPython...
r11064 self.history_manager = HistoryManager(shell=self, parent=self)
MinRK
add %config magic for configuring IPython
r5225 self.configurables.append(self.history_manager)
Brian Granger
More re-organization of InteractiveShell.
r2242
#-------------------------------------------------------------------------
# Things related to exception handling and tracebacks (not debugging)
#-------------------------------------------------------------------------
Ville M. Vainio
crlf -> lf
r1032
Brian Granger
More re-organization of InteractiveShell.
r2242 def init_traceback_handlers(self, custom_exceptions):
# Syntax error handler.
Brian Granger
Initial refactoring to support structured traceback information.
r2792 self.SyntaxTB = ultratb.SyntaxTB(color_scheme='NoColor')
Bernardo B. Marques
remove all trailling spaces
r4872
Brian Granger
More re-organization of InteractiveShell.
r2242 # The interactive one is initialized with an offset, meaning we always
# want to remove the topmost item in the traceback, which is our own
# internal code. Valid modes: ['Plain','Context','Verbose']
self.InteractiveTB = ultratb.AutoFormattedTB(mode = 'Plain',
color_scheme='NoColor',
Fernando Perez
Complete implementation of interactive traceback support....
r3175 tb_offset = 1,
Thomas Kluyver
Better support compiling cells with separate __future__ environments
r9140 check_cache=check_linecache_ipython)
Ville M. Vainio
crlf -> lf
r1032
Fernando Perez
Move crash handling to the application level and simplify class structure....
r2403 # The instance will store a pointer to the system-wide exception hook,
# so that runtime code (such as magics) can access it. This is because
# during the read-eval loop, it may get temporarily overwritten.
self.sys_excepthook = sys.excepthook
Ville M. Vainio
crlf -> lf
r1032
Brian Granger
More re-organization of InteractiveShell.
r2242 # and add any custom exception handlers the user may have specified
self.set_custom_exc(*custom_exceptions)
Ville M. Vainio
crlf -> lf
r1032
Brian Granger
Work to address the review comments on Fernando's branch....
r2498 # Set the exception mode
self.InteractiveTB.set_mode(mode=self.xmode)
Fernando Perez
Improvements to exception handling to transport structured tracebacks....
r2838 def set_custom_exc(self, exc_tuple, handler):
Ville M. Vainio
crlf -> lf
r1032 """set_custom_exc(exc_tuple,handler)
Set a custom exception handler, which will be called if any of the
exceptions in exc_tuple occur in the mainloop (specifically, in the
MinRK
update set_custom_exc docstring with new-style Parameters section
r5000 run_code() method).
Ville M. Vainio
crlf -> lf
r1032
MinRK
update set_custom_exc docstring with new-style Parameters section
r5000 Parameters
----------
exc_tuple : tuple of exception classes
A *tuple* of exception classes, for which to call the defined
handler. It is very important that you use a tuple, and NOT A
LIST here, because of the way Python's except statement works. If
you only want to trap a single exception, use a singleton tuple::
Ville M. Vainio
crlf -> lf
r1032
MinRK
update set_custom_exc docstring with new-style Parameters section
r5000 exc_tuple == (MyCustomException,)
Ville M. Vainio
crlf -> lf
r1032
MinRK
update set_custom_exc docstring with new-style Parameters section
r5000 handler : callable
handler must have the following signature::
Ville M. Vainio
crlf -> lf
r1032
MinRK
update set_custom_exc docstring with new-style Parameters section
r5000 def my_handler(self, etype, value, tb, tb_offset=None):
...
return structured_traceback
Fernando Perez
Improvements to exception handling to transport structured tracebacks....
r2838
MinRK
update set_custom_exc docstring with new-style Parameters section
r5000 Your handler must return a structured traceback (a list of strings),
or None.
Ville M. Vainio
crlf -> lf
r1032
MinRK
update set_custom_exc docstring with new-style Parameters section
r5000 This will be made into an instance method (via types.MethodType)
of IPython itself, and it will be called if any of the exceptions
listed in the exc_tuple are caught. If the handler is None, an
internal basic one is used, which just prints basic info.
Brian Granger
Added compatibility layer for Shell/ipapi/iplib....
r2061
MinRK
update set_custom_exc docstring with new-style Parameters section
r5000 To protect IPython from crashes, if your handler ever raises an
exception or returns an invalid result, it will be immediately
disabled.
Ville M. Vainio
crlf -> lf
r1032
WARNING: by putting in your own exception handler into IPython's main
execution loop, you run a very good chance of nasty crashes. This
facility should only be used if you really know what you are doing."""
assert type(exc_tuple)==type(()) , \
"The custom exceptions must be given AS A TUPLE."
MinRK
protect IPython from bad custom exception handlers...
r4991 def dummy_handler(self,etype,value,tb,tb_offset=None):
Matthias BUSSONNIER
use print function in module with `print >>`
r7817 print('*** Simple custom exception handler ***')
print('Exception type :',etype)
print('Exception value:',value)
print('Traceback :',tb)
Thomas Kluyver
Remove InteractiveShell's .buffer and .buffer_raw attributes, as well as the .reset_buffer method.
r3756 #print 'Source code :','\n'.join(self.buffer)
MinRK
protect against bad return type of CustomTB...
r4999
def validate_stb(stb):
"""validate structured traceback return type
return type of CustomTB *should* be a list of strings, but allow
single strings or None, which are harmless.
This function will *always* return a list of strings,
and will raise a TypeError if stb is inappropriate.
"""
msg = "CustomTB must return list of strings, not %r" % stb
if stb is None:
return []
Thomas Kluyver
Replace references to unicode and basestring
r13353 elif isinstance(stb, string_types):
MinRK
protect against bad return type of CustomTB...
r4999 return [stb]
elif not isinstance(stb, list):
raise TypeError(msg)
# it's a list
for line in stb:
# check every element
Thomas Kluyver
Replace references to unicode and basestring
r13353 if not isinstance(line, string_types):
MinRK
protect against bad return type of CustomTB...
r4999 raise TypeError(msg)
return stb
Brian Granger
Added compatibility layer for Shell/ipapi/iplib....
r2061
MinRK
protect IPython from bad custom exception handlers...
r4991 if handler is None:
wrapped = dummy_handler
else:
def wrapped(self,etype,value,tb,tb_offset=None):
MinRK
protect against bad return type of CustomTB...
r4999 """wrap CustomTB handler, to protect IPython from user code
This makes it harder (but not impossible) for custom exception
handlers to crash IPython.
"""
MinRK
protect IPython from bad custom exception handlers...
r4991 try:
MinRK
protect against bad return type of CustomTB...
r4999 stb = handler(self,etype,value,tb,tb_offset=tb_offset)
return validate_stb(stb)
MinRK
protect IPython from bad custom exception handlers...
r4991 except:
# clear custom handler immediately
self.set_custom_exc((), None)
Matthias BUSSONNIER
use print function in module with `print >>`
r7817 print("Custom TB Handler failed, unregistering", file=io.stderr)
MinRK
protect IPython from bad custom exception handlers...
r4991 # show the exception in handler first
stb = self.InteractiveTB.structured_traceback(*sys.exc_info())
Matthias BUSSONNIER
use print function in module with `print >>`
r7817 print(self.InteractiveTB.stb2text(stb), file=io.stdout)
print("The original exception:", file=io.stdout)
MinRK
protect against bad return type of CustomTB...
r4999 stb = self.InteractiveTB.structured_traceback(
(etype,value,tb), tb_offset=tb_offset
)
return stb
MinRK
protect IPython from bad custom exception handlers...
r4991
self.CustomTB = types.MethodType(wrapped,self)
Ville M. Vainio
crlf -> lf
r1032 self.custom_exceptions = exc_tuple
Brian Granger
More re-organization of InteractiveShell.
r2242 def excepthook(self, etype, value, tb):
"""One more defense for GUI apps that call sys.excepthook.
Ville M. Vainio
crlf -> lf
r1032
Brian Granger
More re-organization of InteractiveShell.
r2242 GUI frameworks like wxPython trap exceptions and call
sys.excepthook themselves. I guess this is a feature that
enables them to keep running after exceptions that would
otherwise kill their mainloop. This is a bother for IPython
which excepts to catch all of the program exceptions with a try:
except: statement.
Ville M. Vainio
crlf -> lf
r1032
Brian Granger
More re-organization of InteractiveShell.
r2242 Normally, IPython sets sys.excepthook to a CrashHandler instance, so if
any app directly invokes sys.excepthook, it will look to the user like
IPython crashed. In order to work around this, we can disable the
CrashHandler and replace it with this excepthook instead, which prints a
regular traceback using our InteractiveTB. In this fashion, apps which
call sys.excepthook will generate a regular-looking exception from
IPython, and the CrashHandler will only be triggered by real IPython
crashes.
Ville M. Vainio
crlf -> lf
r1032
Brian Granger
More re-organization of InteractiveShell.
r2242 This hook should be used sparingly, only in places which are not likely
to be true IPython errors.
"""
Justyna Ilczuk
i1673 implementation of py3 proper error handling...
r17157 self.showtraceback((etype, value, tb), tb_offset=0)
Ville M. Vainio
crlf -> lf
r1032
MinRK
move exc_info extraction to Shell._get_exc_info...
r6109 def _get_exc_info(self, exc_tuple=None):
"""get exc_info from a given tuple, sys.exc_info() or sys.last_type etc.
Ensures sys.last_type,value,traceback hold the exc_info we found,
from whichever source.
raises ValueError if none of these contain any information
"""
if exc_tuple is None:
etype, value, tb = sys.exc_info()
else:
etype, value, tb = exc_tuple
if etype is None:
if hasattr(sys, 'last_type'):
etype, value, tb = sys.last_type, sys.last_value, \
sys.last_traceback
if etype is None:
raise ValueError("No exception to find")
# Now store the exception info in sys.last_type etc.
# WARNING: these variables are somewhat deprecated and not
# necessarily safe to use in a threaded environment, but tools
# like pdb depend on their existence, so let's set them. If we
# find problems in the field, we'll need to revisit their use.
sys.last_type = etype
sys.last_value = value
sys.last_traceback = tb
return etype, value, tb
MinRK
add InteractiveShell.show_usage_error...
r11466 def show_usage_error(self, exc):
"""Show a short message for UsageErrors
These are special exceptions that shouldn't show a traceback.
"""
self.write_err("UsageError: %s" % exc)
Justyna Ilczuk
i1673 implementation of py3 proper error handling...
r17157 def showtraceback(self, exc_tuple=None, filename=None, tb_offset=None,
Fernando Perez
Lots of work on exception handling, including tests for traceback printing....
r2440 exception_only=False):
Brian Granger
More re-organization of InteractiveShell.
r2242 """Display the exception that just occurred.
Ville M. Vainio
crlf -> lf
r1032
Brian Granger
More re-organization of InteractiveShell.
r2242 If nothing is known about the exception, this is the method which
should be used throughout the code for presenting user tracebacks,
rather than directly invoking the InteractiveTB object.
Ville M. Vainio
crlf -> lf
r1032
Brian Granger
More re-organization of InteractiveShell.
r2242 A specific showsyntaxerror() also exists, but this method can take
care of calling it if needed, so unless you are explicitly catching a
SyntaxError exception, don't try to analyze the stack manually and
simply call this method."""
Bernardo B. Marques
remove all trailling spaces
r4872
Ville M. Vainio
crlf -> lf
r1032 try:
MinRK
move exc_info extraction to Shell._get_exc_info...
r6109 try:
etype, value, tb = self._get_exc_info(exc_tuple)
except ValueError:
self.write_err('No traceback available to show.\n')
return
MinRK
move import RemoteError after get_exc_info...
r7563
Thomas Kluyver
Make IndentationErrors display like other SyntaxErrors...
r8417 if issubclass(etype, SyntaxError):
Fernando Perez
Lots of work on exception handling, including tests for traceback printing....
r2440 # Though this won't be called by syntax errors in the input
Thomas Kluyver
Fix for looking up print function in Python 3.
r4741 # line, there may be SyntaxError cases with imported code.
Brian Granger
More re-organization of InteractiveShell.
r2242 self.showsyntaxerror(filename)
elif etype is UsageError:
MinRK
add InteractiveShell.show_usage_error...
r11466 self.show_usage_error(value)
Brian Granger
More re-organization of InteractiveShell.
r2242 else:
Thomas Kluyver
Remove check for custom_exceptions from showtraceback; it's checked in run_code.
r7109 if exception_only:
stb = ['An exception has occurred, use %tb to see '
'the full traceback.\n']
stb.extend(self.InteractiveTB.get_exception_only(etype,
value))
Brian Granger
More re-organization of InteractiveShell.
r2242 else:
Thomas Kluyver
Allow custom tracebacks for exception types with a _render_traceback_() method.
r8082 try:
# Exception classes can customise their traceback - we
# use this in IPython.parallel for exceptions occurring
# in the engines. This should return a list of strings.
stb = value._render_traceback_()
except Exception:
stb = self.InteractiveTB.structured_traceback(etype,
Thomas Kluyver
Remove check for custom_exceptions from showtraceback; it's checked in run_code.
r7109 value, tb, tb_offset=tb_offset)
self._showtraceback(etype, value, stb)
if self.call_pdb:
# drop into debugger
self.debugger(force=True)
return
Fernando Perez
Improvements to exception handling to transport structured tracebacks....
r2838
# Actually show the traceback
self._showtraceback(etype, value, stb)
Bernardo B. Marques
remove all trailling spaces
r4872
Brian Granger
More re-organization of InteractiveShell.
r2242 except KeyboardInterrupt:
Fernando Perez
Improvements to exception handling to transport structured tracebacks....
r2838 self.write_err("\nKeyboardInterrupt\n")
def _showtraceback(self, etype, evalue, stb):
"""Actually show a traceback.
Subclasses may override this method to put the traceback on a different
place, like a side channel.
"""
Matthias BUSSONNIER
use print function in module with `print >>`
r7817 print(self.InteractiveTB.stb2text(stb), file=io.stdout)
Brian Granger
Continuing a massive refactor of everything.
r2205
Brian Granger
More re-organization of InteractiveShell.
r2242 def showsyntaxerror(self, filename=None):
"""Display the syntax error that just occurred.
Brian Granger
Continuing a massive refactor of everything.
r2205
Brian Granger
More re-organization of InteractiveShell.
r2242 This doesn't display a stack trace because there isn't one.
Brian Granger
Massive, crazy refactoring of everything....
r2202
Brian Granger
More re-organization of InteractiveShell.
r2242 If a filename is given, it is stuffed in the exception instead
of what was there before (because Python's parser always uses
"<string>" when reading from a string).
"""
MinRK
move exc_info extraction to Shell._get_exc_info...
r6109 etype, value, last_traceback = self._get_exc_info()
Bernardo B. Marques
remove all trailling spaces
r4872
Thomas Kluyver
Make IndentationErrors display like other SyntaxErrors...
r8417 if filename and issubclass(etype, SyntaxError):
Brian Granger
More re-organization of InteractiveShell.
r2242 try:
Thomas Kluyver
Fix display of SyntaxError in Python 3....
r5827 value.filename = filename
Brian Granger
More re-organization of InteractiveShell.
r2242 except:
# Not the format we expect; leave it alone
pass
Thomas Kluyver
Fix display of SyntaxError in Python 3....
r5827
Fernando Perez
Improvements to exception handling to transport structured tracebacks....
r2838 stb = self.SyntaxTB.structured_traceback(etype, value, [])
self._showtraceback(etype, value, stb)
Bernardo B. Marques
remove all trailling spaces
r4872
Thomas Kluyver
Only tell the user about %paste in the terminal shell.
r4226 # This is overridden in TerminalInteractiveShell to show a message about
# the %paste magic.
Thomas Kluyver
Make showindentationerror a separate function, so it can have its own docstring.
r4227 def showindentationerror(self):
"""Called by run_cell when there's an IndentationError in code entered
at the prompt.
Bernardo B. Marques
remove all trailling spaces
r4872
Thomas Kluyver
Make showindentationerror a separate function, so it can have its own docstring.
r4227 This is overridden in TerminalInteractiveShell to show a message about
the %paste magic."""
self.showsyntaxerror()
Ville M. Vainio
crlf -> lf
r1032
Brian Granger
More re-organization of InteractiveShell.
r2242 #-------------------------------------------------------------------------
# Things related to readline
#-------------------------------------------------------------------------
def init_readline(self):
"""Command history completion/saving/reloading."""
Fernando Perez
Better handling of no-readline.
r2377 if self.readline_use:
import IPython.utils.rlineimpl as readline
Brian Granger
Second attempt to fix init_io readline test.
r2808
Brian Granger
More re-organization of InteractiveShell.
r2242 self.rl_next_input = None
self.rl_do_indent = False
Fernando Perez
Better handling of no-readline.
r2377 if not self.readline_use or not readline.have_readline:
self.has_readline = False
Brian Granger
More re-organization of InteractiveShell.
r2242 self.readline = None
Fernando Perez
Better handling of no-readline.
r2377 # Set a number of methods that depend on readline to be no-op
epatters
BUG: Don't use readline in the ZMQShell....
r4816 self.readline_no_record = no_op_context
Fernando Perez
Simplify completer handling by isolating readline-specific logic more....
r2952 self.set_readline_completer = no_op
Fernando Perez
Better handling of no-readline.
r2377 self.set_custom_completer = no_op
epatters
BUG: Don't use readline in the ZMQShell....
r4816 if self.readline_use:
warn('Readline services not available or not loaded.')
Brian Granger
More re-organization of InteractiveShell.
r2242 else:
Fernando Perez
Better handling of no-readline.
r2377 self.has_readline = True
self.readline = readline
Brian Granger
More re-organization of InteractiveShell.
r2242 sys.modules['readline'] = readline
Bernardo B. Marques
remove all trailling spaces
r4872
Brian Granger
More re-organization of InteractiveShell.
r2242 # Platform-specific configuration
if os.name == 'nt':
Fernando Perez
Fix bug where atexit operations were only done if readline was present.
r2953 # FIXME - check with Frederick to see if we can harmonize
# naming conventions with pyreadline to avoid this
# platform-dependent check
Brian Granger
More re-organization of InteractiveShell.
r2242 self.readline_startup_hook = readline.set_pre_input_hook
else:
self.readline_startup_hook = readline.set_startup_hook
MinRK
load inputrc after IPython readline config...
r16811 # Readline config order:
# - IPython config (default value)
# - custom inputrc
# - IPython config (user customized)
# load IPython config before inputrc if default
# skip if libedit because parse_and_bind syntax is different
if not self._custom_readline_config and not readline.uses_libedit:
for rlcommand in self.readline_parse_and_bind:
readline.parse_and_bind(rlcommand)
Brian Granger
More re-organization of InteractiveShell.
r2242 # Load user's initrc file (readline config)
# Or if libedit is used, load editrc.
inputrc_name = os.environ.get('INPUTRC')
if inputrc_name is None:
MinRK
allow IPython to run without writable home dir...
r5384 inputrc_name = '.inputrc'
if readline.uses_libedit:
inputrc_name = '.editrc'
inputrc_name = os.path.join(self.home_dir, inputrc_name)
Brian Granger
More re-organization of InteractiveShell.
r2242 if os.path.isfile(inputrc_name):
try:
readline.read_init_file(inputrc_name)
except:
warn('Problems reading readline initialization file <%s>'
% inputrc_name)
MinRK
load inputrc after IPython readline config...
r16811
# load IPython config after inputrc if user has customized
if self._custom_readline_config:
Brian Granger
More re-organization of InteractiveShell.
r2242 for rlcommand in self.readline_parse_and_bind:
readline.parse_and_bind(rlcommand)
# Remove some chars from the delimiters list. If we encounter
# unicode chars, discard them.
Thomas Kluyver
Further Python 3 fixes in core.
r4742 delims = readline.get_completer_delims()
if not py3compat.PY3:
delims = delims.encode("ascii", "ignore")
Thomas Kluyver
Eliminate Str and CStr trait types except in IPython.parallel
r4046 for d in self.readline_remove_delims:
delims = delims.replace(d, "")
Fernando Perez
Reorganization of readline and completion dependent code....
r2956 delims = delims.replace(ESC_MAGIC, '')
Brian Granger
More re-organization of InteractiveShell.
r2242 readline.set_completer_delims(delims)
Thomas Kluyver
Reset readline delimiters after loading rmagic....
r9017 # Store these so we can restore them if something like rpy2 modifies
# them.
self.readline_delims = delims
Brian Granger
More re-organization of InteractiveShell.
r2242 # otherwise we end up with a monster history after a while:
Satrajit Ghosh
History refactored and saved to json file...
r3240 readline.set_history_length(self.history_length)
Bernardo B. Marques
remove all trailling spaces
r4872
Thomas Kluyver
Add context manager to reload readline history when leaving a block.
r3474 self.refill_readline_hist()
self.readline_no_record = ReadlineNoRecord(self)
Brian Granger
More re-organization of InteractiveShell.
r2242
# Configure auto-indent for all platforms
self.set_autoindent(self.autoindent)
Bernardo B. Marques
remove all trailling spaces
r4872
Thomas Kluyver
Add context manager to reload readline history when leaving a block.
r3474 def refill_readline_hist(self):
# Load the last 1000 lines from history
self.readline.clear_history()
stdin_encoding = sys.stdin.encoding or "utf-8"
Thomas Kluyver
Do not push consecutive duplicates when we refill readline history....
r5307 last_cell = u""
Thomas Kluyver
Add context manager to reload readline history when leaving a block.
r3474 for _, _, cell in self.history_manager.get_tail(1000,
include_latest=True):
Thomas Kluyver
Do not push consecutive duplicates when we refill readline history....
r5307 # Ignore blank lines and consecutive duplicates
Thomas Kluyver
Only strip whitespace from cell once when filling readline history.
r5311 cell = cell.rstrip()
if cell and (cell != last_cell):
Thomas Kluyver
Catch errors filling readline history on startup....
r11881 try:
if self.multiline_history:
self.readline.add_history(py3compat.unicode_to_str(cell,
stdin_encoding))
else:
for line in cell.splitlines():
self.readline.add_history(py3compat.unicode_to_str(line,
stdin_encoding))
last_cell = cell
except TypeError:
# The history DB can get corrupted so it returns strings
# containing null bytes, which readline objects to.
continue
Brian Granger
Continuing a massive refactor of everything.
r2205
Thomas Kluyver
Skip doctest that can't possibly work.
r9246 @skip_doctest
Brian Granger
Continuing a massive refactor of everything.
r2205 def set_next_input(self, s):
""" Sets the 'default' input string for the next command line.
Bernardo B. Marques
remove all trailling spaces
r4872
Brian Granger
Continuing a massive refactor of everything.
r2205 Requires readline.
Bernardo B. Marques
remove all trailling spaces
r4872
Thomas Kluyver
Miscellaneous docs fixes
r9244 Example::
Bernardo B. Marques
remove all trailling spaces
r4872
Thomas Kluyver
Miscellaneous docs fixes
r9244 In [1]: _ip.set_next_input("Hello Word")
In [2]: Hello Word_ # cursor is here
Brian Granger
Continuing a massive refactor of everything.
r2205 """
Thomas Kluyver
Fix setting the next input cell at the terminal on Python 3.
r5308 self.rl_next_input = py3compat.cast_bytes_py2(s)
Brian Granger
Continuing a massive refactor of everything.
r2205
Brian Granger
Complete reorganization of InteractiveShell....
r2761 # Maybe move this to the terminal subclass?
Brian Granger
More re-organization of InteractiveShell.
r2242 def pre_readline(self):
"""readline hook to be used at the start of each line.
Ville M. Vainio
crlf -> lf
r1032
Brian Granger
More re-organization of InteractiveShell.
r2242 Currently it handles auto-indent only."""
Ville M. Vainio
crlf -> lf
r1032
Brian Granger
More re-organization of InteractiveShell.
r2242 if self.rl_do_indent:
self.readline.insert_text(self._indent_current_str())
if self.rl_next_input is not None:
self.readline.insert_text(self.rl_next_input)
self.rl_next_input = None
Ville M. Vainio
crlf -> lf
r1032
Brian Granger
More re-organization of InteractiveShell.
r2242 def _indent_current_str(self):
"""return the current level of indentation as a string"""
MinRK
merge interactiveshell.py
r3122 return self.input_splitter.indent_spaces * ' '
Ville M. Vainio
crlf -> lf
r1032
Brian Granger
More re-organization of InteractiveShell.
r2242 #-------------------------------------------------------------------------
Fernando Perez
Reorganization of readline and completion dependent code....
r2956 # Things related to text completion
#-------------------------------------------------------------------------
def init_completer(self):
"""Initialize the completion machinery.
This creates completion machinery that can be used by client code,
either interactively in-process (typically triggered by the readline
library), programatically (such as in test suites) or out-of-prcess
(typically over the network by remote frontends).
"""
from IPython.core.completer import IPCompleter
Fernando Perez
Restored major default completer functionality (cd, import, run)....
r2959 from IPython.core.completerlib import (module_completer,
Paul Ivanov
%reset now takes optional in/out/dhist/array args...
r5965 magic_run_completer, cd_completer, reset_completer)
Bernardo B. Marques
remove all trailling spaces
r4872
MinRK
make Completer.greedy configurable
r4825 self.Completer = IPCompleter(shell=self,
namespace=self.user_ns,
global_namespace=self.user_global_ns,
use_readline=self.has_readline,
MinRK
use `parent=self` throughout IPython...
r11064 parent=self,
MinRK
make Completer.greedy configurable
r4825 )
MinRK
add %config magic for configuring IPython
r5225 self.configurables.append(self.Completer)
Bernardo B. Marques
remove all trailling spaces
r4872
Fernando Perez
Restored major default completer functionality (cd, import, run)....
r2959 # Add custom completers to the basic ones built into IPCompleter
Fernando Perez
Reorganization of readline and completion dependent code....
r2956 sdisp = self.strdispatchers.get('complete_command', StrDispatch())
self.strdispatchers['complete_command'] = sdisp
self.Completer.custom_completers = sdisp
Fernando Perez
Restored major default completer functionality (cd, import, run)....
r2959 self.set_hook('complete_command', module_completer, str_key = 'import')
self.set_hook('complete_command', module_completer, str_key = 'from')
self.set_hook('complete_command', magic_run_completer, str_key = '%run')
self.set_hook('complete_command', cd_completer, str_key = '%cd')
Paul Ivanov
%reset now takes optional in/out/dhist/array args...
r5965 self.set_hook('complete_command', reset_completer, str_key = '%reset')
Fernando Perez
Restored major default completer functionality (cd, import, run)....
r2959
# Only configure readline if we truly are using readline. IPython can
# do tab-completion over the network, in GUIs, etc, where readline
# itself may be absent
Fernando Perez
Reorganization of readline and completion dependent code....
r2956 if self.has_readline:
self.set_readline_completer()
def complete(self, text, line=None, cursor_pos=None):
"""Return the completed text and a list of completions.
Parameters
----------
text : string
A string of text to be completed on. It can be given as empty and
instead a line/position pair are given. In this case, the
completer itself will split the line like readline does.
line : string, optional
The complete line that text is part of.
cursor_pos : int, optional
The position of the cursor on the input line.
Returns
-------
text : string
The actual text that was completed.
matches : list
A sorted list with all possible completions.
The optional arguments allow the completion to take more context into
account, and are part of the low-level completion API.
Bernardo B. Marques
remove all trailling spaces
r4872
Fernando Perez
Reorganization of readline and completion dependent code....
r2956 This is a wrapper around the completion mechanism, similar to what
readline does at the command line when the TAB key is hit. By
exposing it as a method, it can be used by other non-readline
environments (such as GUIs) for text completion.
Simple usage example:
In [1]: x = 'hello'
In [2]: _ip.complete('x.l')
Out[2]: ('x.l', ['x.ljust', 'x.lower', 'x.lstrip'])
"""
# Inject names into __builtin__ so we can complete on the added names.
with self.builtin_trap:
return self.Completer.complete(text, line, cursor_pos)
def set_custom_completer(self, completer, pos=0):
"""Adds a new custom completer function.
The position argument (defaults to 0) is the index in the completers
list where you want the completer to be inserted."""
Thomas Kluyver
Clean up deprecated code: exceptions.Exception, new.instancemethod.
r3158 newcomp = types.MethodType(completer,self.Completer)
Fernando Perez
Reorganization of readline and completion dependent code....
r2956 self.Completer.matchers.insert(pos,newcomp)
def set_readline_completer(self):
"""Reset readline's completer to be our own."""
self.readline.set_completer(self.Completer.rlcomplete)
def set_completer_frame(self, frame=None):
"""Set the frame of the completer."""
if frame:
self.Completer.namespace = frame.f_locals
self.Completer.global_namespace = frame.f_globals
else:
self.Completer.namespace = self.user_ns
self.Completer.global_namespace = self.user_global_ns
#-------------------------------------------------------------------------
Brian Granger
More re-organization of InteractiveShell.
r2242 # Things related to magics
#-------------------------------------------------------------------------
Ville M. Vainio
crlf -> lf
r1032
Brian Granger
More re-organization of InteractiveShell.
r2242 def init_magics(self):
Fernando Perez
Create new core.magics package and start populating with history.
r6956 from IPython.core import magics as m
Fernando Perez
Add proper initialization of magics to main shell instance....
r6923 self.magics_manager = magic.MagicsManager(shell=self,
MinRK
use `parent=self` throughout IPython...
r11064 parent=self,
Fernando Perez
Move UserMagics to core.magics
r6957 user_magics=m.UserMagics(self))
Fernando Perez
Add proper initialization of magics to main shell instance....
r6923 self.configurables.append(self.magics_manager)
Fernando Perez
Settle on cleaner API for magic registration....
r6936 # Expose as public API from the magics manager
Fernando Perez
Clean up magic registration api and make it public.
r6933 self.register_magics = self.magics_manager.register
Fernando Perez
Update api names as per review discussion.
r6954 self.define_magic = self.magics_manager.define_magic
Fernando Perez
Clean up magic registration api and make it public.
r6933
Fernando Perez
Create core.magics.auto according to new API.
r6964 self.register_magics(m.AutoMagics, m.BasicMagics, m.CodeMagics,
MinRK
add %%javascript, %%svg, and %%latex display magics...
r7946 m.ConfigMagics, m.DeprecatedMagics, m.DisplayMagics, m.ExecutionMagics,
Fernando Perez
Create core.magics.extension according to new API.
r6967 m.ExtensionMagics, m.HistoryMagics, m.LoggingMagics,
MinRK
add script magics...
r7299 m.NamespaceMagics, m.OSMagics, m.PylabMagics, m.ScriptMagics,
)
Fernando Perez
Add proper initialization of magics to main shell instance....
r6923
Bradley M. Froehle
Use magic alias api to register magic aliases.
r7933 # Register Magic Aliases
mman = self.magics_manager
MinRK
clarify FIXME comment for magics aliases
r10655 # FIXME: magic aliases should be defined by the Magics classes
# or in MagicsManager, not here
Bradley M. Froehle
Use magic alias api to register magic aliases.
r7933 mman.register_alias('ed', 'edit')
mman.register_alias('hist', 'history')
mman.register_alias('rep', 'recall')
MinRK
add uppercase aliases to html, svg cell magics...
r10000 mman.register_alias('SVG', 'svg', 'cell')
mman.register_alias('HTML', 'html', 'cell')
MinRK
make that writefile
r10634 mman.register_alias('file', 'writefile', 'cell')
Bradley M. Froehle
Use magic alias api to register magic aliases.
r7933
Brian Granger
Refactor of prompts and the displayhook....
r2781 # FIXME: Move the color initialization to the DisplayHook, which
# should be split into a prompt manager and displayhook. We probably
# even need a centralize colors management object.
Fernando Perez
Fix %lsmagic
r6925 self.magic('colors %s' % self.colors)
Thomas Kluyver
Declare ip.register_magic_function at class level so that it is included in docs
r12297
# Defined here so that it's included in the documentation
@functools.wraps(magic.MagicsManager.register_function)
def register_magic_function(self, func, magic_kind='line', magic_name=None):
self.magics_manager.register_function(func,
magic_kind=magic_kind, magic_name=magic_name)
Ville M. Vainio
crlf -> lf
r1032
Fernando Perez
Rename a few methods as per review, also complete some docstrings.
r7003 def run_line_magic(self, magic_name, line):
Fernando Perez
First working version of cell magic support.
r6953 """Execute the given line magic.
Fernando Perez
Fix https://bugs.launchpad.net/ipython/+bug/239054...
r1859
Fernando Perez
First working version of cell magic support.
r6953 Parameters
----------
magic_name : str
Name of the desired magic function, without '%' prefix.
Fernando Perez
Fix https://bugs.launchpad.net/ipython/+bug/239054...
r1859
Fernando Perez
First working version of cell magic support.
r6953 line : str
The rest of the input line as a single string.
Brian Granger
More re-organization of InteractiveShell.
r2242 """
Fernando Perez
First working version of cell magic support.
r6953 fn = self.find_line_magic(magic_name)
Brian Granger
More re-organization of InteractiveShell.
r2242 if fn is None:
Fernando Perez
First working version of cell magics in inputsplitter in line mode....
r6978 cm = self.find_cell_magic(magic_name)
Fernando Perez
Improve error messages for line/cell magics.
r6983 etpl = "Line magic function `%%%s` not found%s."
extra = '' if cm is None else (' (But cell magic `%%%%%s` exists, '
'did you mean that instead?)' % magic_name )
error(etpl % (magic_name, extra))
Brian Granger
More re-organization of InteractiveShell.
r2242 else:
Fernando Perez
First working version of cell magic support.
r6953 # Note: this is the distance in the stack to the user's frame.
# This will need to be updated if the internal calling logic gets
# refactored, or else we'll be expanding the wrong variables.
stack_depth = 2
magic_arg_s = self.var_expand(line, stack_depth)
Fernando Perez
Simplify logic of passing local scope to magics that need it....
r6907 # Put magic args in a list so we can call with f(*a) syntax
args = [magic_arg_s]
Guy Haskin Fernald
Added functionality to %R and %octave magics so that -i first looks in local...
r8262 kwargs = {}
Thomas Kluyver
Refine implementation, so that local scope is only used if a function needs it.
r3479 # Grab local namespace if we need it:
if getattr(fn, "needs_local_scope", False):
Guy Haskin Fernald
Added functionality to %R and %octave magics so that -i first looks in local...
r8262 kwargs['local_ns'] = sys._getframe(stack_depth).f_locals
Fernando Perez
Make post-execution happen at the cell instead of the block level....
r3732 with self.builtin_trap:
Guy Haskin Fernald
Added functionality to %R and %octave magics so that -i first looks in local...
r8262 result = fn(*args,**kwargs)
Thomas Kluyver
Refine implementation, so that local scope is only used if a function needs it.
r3479 return result
Ville M. Vainio
crlf -> lf
r1032
Fernando Perez
Rename a few methods as per review, also complete some docstrings.
r7003 def run_cell_magic(self, magic_name, line, cell):
Fernando Perez
First working version of cell magic support.
r6953 """Execute the given cell magic.
Fernando Perez
Rename a few methods as per review, also complete some docstrings.
r7003
Parameters
----------
magic_name : str
Name of the desired magic function, without '%' prefix.
line : str
The rest of the first input line as a single string.
cell : str
The body of the cell as a (possibly multiline) string.
Fernando Perez
First working version of cell magic support.
r6953 """
fn = self.find_cell_magic(magic_name)
if fn is None:
Fernando Perez
Improve error messages for line/cell magics.
r6983 lm = self.find_line_magic(magic_name)
MinRK
better UsageError for cell magic with no body...
r10227 etpl = "Cell magic `%%{0}` not found{1}."
Robert Marchman
new style formatting for magic-not-found warning
r9469 extra = '' if lm is None else (' (But line magic `%{0}` exists, '
'did you mean that instead?)'.format(magic_name))
error(etpl.format(magic_name, extra))
Robert Marchman
general empty cell warning
r9466 elif cell == '':
MinRK
better UsageError for cell magic with no body...
r10227 message = '%%{0} is a cell magic, but the cell body is empty.'.format(magic_name)
if self.find_line_magic(magic_name) is not None:
message += ' Did you mean the line magic %{0} (single %)?'.format(magic_name)
raise UsageError(message)
Fernando Perez
First working version of cell magic support.
r6953 else:
# Note: this is the distance in the stack to the user's frame.
# This will need to be updated if the internal calling logic gets
# refactored, or else we'll be expanding the wrong variables.
stack_depth = 2
magic_arg_s = self.var_expand(line, stack_depth)
with self.builtin_trap:
MinRK
expand line in cell magics...
r7902 result = fn(magic_arg_s, cell)
Fernando Perez
First working version of cell magic support.
r6953 return result
Fernando Perez
Add proper initialization of magics to main shell instance....
r6923 def find_line_magic(self, magic_name):
Fernando Perez
First working version of cell magic support.
r6953 """Find and return a line magic by name.
Returns None if the magic isn't found."""
Fernando Perez
Add proper initialization of magics to main shell instance....
r6923 return self.magics_manager.magics['line'].get(magic_name)
def find_cell_magic(self, magic_name):
Fernando Perez
First working version of cell magic support.
r6953 """Find and return a cell magic by name.
Returns None if the magic isn't found."""
Fernando Perez
Add proper initialization of magics to main shell instance....
r6923 return self.magics_manager.magics['cell'].get(magic_name)
Fernando Perez
Remove next_input nonsense in magic calls (but keep functionality).
r6974 def find_magic(self, magic_name, magic_kind='line'):
Fernando Perez
First working version of cell magic support.
r6953 """Find and return a magic of the given type by name.
Returns None if the magic isn't found."""
Fernando Perez
Remove next_input nonsense in magic calls (but keep functionality).
r6974 return self.magics_manager.magics[magic_kind].get(magic_name)
Fernando Perez
First full decoupling of magics into a standalone object.
r6906
Fernando Perez
Remove next_input nonsense in magic calls (but keep functionality).
r6974 def magic(self, arg_s):
Fernando Perez
Rename a few methods as per review, also complete some docstrings.
r7003 """DEPRECATED. Use run_line_magic() instead.
Fernando Perez
First working version of cell magic support.
r6953
Call a magic function by name.
Input: a string containing the name of the magic function to call and
any additional arguments to be passed to the magic.
magic('name -opt foo bar') is equivalent to typing at the ipython
prompt:
In[1]: %name -opt foo bar
To call a magic without arguments, simply use magic('name').
This provides a proper Python function to call IPython's magics in any
valid Python code you can type at the interpreter, including loops and
compound statements.
"""
# TODO: should we issue a loud deprecation warning here?
magic_name, _, magic_arg_s = arg_s.partition(' ')
magic_name = magic_name.lstrip(prefilter.ESC_MAGIC)
Fernando Perez
Rename a few methods as per review, also complete some docstrings.
r7003 return self.run_line_magic(magic_name, magic_arg_s)
Fernando Perez
First working version of cell magic support.
r6953
Brian Granger
More re-organization of InteractiveShell.
r2242 #-------------------------------------------------------------------------
# Things related to macros
#-------------------------------------------------------------------------
Ville M. Vainio
crlf -> lf
r1032
Brian Granger
More re-organization of InteractiveShell.
r2242 def define_macro(self, name, themacro):
"""Define a new macro
Fernando Perez
Fix bug: https://bugs.launchpad.net/ipython/+bug/269966...
r1856
Brian Granger
More re-organization of InteractiveShell.
r2242 Parameters
----------
name : str
The name of the macro.
themacro : str or Macro
Bernardo B. Marques
remove all trailling spaces
r4872 The action to do upon invoking the macro. If a string, a new
Brian Granger
More re-organization of InteractiveShell.
r2242 Macro object is created by passing the string to it.
Fernando Perez
Work again on bug 269966....
r1916 """
Bernardo B. Marques
remove all trailling spaces
r4872
Brian Granger
More re-organization of InteractiveShell.
r2242 from IPython.core import macro
Fernando Perez
Work again on bug 269966....
r1916
Thomas Kluyver
Replace references to unicode and basestring
r13353 if isinstance(themacro, string_types):
Brian Granger
More re-organization of InteractiveShell.
r2242 themacro = macro.Macro(themacro)
if not isinstance(themacro, macro.Macro):
raise ValueError('A macro must be a string or a Macro instance.')
self.user_ns[name] = themacro
Fernando Perez
Fix bug: https://bugs.launchpad.net/ipython/+bug/269966...
r1856
Brian Granger
More re-organization of InteractiveShell.
r2242 #-------------------------------------------------------------------------
# Things related to the running of system commands
#-------------------------------------------------------------------------
Fernando Perez
Fix bug: https://bugs.launchpad.net/ipython/+bug/269966...
r1856
MinRK
split shell.system into shell.system_raw/system_piped...
r3909 def system_piped(self, cmd):
"""Call the given cmd in a subprocess, piping stdout/err
Fernando Perez
Fix bugs in x=!cmd; we can't use pexpect at all....
r3002
Parameters
----------
cmd : str
MinRK
split shell.system into shell.system_raw/system_piped...
r3909 Command to execute (can not end in '&', as background processes are
not supported. Should not be a command that expects input
other than simple text.
Fernando Perez
Fix bugs in x=!cmd; we can't use pexpect at all....
r3002 """
MinRK
split shell.system into shell.system_raw/system_piped...
r3909 if cmd.rstrip().endswith('&'):
# this is *far* from a rigorous test
# We do not support backgrounding processes because we either use
# pexpect or pipes to read from. Users can always just call
# os.system() or use ip.system=ip.system_raw
# if they really want a background process.
Fernando Perez
Remove shell hook and system_verbose magic....
r2905 raise OSError("Background processes not supported.")
Bernardo B. Marques
remove all trailling spaces
r4872
MinRK
store exit code in user_ns['_exit_code']...
r3910 # we explicitly do NOT return the subprocess status code, because
# a non-None value would trigger :func:`sys.displayhook` calls.
# Instead, we store the exit_code in user_ns.
Thomas Kluyver
Correct stack depth for !system calls...
r7332 self.user_ns['_exit_code'] = system(self.var_expand(cmd, depth=1))
Bernardo B. Marques
remove all trailling spaces
r4872
MinRK
split shell.system into shell.system_raw/system_piped...
r3909 def system_raw(self, cmd):
Théophile Studer
Use default OS shell to run system commands...
r12366 """Call the given cmd in a subprocess using os.system on Windows or
subprocess.call using the system shell on other platforms.
Bernardo B. Marques
remove all trailling spaces
r4872
MinRK
split shell.system into shell.system_raw/system_piped...
r3909 Parameters
----------
cmd : str
Command to execute.
"""
Thomas Kluyver
Correct stack depth for !system calls...
r7332 cmd = self.var_expand(cmd, depth=1)
MinRK
protect system_raw from UNC paths on windows
r5277 # protect os.system from UNC paths on Windows, which it can't handle:
if sys.platform == 'win32':
from IPython.utils._process_win32 import AvoidUNCPath
with AvoidUNCPath() as path:
if path is not None:
cmd = '"pushd %s &&"%s' % (path, cmd)
Jörgen Stenarson
Use unicode_to_str from py3compat
r5313 cmd = py3compat.unicode_to_str(cmd)
MinRK
protect system_raw from UNC paths on windows
r5277 ec = os.system(cmd)
else:
Jörgen Stenarson
Add simple test for non-ascii characters in system_raw call.
r5314 cmd = py3compat.unicode_to_str(cmd)
Théophile Studer
Use default OS shell to run system commands...
r12366 # Call the cmd using the OS shell, instead of the default /bin/sh, if set.
ec = subprocess.call(cmd, shell=True, executable=os.environ.get('SHELL', None))
Thomas Kluyver
Unify exit status from system_raw and system_piped
r12766 # exit code is positive for program failure, or negative for
# terminating signal number.
MinRK
handle error code > 128 in system_raw like system_piped...
r17015
# Interpret ec > 128 as signal
# Some shells (csh, fish) don't follow sh/bash conventions for exit codes
if ec > 128:
ec = -(ec - 128)
MinRK
protect system_raw from UNC paths on windows
r5277
MinRK
store exit code in user_ns['_exit_code']...
r3910 # We explicitly do NOT return the subprocess status code, because
# a non-None value would trigger :func:`sys.displayhook` calls.
# Instead, we store the exit_code in user_ns.
MinRK
protect system_raw from UNC paths on windows
r5277 self.user_ns['_exit_code'] = ec
Bernardo B. Marques
remove all trailling spaces
r4872
MinRK
split shell.system into shell.system_raw/system_piped...
r3909 # use piped system by default, because it is better behaved
system = system_piped
Fernando Perez
Remove shell hook and system_verbose magic....
r2905
Thomas Kluyver
Expose & document depth parameter to ip.getoutput()
r7400 def getoutput(self, cmd, split=True, depth=0):
Fernando Perez
Fix bugs in x=!cmd; we can't use pexpect at all....
r3002 """Get output (possibly including stderr) from a subprocess.
Parameters
----------
cmd : str
Fernando Perez
Add init_environment(), %less, %more, %man and %clear/%cls, in zmq shell....
r3005 Command to execute (can not end in '&', as background processes are
Fernando Perez
Fix bugs in x=!cmd; we can't use pexpect at all....
r3002 not supported.
split : bool, optional
If True, split the output into an IPython SList. Otherwise, an
IPython LSString is returned. These are objects similar to normal
lists and strings, with a few convenience attributes for easier
manipulation of line-based output. You can use '?' on them for
details.
Thomas Kluyver
Expose & document depth parameter to ip.getoutput()
r7400 depth : int, optional
How many frames above the caller are the local variables which should
be expanded in the command string? The default (0) assumes that the
expansion variables are in the stack frame calling this function.
"""
MinRK
split shell.system into shell.system_raw/system_piped...
r3909 if cmd.rstrip().endswith('&'):
# this is *far* from a rigorous test
Fernando Perez
Remove shell hook and system_verbose magic....
r2905 raise OSError("Background processes not supported.")
Thomas Kluyver
Expose & document depth parameter to ip.getoutput()
r7400 out = getoutput(self.var_expand(cmd, depth=depth+1))
Fernando Perez
Fix bugs in x=!cmd; we can't use pexpect at all....
r3002 if split:
out = SList(out.splitlines())
else:
out = LSString(out)
return out
Fernando Perez
Remove shell hook and system_verbose magic....
r2905
Brian Granger
More re-organization of InteractiveShell.
r2242 #-------------------------------------------------------------------------
# Things related to aliases
#-------------------------------------------------------------------------
Brian Granger
More work on componentizing everything....
r2243 def init_alias(self):
MinRK
use `parent=self` throughout IPython...
r11064 self.alias_manager = AliasManager(shell=self, parent=self)
MinRK
add %config magic for configuring IPython
r5225 self.configurables.append(self.alias_manager)
Ville M. Vainio
crlf -> lf
r1032
Brian Granger
More re-organization of InteractiveShell.
r2242 #-------------------------------------------------------------------------
Brian Granger
Cleaning up extensions that used plugins.
r8197 # Things related to extensions
Brian Granger
First draft of refactored Component->Configurable.
r2731 #-------------------------------------------------------------------------
def init_extension_manager(self):
MinRK
use `parent=self` throughout IPython...
r11064 self.extension_manager = ExtensionManager(shell=self, parent=self)
MinRK
add %config magic for configuring IPython
r5225 self.configurables.append(self.extension_manager)
Brian Granger
First draft of refactored Component->Configurable.
r2731
#-------------------------------------------------------------------------
Brian Granger
Final attempt to fix init_io logic.
r2810 # Things related to payloads
#-------------------------------------------------------------------------
def init_payload(self):
MinRK
use `parent=self` throughout IPython...
r11064 self.payload_manager = PayloadManager(parent=self)
MinRK
add %config magic for configuring IPython
r5225 self.configurables.append(self.payload_manager)
MinRK
add Kernel-side widgets
r13188
#-------------------------------------------------------------------------
# Things related to widgets
#-------------------------------------------------------------------------
MinRK
s/init_widgets/init_comms
r13218 def init_comms(self):
MinRK
add Kernel-side widgets
r13188 # not implemented in the base class
pass
Brian Granger
Final attempt to fix init_io logic.
r2810 #-------------------------------------------------------------------------
Brian Granger
Complete reorganization of InteractiveShell....
r2761 # Things related to the prefilter
#-------------------------------------------------------------------------
def init_prefilter(self):
MinRK
use `parent=self` throughout IPython...
r11064 self.prefilter_manager = PrefilterManager(shell=self, parent=self)
MinRK
add %config magic for configuring IPython
r5225 self.configurables.append(self.prefilter_manager)
Brian Granger
Complete reorganization of InteractiveShell....
r2761 # Ultimately this will be refactored in the new interpreter code, but
# for now, we should expose the main prefilter method (there's legacy
# code out there that may rely on this).
self.prefilter = self.prefilter_manager.prefilter_lines
Fernando Perez
Put auto_rewrite functionality into a method so subclasses can do the...
r2951 def auto_rewrite_input(self, cmd):
"""Print to the screen the rewritten form of the user's command.
Fernando Perez
Change wording of example so
r2954 This shows visual feedback by rewriting input lines that cause
automatic calling to kick in, like::
/f x
into::
Fernando Perez
Put auto_rewrite functionality into a method so subclasses can do the...
r2951
Fernando Perez
Change wording of example so
r2954 ------> f(x)
Bernardo B. Marques
remove all trailling spaces
r4872
Fernando Perez
Change wording of example so
r2954 after the user's input prompt. This helps the user understand that the
input line was transformed automatically by IPython.
Fernando Perez
Put auto_rewrite functionality into a method so subclasses can do the...
r2951 """
Thomas Kluyver
Make rewrite prompt non-configurable.
r5555 if not self.show_rewritten_input:
return
Thomas Kluyver
Refactor prompt handling into new prompt manager.
r5495 rw = self.prompt_manager.render('rewrite') + cmd
Fernando Perez
Put auto_rewrite functionality into a method so subclasses can do the...
r2951
try:
# plain ascii works better w/ pyreadline, on some machines, so
# we use it and only print uncolored rewrite if we have unicode
rw = str(rw)
Matthias BUSSONNIER
use print function in module with `print >>`
r7817 print(rw, file=io.stdout)
Fernando Perez
Put auto_rewrite functionality into a method so subclasses can do the...
r2951 except UnicodeEncodeError:
Matthias BUSSONNIER
use print function in module with `print >>`
r7817 print("------> " + cmd)
Bernardo B. Marques
remove all trailling spaces
r4872
Brian Granger
Complete reorganization of InteractiveShell....
r2761 #-------------------------------------------------------------------------
Fernando Perez
Rework messaging to better conform to our spec....
r2926 # Things related to extracting values/expressions from kernel and user_ns
#-------------------------------------------------------------------------
MinRK
user_variables and user_expressions use rich repr API...
r10636 def _user_obj_error(self):
"""return simple exception dict
MinRK
remove user_variables...
r16570 for use in user_expressions
MinRK
user_variables and user_expressions use rich repr API...
r10636 """
etype, evalue, tb = self._get_exc_info()
stb = self.InteractiveTB.get_exception_only(etype, evalue)
exc_info = {
u'status' : 'error',
u'traceback' : stb,
Thomas Kluyver
Replace references to unicode and basestring
r13353 u'ename' : unicode_type(etype.__name__),
MinRK
user_variables and user_expressions use rich repr API...
r10636 u'evalue' : py3compat.safe_unicode(evalue),
}
Fernando Perez
Rework messaging to better conform to our spec....
r2926
MinRK
user_variables and user_expressions use rich repr API...
r10636 return exc_info
def _format_user_obj(self, obj):
"""format a user object to display dict
MinRK
remove user_variables...
r16570 for use in user_expressions
MinRK
user_variables and user_expressions use rich repr API...
r10636 """
data, md = self.display_formatter.format(obj)
value = {
'status' : 'ok',
'data' : data,
'metadata' : md,
}
return value
Fernando Perez
Document the code execution semantics much more carefully....
r3050 def user_expressions(self, expressions):
Fernando Perez
Rework messaging to better conform to our spec....
r2926 """Evaluate a dict of expressions in the user's namespace.
Fernando Perez
Document the code execution semantics much more carefully....
r3050 Parameters
----------
expressions : dict
A dict with string keys and string values. The expression values
should be valid Python expressions, each of which will be evaluated
in the user namespace.
Bernardo B. Marques
remove all trailling spaces
r4872
Fernando Perez
Document the code execution semantics much more carefully....
r3050 Returns
-------
MinRK
user_variables and user_expressions use rich repr API...
r10636 A dict, keyed like the input expressions dict, with the rich mime-typed
display_data of each value.
Fernando Perez
Rework messaging to better conform to our spec....
r2926 """
out = {}
user_ns = self.user_ns
global_ns = self.user_global_ns
MinRK
user_variables and user_expressions use rich repr API...
r10636
Thomas Kluyver
Fix references to dict.iteritems and dict.itervalues
r13361 for key, expr in iteritems(expressions):
Fernando Perez
Rework messaging to better conform to our spec....
r2926 try:
MinRK
user_variables and user_expressions use rich repr API...
r10636 value = self._format_user_obj(eval(expr, global_ns, user_ns))
Fernando Perez
Rework messaging to better conform to our spec....
r2926 except:
MinRK
user_variables and user_expressions use rich repr API...
r10636 value = self._user_obj_error()
Fernando Perez
Rework messaging to better conform to our spec....
r2926 out[key] = value
return out
#-------------------------------------------------------------------------
Brian Granger
More re-organization of InteractiveShell.
r2242 # Things related to the running of code
#-------------------------------------------------------------------------
Ville M. Vainio
crlf -> lf
r1032
Brian Granger
More re-organization of InteractiveShell.
r2242 def ex(self, cmd):
"""Execute a normal python statement in user namespace."""
Fernando Perez
Make post-execution happen at the cell instead of the block level....
r3732 with self.builtin_trap:
Thomas Kluyver
Fix exec statements for Py 3...
r13350 exec(cmd, self.user_global_ns, self.user_ns)
Ville M. Vainio
crlf -> lf
r1032
Brian Granger
More re-organization of InteractiveShell.
r2242 def ev(self, expr):
"""Evaluate python expression expr in user namespace.
Ville M. Vainio
crlf -> lf
r1032
Brian Granger
More re-organization of InteractiveShell.
r2242 Returns the result of evaluation
"""
Fernando Perez
Make post-execution happen at the cell instead of the block level....
r3732 with self.builtin_trap:
Brian Granger
More re-organization of InteractiveShell.
r2242 return eval(expr, self.user_global_ns, self.user_ns)
Ville M. Vainio
crlf -> lf
r1032
Brian Granger
Work on startup related things....
r2252 def safe_execfile(self, fname, *where, **kw):
Brian Granger
More re-organization of InteractiveShell.
r2242 """A safe version of the builtin execfile().
Ville M. Vainio
crlf -> lf
r1032
Brian Granger
Work on startup related things....
r2252 This version will never throw an exception, but instead print
helpful error messages to the screen. This only works on pure
Python files with the .py extension.
Brian Granger
Continuing a massive refactor of everything.
r2205
Brian Granger
Work on startup related things....
r2252 Parameters
----------
fname : string
The name of the file to be executed.
where : tuple
Brian Granger
More re-organization of InteractiveShell.
r2242 One or two namespaces, passed to execfile() as (globals,locals).
If only one is given, it is passed as both.
Brian Granger
Work on startup related things....
r2252 exit_ignore : bool (False)
Fernando Perez
Lots of work on exception handling, including tests for traceback printing....
r2440 If True, then silence SystemExit for non-zero status (it is always
silenced for zero status, as it is so common).
Jörgen Stenarson
Adding test for safe_execfile call with non-ascii path
r5094 raise_exceptions : bool (False)
If True raise exceptions everywhere. Meant for testing.
Brian Granger
Work on startup related things....
r2252 """
kw.setdefault('exit_ignore', False)
Jörgen Stenarson
Adding test for safe_execfile call with non-ascii path
r5094 kw.setdefault('raise_exceptions', False)
Ville M. Vainio
crlf -> lf
r1032
Brian Granger
Work on startup related things....
r2252 fname = os.path.abspath(os.path.expanduser(fname))
Ville M. Vainio
crlf -> lf
r1032
Brian Granger
Work on startup related things....
r2252 # Make sure we can open the file
try:
with open(fname) as thefile:
pass
except:
warn('Could not open file <%s> for safe execution.' % fname)
return
Brian Granger
Continuing a massive refactor of everything.
r2205
Brian Granger
More re-organization of InteractiveShell.
r2242 # Find things also in current directory. This is needed to mimic the
# behavior of running a script from the system command line, where
# Python inserts the script's directory into sys.path
Brian Granger
Work on startup related things....
r2252 dname = os.path.dirname(fname)
Brian Granger
More re-organization of InteractiveShell.
r2242
Brian Granger
Work on startup related things....
r2252 with prepended_to_syspath(dname):
Brian Granger
More re-organization of InteractiveShell.
r2242 try:
Thomas Kluyver
Start using py3compat module.
r4731 py3compat.execfile(fname,*where)
Matthias BUSSONNIER
conform to pep 3110...
r7787 except SystemExit as status:
Fernando Perez
Lots of work on exception handling, including tests for traceback printing....
r2440 # If the call was made with 0 or None exit status (sys.exit(0)
# or sys.exit() ), don't bother showing a traceback, as both of
# these are considered normal by the OS:
# > python -c'import sys;sys.exit(0)'; echo $?
# 0
# > python -c'import sys;sys.exit()'; echo $?
# 0
# For other exit status, we show the exception unless
# explicitly silenced, but only in short form.
Jörgen Stenarson
Adding test for safe_execfile call with non-ascii path
r5094 if kw['raise_exceptions']:
raise
Bradley M. Froehle
safe_run_module: Ignore SystemExit codes 0 and None.
r9679 if status.code and not kw['exit_ignore']:
Fernando Perez
Lots of work on exception handling, including tests for traceback printing....
r2440 self.showtraceback(exception_only=True)
Brian Granger
More re-organization of InteractiveShell.
r2242 except:
Jörgen Stenarson
Adding test for safe_execfile call with non-ascii path
r5094 if kw['raise_exceptions']:
raise
MinRK
fix tb_offset when running a file...
r14730 # tb offset is 2 because we wrap execfile
self.showtraceback(tb_offset=2)
Brian Granger
More re-organization of InteractiveShell.
r2242
Brian Granger
Work on startup related things....
r2252 def safe_execfile_ipy(self, fname):
MinRK
support notebooks in %run...
r13644 """Like safe_execfile, but for .ipy or .ipynb files with IPython syntax.
Brian Granger
Work on startup related things....
r2252
Parameters
----------
fname : str
The name of the file to execute. The filename must have a
MinRK
support notebooks in %run...
r13644 .ipy or .ipynb extension.
Brian Granger
Work on startup related things....
r2252 """
fname = os.path.abspath(os.path.expanduser(fname))
# Make sure we can open the file
try:
with open(fname) as thefile:
pass
except:
warn('Could not open file <%s> for safe execution.' % fname)
return
# Find things also in current directory. This is needed to mimic the
# behavior of running a script from the system command line, where
# Python inserts the script's directory into sys.path
dname = os.path.dirname(fname)
MinRK
support notebooks in %run...
r13644
def get_cells():
"""generator for sequence of code blocks to run"""
if fname.endswith('.ipynb'):
from IPython.nbformat import current
with open(fname) as f:
nb = current.read(f, 'json')
if not nb.worksheets:
return
for cell in nb.worksheets[0].cells:
damianavila
Fix nbrun in notebooks with non-code cells.
r13747 if cell.cell_type == 'code':
yield cell.input
MinRK
support notebooks in %run...
r13644 else:
with open(fname) as f:
yield f.read()
Brian Granger
Work on startup related things....
r2252
with prepended_to_syspath(dname):
try:
MinRK
support notebooks in %run...
r13644 for cell in get_cells():
MinRK
merge interactiveshell.py
r3122 # self.run_cell currently captures all exceptions
# raised in user code. It would be nice if there were
MinRK
support notebooks in %run...
r13644 # versions of run_cell that did raise, so
Brian Granger
Work on startup related things....
r2252 # we could catch the errors.
MinRK
run cells with `silent=True` in `%run nb.ipynb`...
r16554 self.run_cell(cell, silent=True, shell_futures=False)
Brian Granger
Work on startup related things....
r2252 except:
self.showtraceback()
warn('Unknown failure executing file: <%s>' % fname)
Bernardo B. Marques
remove all trailling spaces
r4872
Bradley M. Froehle
Add '-m mod : run library module as a script' option....
r6029 def safe_run_module(self, mod_name, where):
"""A safe version of runpy.run_module().
This version will never throw an exception, but instead print
helpful error messages to the screen.
Bradley M. Froehle
safe_run_module: Ignore SystemExit codes 0 and None.
r9679 `SystemExit` exceptions with status code 0 or None are ignored.
Bradley M. Froehle
Add '-m mod : run library module as a script' option....
r6029 Parameters
----------
mod_name : string
The name of the module to be executed.
where : dict
The globals namespace.
"""
try:
Bradley M. Froehle
safe_run_module: Ignore SystemExit codes 0 and None.
r9679 try:
where.update(
runpy.run_module(str(mod_name), run_name="__main__",
alter_sys=True)
)
except SystemExit as status:
if status.code:
raise
Bradley M. Froehle
Add '-m mod : run library module as a script' option....
r6029 except:
self.showtraceback()
warn('Unknown failure executing module: <%s>' % mod_name)
Fernando Perez
Rename a few methods as per review, also complete some docstrings.
r7003 def _run_cached_cell_magic(self, magic_name, line):
Fernando Perez
First working version of cell magics in inputsplitter in line mode....
r6978 """Special method to call a cell magic with the data stored in self.
"""
Fernando Perez
First implementation of cell magics that goes via inputsplitter....
r6976 cell = self._current_cell_magic_body
self._current_cell_magic_body = None
Fernando Perez
Rename a few methods as per review, also complete some docstrings.
r7003 return self.run_cell_magic(magic_name, line, cell)
Fernando Perez
First implementation of cell magics that goes via inputsplitter....
r6976
Thomas Kluyver
Add shell_futures parameter to run_cell to allow running code without sharing __future__ imports.
r9081 def run_cell(self, raw_cell, store_history=False, silent=False, shell_futures=True):
Thomas Kluyver
Add methods to run an IPython cell based on AST nodes. Have done basic testing manually.
r3527 """Run a complete IPython cell.
Bernardo B. Marques
remove all trailling spaces
r4872
Thomas Kluyver
Add methods to run an IPython cell based on AST nodes. Have done basic testing manually.
r3527 Parameters
----------
Thomas Kluyver
Fix bug with magic names in multi-line strings. run_cell now uses inputsplitter for static transformations.
r3709 raw_cell : str
Thomas Kluyver
Add methods to run an IPython cell based on AST nodes. Have done basic testing manually.
r3527 The code (including IPython code such as %magic functions) to run.
store_history : bool
If True, the raw and translated cell will be stored in IPython's
history. For user code calling back into IPython's machinery, this
should be set to False.
MinRK
add silent kwarg to run_cell...
r6802 silent : bool
Jason Grout
Fix docs to clearly indicate relationship between store_history and silent execute message parameters.
r7999 If True, avoid side-effects, such as implicit displayhooks and
MinRK
add silent kwarg to run_cell...
r6802 and logging. silent=True forces store_history=False.
Thomas Kluyver
Add shell_futures parameter to run_cell to allow running code without sharing __future__ imports.
r9081 shell_futures : bool
If True, the code will share future statements with the interactive
shell. It will both be affected by previous __future__ imports, and
any __future__ imports in the code will affect the shell. If False,
__future__ imports are not shared in either direction.
Thomas Kluyver
Add methods to run an IPython cell based on AST nodes. Have done basic testing manually.
r3527 """
Thomas Kluyver
Tweak empty cell test.
r3710 if (not raw_cell) or raw_cell.isspace():
Thomas Kluyver
Don't increment execution_count on empty cells. +test.
r3706 return
MinRK
add silent kwarg to run_cell...
r6802
if silent:
store_history = False
MinRK
rollback UsageError for cell magic mid-cell...
r11467
Thomas Kluyver
Rename callbacks -> events (mostly), fire -> trigger
r15605 self.events.trigger('pre_execute')
Thomas Kluyver
Start of new callback system
r15597 if not silent:
Thomas Kluyver
Rename pre/post_execute_explicit events to pre/post_run_cell
r15607 self.events.trigger('pre_run_cell')
Thomas Kluyver
Start of new callback system
r15597
Thomas Kluyver
Add comment and remove line as suggested by @fperez
r14989 # If any of our input transformation (input_transformer_manager or
# prefilter_manager) raises an exception, we store it in this variable
# so that we can display the error after logging the input and storing
# it in the history.
Thomas Kluyver
Refactor run_cell for clarity.
r13526 preprocessing_exc_tuple = None
Volker Braun
Also catch SyntaxErrors from InputTransformers in run_cell()...
r13525 try:
Thomas Kluyver
Refactor run_cell for clarity.
r13526 # Static input transformations
Thomas Kluyver
Simplify IPythonInputSplitter API
r13912 cell = self.input_transformer_manager.transform_cell(raw_cell)
Volker Braun
Also catch SyntaxErrors from InputTransformers in run_cell()...
r13525 except SyntaxError:
Thomas Kluyver
Refactor run_cell for clarity.
r13526 preprocessing_exc_tuple = sys.exc_info()
cell = raw_cell # cell has to exist so it can be stored/logged
else:
if len(cell.splitlines()) == 1:
# Dynamic transformations - only applied for single line commands
with self.builtin_trap:
try:
# use prefilter_lines to handle trailing newlines
# restore trailing newline for ast.parse
cell = self.prefilter_manager.prefilter_lines(cell) + '\n'
except Exception:
# don't allow prefilter errors to crash IPython
preprocessing_exc_tuple = sys.exc_info()
# Store raw and processed history
if store_history:
self.history_manager.store_inputs(self.execution_count,
cell, raw_cell)
if not silent:
self.logger.log(cell, raw_cell)
# Display the exception if input processing failed.
if preprocessing_exc_tuple is not None:
self.showtraceback(preprocessing_exc_tuple)
if store_history:
self.execution_count += 1
return
MinRK
rollback UsageError for cell magic mid-cell...
r11467
Thomas Kluyver
Add shell_futures parameter to run_cell to allow running code without sharing __future__ imports.
r9081 # Our own compiler remembers the __future__ environment. If we want to
# run code with a separate __future__ environment, use the default
# compiler
Thomas Kluyver
Better support compiling cells with separate __future__ environments
r9140 compiler = self.compile if shell_futures else CachingCompiler()
Bernardo B. Marques
remove all trailling spaces
r4872
Thomas Kluyver
Add methods to run an IPython cell based on AST nodes. Have done basic testing manually.
r3527 with self.builtin_trap:
Thomas Kluyver
Refactor run_cell for clarity.
r13526 cell_name = self.compile.cache(cell, self.execution_count)
Bernardo B. Marques
remove all trailling spaces
r4872
Thomas Kluyver
Refactor run_cell for clarity.
r13526 with self.display_trap:
# Compile to bytecode
try:
code_ast = compiler.ast_parse(cell, filename=cell_name)
except IndentationError:
self.showindentationerror()
if store_history:
self.execution_count += 1
return None
except (OverflowError, SyntaxError, ValueError, TypeError,
MemoryError):
self.showsyntaxerror()
if store_history:
self.execution_count += 1
return None
# Apply AST transformations
code_ast = self.transform_ast(code_ast)
# Execute the user code
interactivity = "none" if silent else self.ast_node_interactivity
self.run_ast_nodes(code_ast.body, cell_name,
interactivity=interactivity, compiler=compiler)
Thomas Kluyver
Start of new callback system
r15597
Thomas Kluyver
Rename callbacks -> events (mostly), fire -> trigger
r15605 self.events.trigger('post_execute')
Thomas Kluyver
Start of new callback system
r15597 if not silent:
Thomas Kluyver
Rename pre/post_execute_explicit events to pre/post_run_cell
r15607 self.events.trigger('post_run_cell')
Bernardo B. Marques
remove all trailling spaces
r4872
Thomas Kluyver
Add methods to run an IPython cell based on AST nodes. Have done basic testing manually.
r3527 if store_history:
# Write output to the database. Does nothing unless
# history output logging is enabled.
self.history_manager.store_output(self.execution_count)
# Each cell is a *single* input, regardless of how many lines it has
self.execution_count += 1
Thomas Kluyver
Add framework for AST transformations of input code.
r8220
def transform_ast(self, node):
"""Apply the AST transformations from self.ast_transformers
Parameters
----------
node : ast.Node
The root node to be transformed. Typically called with the ast.Module
produced by parsing user input.
Returns
-------
An ast.Node corresponding to the node it was called with. Note that it
may also modify the passed object, so don't rely on references to the
original AST.
"""
for transformer in self.ast_transformers:
try:
node = transformer.visit(node)
except Exception:
Thomas Kluyver
Fix warning message for unregistering AST transformers.
r8222 warn("AST transformer %r threw an error. It will be unregistered." % transformer)
Thomas Kluyver
Add framework for AST transformations of input code.
r8220 self.ast_transformers.remove(transformer)
Thomas Kluyver
Don't call ast.fix_missing_locations unless the AST could have been modified....
r9482 if self.ast_transformers:
ast.fix_missing_locations(node)
return node
Thomas Kluyver
Add framework for AST transformations of input code.
r8220
Bernardo B. Marques
remove all trailling spaces
r4872
Thomas Kluyver
Add shell_futures parameter to run_cell to allow running code without sharing __future__ imports.
r9081 def run_ast_nodes(self, nodelist, cell_name, interactivity='last_expr',
compiler=compile):
Thomas Kluyver
Add methods to run an IPython cell based on AST nodes. Have done basic testing manually.
r3527 """Run a sequence of AST nodes. The execution mode depends on the
interactivity parameter.
Bernardo B. Marques
remove all trailling spaces
r4872
Thomas Kluyver
Add methods to run an IPython cell based on AST nodes. Have done basic testing manually.
r3527 Parameters
----------
nodelist : list
A sequence of AST nodes to run.
Thomas Kluyver
Change integer options to string options for interactivity.
r3533 cell_name : str
Will be passed to the compiler as the filename of the cell. Typically
the value returned by ip.compile.cache(cell).
interactivity : str
Thomas Kluyver
Make default evaluation run the last AST node only if it is an expression.
r3740 'all', 'last', 'last_expr' or 'none', specifying which nodes should be
run interactively (displaying output from expressions). 'last_expr'
will run the last node interactively only if it is an expression (i.e.
expressions in loops or other blocks are not displayed. Other values
for this parameter will raise a ValueError.
Thomas Kluyver
Add shell_futures parameter to run_cell to allow running code without sharing __future__ imports.
r9081 compiler : callable
A function with the same interface as the built-in compile(), to turn
the AST nodes into code objects. Default is the built-in compile().
Thomas Kluyver
Add methods to run an IPython cell based on AST nodes. Have done basic testing manually.
r3527 """
if not nodelist:
return
Bernardo B. Marques
remove all trailling spaces
r4872
Thomas Kluyver
Make default evaluation run the last AST node only if it is an expression.
r3740 if interactivity == 'last_expr':
if isinstance(nodelist[-1], ast.Expr):
interactivity = "last"
else:
interactivity = "none"
Bernardo B. Marques
remove all trailling spaces
r4872
Thomas Kluyver
Change integer options to string options for interactivity.
r3533 if interactivity == 'none':
Thomas Kluyver
Add methods to run an IPython cell based on AST nodes. Have done basic testing manually.
r3527 to_run_exec, to_run_interactive = nodelist, []
Thomas Kluyver
Change integer options to string options for interactivity.
r3533 elif interactivity == 'last':
Thomas Kluyver
Add methods to run an IPython cell based on AST nodes. Have done basic testing manually.
r3527 to_run_exec, to_run_interactive = nodelist[:-1], nodelist[-1:]
Thomas Kluyver
Change integer options to string options for interactivity.
r3533 elif interactivity == 'all':
Thomas Kluyver
Add methods to run an IPython cell based on AST nodes. Have done basic testing manually.
r3527 to_run_exec, to_run_interactive = [], nodelist
Thomas Kluyver
Change integer options to string options for interactivity.
r3533 else:
raise ValueError("Interactivity was %r" % interactivity)
Bernardo B. Marques
remove all trailling spaces
r4872
Thomas Kluyver
Replace run_cell method, and fix up caching compiler so we can cache a string, then compile AST nodes.
r3529 exec_count = self.execution_count
Fernando Perez
Prevent crash from invalid code such as a bare 'return'....
r4566
try:
for i, node in enumerate(to_run_exec):
mod = ast.Module([node])
Thomas Kluyver
Add shell_futures parameter to run_cell to allow running code without sharing __future__ imports.
r9081 code = compiler(mod, cell_name, "exec")
Bradley M. Froehle
Remove flush_softspace option which is never used.
r6644 if self.run_code(code):
Fernando Perez
Prevent crash from invalid code such as a bare 'return'....
r4566 return True
for i, node in enumerate(to_run_interactive):
mod = ast.Interactive([node])
Thomas Kluyver
Add shell_futures parameter to run_cell to allow running code without sharing __future__ imports.
r9081 code = compiler(mod, cell_name, "single")
Bradley M. Froehle
Remove flush_softspace option which is never used.
r6644 if self.run_code(code):
Fernando Perez
Prevent crash from invalid code such as a bare 'return'....
r4566 return True
Bradley M. Froehle
Delay flushing softspace until after an entire cell is run....
r6642
# Flush softspace
if softspace(sys.stdout, 0):
Matthias BUSSONNIER
use print function in module with `print >>`
r7817 print()
Bradley M. Froehle
Delay flushing softspace until after an entire cell is run....
r6642
Fernando Perez
Prevent crash from invalid code such as a bare 'return'....
r4566 except:
# It's possible to have exceptions raised here, typically by
# compilation of odd code (such as a naked 'return' outside a
# function) that did parse but isn't valid. Typically the exception
# is a SyntaxError, but it's safest just to catch anything and show
# the user a traceback.
# We do only one try/except outside the loop to minimize the impact
# on runtime, and also because if any node in the node list is
# broken, we should stop execution completely.
self.showtraceback()
MinRK
remove code_to_run attribute, updates per review....
r3737
return False
Bernardo B. Marques
remove all trailling spaces
r4872
Bradley M. Froehle
Remove flush_softspace option which is never used.
r6644 def run_code(self, code_obj):
Ville M. Vainio
crlf -> lf
r1032 """Execute a code object.
When an exception occurs, self.showtraceback() is called to display a
traceback.
MinRK
fix %autopx in scripts by calling run_code for each ast node...
r3735 Parameters
----------
code_obj : code object
A compiled code object, to be executed
Ville M. Vainio
crlf -> lf
r1032
MinRK
fix %autopx in scripts by calling run_code for each ast node...
r3735 Returns
-------
MinRK
remove code_to_run attribute, updates per review....
r3737 False : successful execution.
True : an error occurred.
Ville M. Vainio
crlf -> lf
r1032 """
# Set our own excepthook in case the user code tries to call it
# directly, so that the IPython crash handler doesn't get triggered
Justyna Ilczuk
i1673 implementation of py3 proper error handling...
r17157 old_excepthook, sys.excepthook = sys.excepthook, self.excepthook
Ville M. Vainio
crlf -> lf
r1032
# we save the original sys.excepthook in the instance, in case config
# code (such as magics) needs access to it.
self.sys_excepthook = old_excepthook
outflag = 1 # happens in more places, so it's easier as default
try:
try:
MinRK
merge interactiveshell.py
r3122 self.hooks.pre_run_code_hook()
Fernando Perez
Improve docs and comments of some internal tools, and of testing code
r3297 #rprint('Running code', repr(code_obj)) # dbg
Thomas Kluyver
Fix exec statements for Py 3...
r13350 exec(code_obj, self.user_global_ns, self.user_ns)
Ville M. Vainio
crlf -> lf
r1032 finally:
# Reset our crash handler in place
sys.excepthook = old_excepthook
except SystemExit:
Fernando Perez
Lots of work on exception handling, including tests for traceback printing....
r2440 self.showtraceback(exception_only=True)
Thomas Kluyver
Update description of options to exit.
r3758 warn("To exit: use 'exit', 'quit', or Ctrl-D.", level=1)
Ville M. Vainio
crlf -> lf
r1032 except self.custom_exceptions:
Justyna Ilczuk
i1673 implementation of py3 proper error handling...
r17157 etype, value, tb = sys.exc_info()
self.CustomTB(etype, value, tb)
Ville M. Vainio
crlf -> lf
r1032 except:
self.showtraceback()
else:
outflag = 0
return outflag
Bernardo B. Marques
remove all trailling spaces
r4872
MinRK
merge interactiveshell.py
r3122 # For backwards compatibility
runcode = run_code
Fernando Perez
Add pending removal comments regarding the input handling methods in the kernel
r3139
Brian Granger
Work on startup related things....
r2252 #-------------------------------------------------------------------------
Brian Granger
Complete reorganization of InteractiveShell....
r2761 # Things related to GUI support and pylab
Brian Granger
More re-organization of InteractiveShell.
r2242 #-------------------------------------------------------------------------
Ville M. Vainio
crlf -> lf
r1032
Fernando Perez
Refactor gui/pylab integration to eliminate code duplication....
r5469 def enable_gui(self, gui=None):
raise NotImplementedError('Implement enable_gui in a subclass')
MinRK
add `%matplotlib` and `shell.enable_matplotlib`...
r11328
def enable_matplotlib(self, gui=None):
"""Enable interactive matplotlib and inline figure support.
This takes the following steps:
1. select the appropriate eventloop and matplotlib backend
2. set up matplotlib for interactive use with that backend
3. configure formatters for inline figure display
4. enable the selected gui eventloop
Parameters
----------
gui : optional, string
If given, dictates the choice of matplotlib GUI backend to use
(should be one of IPython's supported backends, 'qt', 'osx', 'tk',
'gtk', 'wx' or 'inline'), otherwise we use the default chosen by
matplotlib (as dictated by the matplotlib build-time options plus the
user's matplotlibrc configuration file). Note that not all backends
make sense in all contexts, for example a terminal ipython can't
display figures inline.
"""
from IPython.core import pylabtools as pt
gui, backend = pt.find_gui_and_backend(gui, self.pylab_gui_select)
if gui != 'inline':
# If we have our first gui selection, store it
if self.pylab_gui_select is None:
self.pylab_gui_select = gui
# Otherwise if they are different
elif gui != self.pylab_gui_select:
print ('Warning: Cannot change to a different GUI toolkit: %s.'
' Using %s instead.' % (gui, self.pylab_gui_select))
gui, backend = pt.find_gui_and_backend(self.pylab_gui_select)
pt.activate_matplotlib(backend)
pt.configure_inline_support(self, backend)
# Now we must activate the gui pylab wants to use, and fix %run to take
# plot updates into account
self.enable_gui(gui)
self.magics_manager.registry['ExecutionMagics'].default_runner = \
pt.mpl_runner(self.safe_execfile)
return gui, backend
Fernando Perez
Refactor gui/pylab integration to eliminate code duplication....
r5469
Aaron Meurer
Add welcome_message option to enable_pylab...
r8229 def enable_pylab(self, gui=None, import_all=True, welcome_message=False):
Fernando Perez
Refactor gui/pylab integration to eliminate code duplication....
r5469 """Activate pylab support at runtime.
This turns on support for matplotlib, preloads into the interactive
namespace all of numpy and pylab, and configures IPython to correctly
interact with the GUI event loop. The GUI backend to be used can be
Thomas Kluyver
Miscellaneous docs fixes
r9244 optionally selected with the optional ``gui`` argument.
MinRK
add `%matplotlib` and `shell.enable_matplotlib`...
r11328
This method only adds preloading the namespace to InteractiveShell.enable_matplotlib.
Fernando Perez
Refactor gui/pylab integration to eliminate code duplication....
r5469
Parameters
----------
gui : optional, string
If given, dictates the choice of matplotlib GUI backend to use
(should be one of IPython's supported backends, 'qt', 'osx', 'tk',
'gtk', 'wx' or 'inline'), otherwise we use the default chosen by
matplotlib (as dictated by the matplotlib build-time options plus the
user's matplotlibrc configuration file). Note that not all backends
make sense in all contexts, for example a terminal ipython can't
display figures inline.
MinRK
add `%matplotlib` and `shell.enable_matplotlib`...
r11328 import_all : optional, bool, default: True
Whether to do `from numpy import *` and `from pylab import *`
in addition to module imports.
welcome_message : deprecated
This argument is ignored, no welcome message will be displayed.
Fernando Perez
Refactor gui/pylab integration to eliminate code duplication....
r5469 """
MinRK
add `%matplotlib` and `shell.enable_matplotlib`...
r11328 from IPython.core.pylabtools import import_pylab
gui, backend = self.enable_matplotlib(gui)
Fernando Perez
Refactor gui/pylab integration to eliminate code duplication....
r5469 # We want to prevent the loading of pylab to pollute the user's
# namespace as shown by the %who* magics, so we execute the activation
# code in an empty namespace, and we update *both* user_ns and
# user_ns_hidden with this information.
ns = {}
MinRK
add `%matplotlib` and `shell.enable_matplotlib`...
r11328 import_pylab(ns, import_all)
MinRK
warn about names clobbered by `%pylab`
r11325 # warn about clobbered names
ignored = set(["__builtins__"])
both = set(ns).intersection(self.user_ns).difference(ignored)
clobbered = [ name for name in both if self.user_ns[name] is not ns[name] ]
Fernando Perez
Refactor gui/pylab integration to eliminate code duplication....
r5469 self.user_ns.update(ns)
self.user_ns_hidden.update(ns)
MinRK
add `%matplotlib` and `shell.enable_matplotlib`...
r11328 return gui, backend, clobbered
Brian Granger
More re-organization of InteractiveShell.
r2242
#-------------------------------------------------------------------------
# Utilities
#-------------------------------------------------------------------------
Thomas Kluyver
Use DollarFormatter to fill in names in ! shell calls....
r5355 def var_expand(self, cmd, depth=0, formatter=DollarFormatter()):
Brian Granger
Massive, crazy refactoring of everything....
r2202 """Expand python variables in a string.
The depth argument indicates how many frames above the caller should
be walked to look for the local namespace where to expand variables.
The global namespace for expansion is always the user's interactive
namespace.
"""
Thomas Kluyver
Use DollarFormatter to fill in names in ! shell calls....
r5355 ns = self.user_ns.copy()
ns.update(sys._getframe(depth+1).f_locals)
MinRK
ignore errors in shell.var_expand...
r6124 try:
Thomas Kluyver
Fix variable expansion on 'self'...
r8225 # We have to use .vformat() here, because 'self' is a valid and common
# name, and expanding **ns for .format() would make it collide with
# the 'self' argument of the method.
cmd = formatter.vformat(cmd, args=[], kwargs=ns)
MinRK
ignore errors in shell.var_expand...
r6124 except Exception:
# if formatter couldn't format, just let it go untransformed
pass
return cmd
Ville M. Vainio
crlf -> lf
r1032
Fernando Perez
Complete implementation of interactive traceback support....
r3175 def mktempfile(self, data=None, prefix='ipython_edit_'):
Ville M. Vainio
crlf -> lf
r1032 """Make a new tempfile and return its filename.
Matthias BUSSONNIER
avoid import of nearby temporary with %edit...
r14683 This makes a call to tempfile.mkstemp (created in a tempfile.mkdtemp),
but it registers the created filename internally so ipython cleans it up
at exit time.
Ville M. Vainio
crlf -> lf
r1032
Optional inputs:
- data(None): if data is given, it gets written out to the temp file
Thomas Kluyver
Improvements to docs formatting.
r12553 immediately, and the file is closed again."""
Ville M. Vainio
crlf -> lf
r1032
Matthias BUSSONNIER
avoid import of nearby temporary with %edit...
r14683 dirname = tempfile.mkdtemp(prefix=prefix)
self.tempdirs.append(dirname)
handle, filename = tempfile.mkstemp('.py', prefix, dir=dirname)
Ville M. Vainio
crlf -> lf
r1032 self.tempfiles.append(filename)
Bernardo B. Marques
remove all trailling spaces
r4872
Ville M. Vainio
crlf -> lf
r1032 if data:
tmp_file = open(filename,'w')
tmp_file.write(data)
tmp_file.close()
return filename
Brian Granger
Complete reorganization of InteractiveShell....
r2761 # TODO: This should be removed when Term is refactored.
Ville M. Vainio
crlf -> lf
r1032 def write(self,data):
"""Write a string to the default output"""
MinRK
io.Term.cin/out/err replaced by io.stdin/out/err...
r3800 io.stdout.write(data)
Ville M. Vainio
crlf -> lf
r1032
Brian Granger
Complete reorganization of InteractiveShell....
r2761 # TODO: This should be removed when Term is refactored.
Ville M. Vainio
crlf -> lf
r1032 def write_err(self,data):
"""Write a string to the default error output"""
MinRK
io.Term.cin/out/err replaced by io.stdin/out/err...
r3800 io.stderr.write(data)
Ville M. Vainio
crlf -> lf
r1032
MinRK
fix default value in interactiveshell.ask_yes_no...
r5370 def ask_yes_no(self, prompt, default=None):
Brian Granger
More re-organization of InteractiveShell.
r2242 if self.quiet:
return True
return ask_yes_no(prompt,default)
Bernardo B. Marques
remove all trailling spaces
r4872
Fernando Perez
Get naked '?' to work, and in-spec with the new inputsplitter design.
r2876 def show_usage(self):
"""Show a usage message"""
page.page(IPython.core.usage.interactive_usage)
Bernardo B. Marques
remove all trailling spaces
r4872
Fernando Perez
Move extract_input_lines to main shell object, where it belongs.
r6914 def extract_input_lines(self, range_str, raw=False):
"""Return as a string a set of input history slices.
Parameters
----------
range_str : string
The set of slices is given as a string, like "~5/6-~4/2 4:8 9",
since this function is for use by magic functions which get their
arguments as strings. The number before the / is the session
number: ~n goes n back from the current session.
Thomas Kluyver
Clean up numpydoc section headers
r13587 raw : bool, optional
By default, the processed input is used. If this is true, the raw
input history is used instead.
Fernando Perez
Move extract_input_lines to main shell object, where it belongs.
r6914
Thomas Kluyver
Clean up numpydoc section headers
r13587 Notes
-----
Fernando Perez
Move extract_input_lines to main shell object, where it belongs.
r6914
Thomas Kluyver
Clean up numpydoc section headers
r13587 Slices can be described with two notations:
Fernando Perez
Move extract_input_lines to main shell object, where it belongs.
r6914
Thomas Kluyver
Clean up numpydoc section headers
r13587 * ``N:M`` -> standard python form, means including items N...(M-1).
* ``N-M`` -> include items N..M (closed endpoint).
Thomas Kluyver
Improvements to docs formatting.
r12553 """
Fernando Perez
Move extract_input_lines to main shell object, where it belongs.
r6914 lines = self.history_manager.get_range_by_str(range_str, raw=raw)
return "\n".join(x for _, _, x in lines)
George Titsworth
Added new capability to the `%load` magic to search the user's namespace for modules, classes, or functions and inspects those to load source....
r16318 def find_user_code(self, target, raw=True, py_only=False, skip_encoding_cookie=True, search_ns=False):
Matthias BUSSONNIER
find_user_code improvement for not py-files...
r6774 """Get a code string from history, file, url, or a string or macro.
Bernardo B. Marques
remove all trailling spaces
r4872
This is mainly used by magic functions.
Thomas Kluyver
Move _get_some_code method to InteractiveShell object; improve docstring.
r3509 Parameters
----------
Matthias BUSSONNIER
make pycat and loadpy aware of history and more...
r6761
Thomas Kluyver
Move _get_some_code method to InteractiveShell object; improve docstring.
r3509 target : str
Matthias BUSSONNIER
make pycat and loadpy aware of history and more...
r6761
Thomas Kluyver
Move _get_some_code method to InteractiveShell object; improve docstring.
r3509 A string specifying code to retrieve. This will be tried respectively
Matthias BUSSONNIER
make pycat and loadpy aware of history and more...
r6761 as: ranges of input history (see %history for syntax), url,
Matthias BUSSONNIER
fix english, typo, remove code that was a test...
r6773 correspnding .py file, filename, or an expression evaluating to a
Matthias BUSSONNIER
make pycat and loadpy aware of history and more...
r6761 string or Macro in the user namespace.
Thomas Kluyver
Move _get_some_code method to InteractiveShell object; improve docstring.
r3509 raw : bool
If true (default), retrieve raw history. Has no effect on the other
retrieval mechanisms.
Bernardo B. Marques
remove all trailling spaces
r4872
Matthias BUSSONNIER
find_user_code binary fallback
r6775 py_only : bool (default False)
Matthias BUSSONNIER
find_user_code improvement for not py-files...
r6774 Only try to fetch python code, do not try alternative methods to decode file
if unicode fails.
Thomas Kluyver
Move _get_some_code method to InteractiveShell object; improve docstring.
r3509 Returns
-------
A string of code.
Bernardo B. Marques
remove all trailling spaces
r4872
Thomas Kluyver
Move _get_some_code method to InteractiveShell object; improve docstring.
r3509 ValueError is raised if nothing is found, and TypeError if it evaluates
to an object of another type. In each case, .args[0] is a printable
message.
"""
Bernardo B. Marques
remove all trailling spaces
r4872 code = self.extract_input_lines(target, raw=raw) # Grab history
Thomas Kluyver
Move _get_some_code method to InteractiveShell object; improve docstring.
r3509 if code:
return code
Matthias BUSSONNIER
find_user_code improvement for not py-files...
r6774 utarget = unquote_filename(target)
Matthias BUSSONNIER
use openpy, and catch non-responding URL
r6763 try:
if utarget.startswith(('http://', 'https://')):
Jörgen Stenarson
Make magic pycat print encoding_cookie
r8334 return openpy.read_py_url(utarget, skip_encoding_cookie=skip_encoding_cookie)
Matthias BUSSONNIER
fix english, typo, remove code that was a test...
r6773 except UnicodeDecodeError:
Matthias BUSSONNIER
find_user_code improvement for not py-files...
r6774 if not py_only :
Sean Vig
Fix Python 3 handling of urllib...
r13640 # Deferred import
try:
from urllib.request import urlopen # Py3
except ImportError:
from urllib import urlopen
Thomas Kluyver
Defer import of urllib
r9389 response = urlopen(target)
Matthias BUSSONNIER
remove TextIOWrapper, use strig mode for load options
r6895 return response.read().decode('latin1')
Matthias BUSSONNIER
find_user_code improvement for not py-files...
r6774 raise ValueError(("'%s' seem to be unreadable.") % utarget)
Matthias BUSSONNIER
make pycat and loadpy aware of history and more...
r6761
Matthias BUSSONNIER
share code for file and py_file
r6778 potential_target = [target]
Matthias BUSSONNIER
make pycat and loadpy aware of history and more...
r6761 try :
Matthias BUSSONNIER
share code for file and py_file
r6778 potential_target.insert(0,get_py_filename(target))
Matthias BUSSONNIER
make pycat and loadpy aware of history and more...
r6761 except IOError:
pass
Matthias BUSSONNIER
share code for file and py_file
r6778
for tgt in potential_target :
if os.path.isfile(tgt): # Read file
try :
Jörgen Stenarson
Make magic pycat print encoding_cookie
r8334 return openpy.read_py_file(tgt, skip_encoding_cookie=skip_encoding_cookie)
Matthias BUSSONNIER
share code for file and py_file
r6778 except UnicodeDecodeError :
if not py_only :
with io_open(tgt,'r', encoding='latin1') as f :
return f.read()
raise ValueError(("'%s' seem to be unreadable.") % target)
Paul Ivanov
informative error when trying to load directories...
r10348 elif os.path.isdir(os.path.expanduser(tgt)):
raise ValueError("'%s' is a directory, not a regular file." % target)
Bernardo B. Marques
remove all trailling spaces
r4872
George Titsworth
Added new capability to the `%load` magic to search the user's namespace for modules, classes, or functions and inspects those to load source....
r16318 if search_ns:
George Titsworth
Reworking object look up code to use existing inspect functionality.
r16353 # Inspect namespace to load object source
object_info = self.object_inspect(target, detail_level=1)
if object_info['found'] and object_info['source']:
return object_info['source']
George Titsworth
Added new capability to the `%load` magic to search the user's namespace for modules, classes, or functions and inspects those to load source....
r16318
Thomas Kluyver
Move _get_some_code method to InteractiveShell object; improve docstring.
r3509 try: # User namespace
codeobj = eval(target, self.user_ns)
except Exception:
Matthias BUSSONNIER
share code for file and py_file
r6778 raise ValueError(("'%s' was not found in history, as a file, url, "
Matthias BUSSONNIER
make pycat and loadpy aware of history and more...
r6761 "nor in the user namespace.") % target)
George Titsworth
Added new capability to the `%load` magic to search the user's namespace for modules, classes, or functions and inspects those to load source....
r16318
Thomas Kluyver
Replace references to unicode and basestring
r13353 if isinstance(codeobj, string_types):
Thomas Kluyver
Move _get_some_code method to InteractiveShell object; improve docstring.
r3509 return codeobj
elif isinstance(codeobj, Macro):
return codeobj.value
Bernardo B. Marques
remove all trailling spaces
r4872
Thomas Kluyver
Move _get_some_code method to InteractiveShell object; improve docstring.
r3509 raise TypeError("%s is neither a string nor a macro." % target,
codeobj)
Brian Granger
More re-organization of InteractiveShell.
r2242
#-------------------------------------------------------------------------
# Things related to IPython exiting
#-------------------------------------------------------------------------
def atexit_operations(self):
"""This will be executed at the time of exit.
Ville M. Vainio
crlf -> lf
r1032
Fernando Perez
Fix bug where atexit operations were only done if readline was present.
r2953 Cleanup operations and saving of persistent data that is done
unconditionally by IPython should be performed here.
Ville M. Vainio
crlf -> lf
r1032
Fernando Perez
Fix bug where atexit operations were only done if readline was present.
r2953 For things that may depend on startup flags or platform specifics (such
as having readline or not), register a separate atexit function in the
code that has the appropriate information, rather than trying to
Bernardo B. Marques
remove all trailling spaces
r4872 clutter
Fernando Perez
Fix bug where atexit operations were only done if readline was present.
r2953 """
MinRK
add test history db to shell.tempfiles for cleanup...
r4602 # Close the history session (this stores the end time and line count)
# this must be *before* the tempfile cleanup, in case of temporary
# history db
self.history_manager.end_session()
Bernardo B. Marques
remove all trailling spaces
r4872
Matthias BUSSONNIER
avoid import of nearby temporary with %edit...
r14683 # Cleanup all tempfiles and folders left around
Brian Granger
More re-organization of InteractiveShell.
r2242 for tfile in self.tempfiles:
try:
os.unlink(tfile)
except OSError:
pass
Bernardo B. Marques
remove all trailling spaces
r4872
Matthias BUSSONNIER
avoid import of nearby temporary with %edit...
r14683 for tdir in self.tempdirs:
try:
os.rmdir(tdir)
except OSError:
pass
Brian Granger
More re-organization of InteractiveShell.
r2242 # Clear all user namespaces to release all references cleanly.
Thomas Kluyver
ipython-qtconsole now calls the right function.
r3397 self.reset(new_session=False)
Ville M. Vainio
crlf -> lf
r1032
Brian Granger
More re-organization of InteractiveShell.
r2242 # Run user hooks
self.hooks.shutdown_hook()
Ville M. Vainio
crlf -> lf
r1032
Brian Granger
More re-organization of InteractiveShell.
r2242 def cleanup(self):
self.restore_sys_module_state()
Ville M. Vainio
crlf -> lf
r1032
Thomas Kluyver
Fixes for metaclass syntax
r13359 class InteractiveShellABC(with_metaclass(abc.ABCMeta, object)):
Brian Granger
Finishing work on configurables, plugins and extensions.
r2738 """An abstract base class for InteractiveShell."""
InteractiveShellABC.register(InteractiveShell)