##// END OF EJS Templates
Add transformers to understand code pasted with >>> or IPython prompts....
Add transformers to understand code pasted with >>> or IPython prompts. Now the following all work out of the box: In [8]: In [6]: for i in range(5): ...: ...: print i, ...: ...: ...: 0 1 2 3 4 In [10]: >>> width = 20 In [11]: >>> height = 5*9 In [12]: >>> width * height Out[12]: 900 And the history is still clean: In [13]: %hist -n [snipped] for i in range(5): print i, get_ipython().magic("hist -n") width = 20 height = 5*9 width * height This will be extremely useful when copy/pasting from interactive tutorials, doctests and examples. Also fixes %doctest_mode: https://bugs.launchpad.net/ipython/+bug/505404

File last commit:

r2301:649f9975
r2426:61e33e8e
Show More
configobjfactory.py
78 lines | 2.4 KiB | text/x-python | PythonLexer
#!/usr/bin/env python
# encoding: utf-8
"""
A class for creating a Twisted service that is configured using IPython's
configuration system.
"""
#-----------------------------------------------------------------------------
# Copyright (C) 2008-2009 The IPython Development Team
#
# Distributed under the terms of the BSD License. The full license is in
# the file COPYING, distributed as part of this software.
#-----------------------------------------------------------------------------
#-----------------------------------------------------------------------------
# Imports
#-----------------------------------------------------------------------------
import zope.interface as zi
from IPython.core.component import Component
#-----------------------------------------------------------------------------
# Code
#-----------------------------------------------------------------------------
class IConfiguredObjectFactory(zi.Interface):
"""I am a component that creates a configured object.
This class is useful if you want to configure a class that is not a
subclass of :class:`IPython.core.component.Component`.
"""
def __init__(config):
"""Get ready to configure the object using config."""
def create():
"""Return an instance of the configured object."""
class ConfiguredObjectFactory(Component):
zi.implements(IConfiguredObjectFactory)
def __init__(self, config):
super(ConfiguredObjectFactory, self).__init__(None, config=config)
def create(self):
raise NotImplementedError('create must be implemented in a subclass')
class IAdaptedConfiguredObjectFactory(zi.Interface):
"""I am a component that adapts and configures an object.
This class is useful if you have the adapt an instance and configure it.
"""
def __init__(config, adaptee=None):
"""Get ready to adapt adaptee and then configure it using config."""
def create():
"""Return an instance of the adapted and configured object."""
class AdaptedConfiguredObjectFactory(Component):
# zi.implements(IAdaptedConfiguredObjectFactory)
def __init__(self, config, adaptee):
# print
# print "config pre:", config
super(AdaptedConfiguredObjectFactory, self).__init__(None, config=config)
# print
# print "config post:", config
self.adaptee = adaptee
def create(self):
raise NotImplementedError('create must be implemented in a subclass')