##// END OF EJS Templates
add parent to Configurable...
add parent to Configurable this adds the notion of a parent and member config, so the config: c.Foo.Bar.attr = value will only set `Bar.attr = value` for `Bar` instances which are members of `Foo` instances. The mechanism for doing this is ```python f = Foo(config=cfg) f.b = Bar(parent=f) ``` This Instance config has higher priority than plain class config for Bar, but still lower priority than direct keyword arg trait assignment. The main implication this has is to change the standard creation of descendants: ```python self.bar = Bar(config=self.config) ``` into a direct parent expression ```python self.bar = Bar(parent=self) ``` This also means that most Configurables will actually have a handle on their parent object.

File last commit:

r10201:06a54042
r11062:7f44a560
Show More
__init__.py
72 lines | 2.1 KiB | text/x-python | PythonLexer
MinRK
update recently changed modules with Authors in docstring
r4018 """The IPython ZMQ-based parallel computing interface.
Authors:
* MinRK
"""
MinRK
cleanup pass
r3644 #-----------------------------------------------------------------------------
# Copyright (C) 2011 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
#-----------------------------------------------------------------------------
MinRK
depend on pyzmq-2.1dev on Windows...
r3779 import os
MinRK
warn on detection of libzmq 3
r4248 import warnings
MinRK
pyzmq-2.1.3 related testing adjustments
r3661 import zmq
MinRK
bind_kernel on a bound kernel is a no-op
r7312 from IPython.config.configurable import MultipleInstanceError
MinRK
move check_for_zmq to utils.zmqrelated
r10201 from IPython.utils.zmqrelated import check_for_zmq
MinRK
depend on pyzmq-2.1dev on Windows...
r3779
MinRK
bump minimum pyzmq version to 2.1.11...
r9336 min_pyzmq = '2.1.11'
MinRK
warn on detection of libzmq 3
r4248
MinRK
use ROUTER/DEALER socket names instead of XREP/XREQ...
r4725 check_for_zmq(min_pyzmq, 'IPython.parallel')
MinRK
warn on detection of libzmq 3
r4248
MinRK
move IPython.zmq.parallel to IPython.parallel
r3666 from IPython.utils.pickleutil import Reference
MinRK
add DirectView.importer contextmanager, demote targets to mutable flag...
r3665
MinRK
organize IPython.parallel into subpackages
r3673 from .client.asyncresult import *
from .client.client import Client
from .client.remotefunction import *
from .client.view import *
from .controller.dependency import *
MinRK
include errors in IPython.parallel namespace
r7483 from .error import *
from .util import interactive
MinRK
organize IPython.parallel into subpackages
r3673
MinRK
add IPython.parallel.bind_kernel...
r6893 #-----------------------------------------------------------------------------
# Functions
#-----------------------------------------------------------------------------
def bind_kernel(**kwargs):
"""Bind an Engine's Kernel to be used as a full IPython kernel.
This allows a running Engine to be used simultaneously as a full IPython kernel
with the QtConsole or other frontends.
This function returns immediately.
"""
MinRK
mv IPython.zmq to IPython.kernel.zmq
r9372 from IPython.kernel.zmq.kernelapp import IPKernelApp
MinRK
add IPython.parallel.bind_kernel...
r6893 from IPython.parallel.apps.ipengineapp import IPEngineApp
MinRK
bind_kernel on a bound kernel is a no-op
r7312
# first check for IPKernelApp, in which case this should be a no-op
# because there is already a bound kernel
if IPKernelApp.initialized() and isinstance(IPKernelApp._instance, IPKernelApp):
return
MinRK
add IPython.parallel.bind_kernel...
r6893 if IPEngineApp.initialized():
MinRK
bind_kernel on a bound kernel is a no-op
r7312 try:
app = IPEngineApp.instance()
except MultipleInstanceError:
pass
else:
return app.bind_kernel(**kwargs)
raise RuntimeError("bind_kernel be called from an IPEngineApp instance")
MinRK
add IPython.parallel.bind_kernel...
r6893
MinRK
add DirectView.importer contextmanager, demote targets to mutable flag...
r3665