##// END OF EJS Templates
Merge pull request #2223 from takluyver/custom_traceback...
Thomas Kluyver -
r8088:06c27d89 merge
parent child Browse files
Show More
@@ -0,0 +1,44
1 .. _integrating:
2
3 =====================================
4 Integrating your objects with IPython
5 =====================================
6
7 Tab completion
8 ==============
9
10 To change the attributes displayed by tab-completing your object, define a
11 ``__dir__(self)`` method for it. For more details, see the documentation of the
12 built-in `dir() function <http://docs.python.org/library/functions.html#dir>`_.
13
14 Rich display
15 ============
16
17 The notebook and the Qt console can display richer representations of objects.
18 To use this, you can define any of a number of ``_repr_*_()`` methods. Note that
19 these are surrounded by single, not double underscores.
20
21 Both the notebook and the Qt console can display ``svg``, ``png`` and ``jpeg``
22 representations. The notebook can also display ``html``, ``javascript``,
23 and ``latex``. If the methods don't exist, or return ``None``, it falls
24 back to a standard ``repr()``.
25
26 For example::
27
28 class Shout(object):
29 def __init__(self, text):
30 self.text = text
31
32 def _repr_html_(self):
33 return "<h1>" + self.text + "</h1>"
34
35 Custom exception tracebacks
36 ===========================
37
38 Rarely, you might want to display a different traceback with an exception -
39 IPython's own parallel computing framework does this to display errors from the
40 engines. To do this, define a ``_render_traceback_(self)`` method which returns
41 a list of strings, each containing one line of the traceback.
42
43 Please be conservative in using this feature; by replacing the default traceback
44 you may hide important information from the user.
@@ -187,6 +187,8 def display_latex(*objs, **kwargs):
187 def display_json(*objs, **kwargs):
187 def display_json(*objs, **kwargs):
188 """Display the JSON representation of an object.
188 """Display the JSON representation of an object.
189
189
190 Note that not many frontends support displaying JSON.
191
190 Parameters
192 Parameters
191 ----------
193 ----------
192 objs : tuple of objects
194 objs : tuple of objects
@@ -86,22 +86,6 from IPython.utils.traitlets import (Integer, CBool, CaselessStrEnum, Enum,
86 from IPython.utils.warn import warn, error
86 from IPython.utils.warn import warn, error
87 import IPython.core.hooks
87 import IPython.core.hooks
88
88
89 # FIXME: do this in a function to avoid circular dependencies
90 # A better solution is to remove IPython.parallel.error,
91 # and place those classes in IPython.core.error.
92
93 class RemoteError(Exception):
94 pass
95
96 def _import_remote_error():
97 global RemoteError
98 try:
99 from IPython.parallel.error import RemoteError
100 except:
101 pass
102
103 _import_remote_error()
104
105 #-----------------------------------------------------------------------------
89 #-----------------------------------------------------------------------------
106 # Globals
90 # Globals
107 #-----------------------------------------------------------------------------
91 #-----------------------------------------------------------------------------
@@ -1735,10 +1719,6 class InteractiveShell(SingletonConfigurable):
1735 self.showsyntaxerror(filename)
1719 self.showsyntaxerror(filename)
1736 elif etype is UsageError:
1720 elif etype is UsageError:
1737 self.write_err("UsageError: %s" % value)
1721 self.write_err("UsageError: %s" % value)
1738 elif issubclass(etype, RemoteError):
1739 # IPython.parallel remote exceptions.
1740 # Draw the remote traceback, not the local one.
1741 self._showtraceback(etype, value, value.render_traceback())
1742 else:
1722 else:
1743 if exception_only:
1723 if exception_only:
1744 stb = ['An exception has occurred, use %tb to see '
1724 stb = ['An exception has occurred, use %tb to see '
@@ -1746,6 +1726,12 class InteractiveShell(SingletonConfigurable):
1746 stb.extend(self.InteractiveTB.get_exception_only(etype,
1726 stb.extend(self.InteractiveTB.get_exception_only(etype,
1747 value))
1727 value))
1748 else:
1728 else:
1729 try:
1730 # Exception classes can customise their traceback - we
1731 # use this in IPython.parallel for exceptions occurring
1732 # in the engines. This should return a list of strings.
1733 stb = value._render_traceback_()
1734 except Exception:
1749 stb = self.InteractiveTB.structured_traceback(etype,
1735 stb = self.InteractiveTB.structured_traceback(etype,
1750 value, tb, tb_offset=tb_offset)
1736 value, tb, tb_offset=tb_offset)
1751
1737
@@ -33,6 +33,7 import nose.tools as nt
33
33
34 # Our own
34 # Our own
35 from IPython.testing.decorators import skipif
35 from IPython.testing.decorators import skipif
36 from IPython.testing import tools as tt
36 from IPython.utils import io
37 from IPython.utils import io
37
38
38 #-----------------------------------------------------------------------------
39 #-----------------------------------------------------------------------------
@@ -401,6 +402,18 class TestSystemRaw(unittest.TestCase):
401 cmd = ur'''python -c "'åäö'" '''
402 cmd = ur'''python -c "'åäö'" '''
402 ip.system_raw(cmd)
403 ip.system_raw(cmd)
403
404
405 class TestModules(unittest.TestCase, tt.TempFileMixin):
406 def test_extraneous_loads(self):
407 """Test we're not loading modules on startup that we shouldn't.
408 """
409 self.mktmp("import sys\n"
410 "print('numpy' in sys.modules)\n"
411 "print('IPython.parallel' in sys.modules)\n"
412 "print('IPython.zmq' in sys.modules)\n"
413 )
414 out = "False\nFalse\nFalse\n"
415 tt.ipexec_validate(self.fname, out)
416
404
417
405 def test__IPYTHON__():
418 def test__IPYTHON__():
406 # This shouldn't raise a NameError, that's all
419 # This shouldn't raise a NameError, that's all
@@ -194,6 +194,9 class RemoteError(KernelError):
194 """render traceback to a list of lines"""
194 """render traceback to a list of lines"""
195 return (self.traceback or "No traceback available").splitlines()
195 return (self.traceback or "No traceback available").splitlines()
196
196
197 # Special method for custom tracebacks within IPython
198 _render_traceback_ = render_traceback
199
197 def print_traceback(self, excid=None):
200 def print_traceback(self, excid=None):
198 """print my traceback"""
201 """print my traceback"""
199 print('\n'.join(self.render_traceback()))
202 print('\n'.join(self.render_traceback()))
@@ -10,5 +10,6 Configuration and customization
10 overview.txt
10 overview.txt
11 extensions/index.txt
11 extensions/index.txt
12 ipython.txt
12 ipython.txt
13 integrating.txt
13 editors.txt
14 editors.txt
14 old.txt
15 old.txt
@@ -6,4 +6,8 This document describes in-flight development work.
6
6
7 The CodeMirror js library has been updated fron 2.23 to 2.32
7 The CodeMirror js library has been updated fron 2.23 to 2.32
8 this might induce a few changes in behavior of keymaps in the notebook,
8 this might induce a few changes in behavior of keymaps in the notebook,
9 especially intenting/deindenting blocks that is now bounded to Ctrl+] and ctr+[
9 especially intenting/deindenting blocks that is now bound to Ctrl+] and ctr+[
10
11 * Exception types can now be displayed with a custom traceback, by defining a
12 ``_render_traceback_()`` method which returns a list of strings, each
13 containing one line of the traceback.
General Comments 0
You need to be logged in to leave comments. Login now