##// END OF EJS Templates
Fixed keyboard.js indent break
Fixed keyboard.js indent break

File last commit:

r15613:1b3e35d2
r15974:433c1257
Show More
callbacks.rst
42 lines | 1.4 KiB | text/x-rst | RstLexer
Thomas Kluyver
Document new callbacks system
r15604 =====================
Registering callbacks
=====================
Extension code can register callbacks functions which will be called on specific
events within the IPython code. You can see the current list of available
callbacks, and the parameters that will be passed with each, in the callback
prototype functions defined in :mod:`IPython.core.callbacks`.
Thomas Kluyver
callbacks -> events in docs
r15613 To register callbacks, use :meth:`IPython.core.events.EventManager.register`.
Thomas Kluyver
Document new callbacks system
r15604 For example::
class VarWatcher(object):
def __init__(self, ip):
self.shell = ip
self.last_x = None
def pre_execute(self):
self.last_x = self.shell.user_ns.get('x', None)
def post_execute(self):
if self.shell.user_ns.get('x', None) != self.last_x:
print("x changed!")
def load_ipython_extension(ip):
vw = VarWatcher(ip)
Thomas Kluyver
callbacks -> events in docs
r15613 ip.events.register('pre_execute', vw.pre_execute)
ip.events.register('post_execute', vw.post_execute)
Thomas Kluyver
Document new callbacks system
r15604
Thomas Kluyver
Add note about experimental API
r15606 .. note::
This API is experimental in IPython 2.0, and may be revised in future versions.
Thomas Kluyver
Document new callbacks system
r15604 .. seealso::
Module :mod:`IPython.core.hooks`
The older 'hooks' system allows end users to customise some parts of
IPython's behaviour.
:doc:`inputtransforms`
By registering input transformers that don't change code, you can monitor
what is being executed.