##// END OF EJS Templates
Summary of changes:...
Summary of changes: 1) IPython/core/compilerop.py: IronPython __future__ flags are non-standard, Solution try/except; comment added 2) IPython/core/completer.py: __main__ was undefined, due to local mistake in creating IronPython scope; removed this tweak 3) IPython/core/prompts.py: os.getuid() is not defined (IronPython bug; see: https://mail.python.org/pipermail/ironpython-users/2014-February/016812.html) 4) IPython/lib/inputhook.py: ctypes SystemError; comment added 5) IPython/utils/process.py and IPython/utils/_process_cli.py: adds a new _process_cli.py which would handle the processes under cli; fixed os.pathsep 6) IPython/utils/io.py: devnull opened in append mode; changed to "w" 7) New issue: IPython/external/decorator/_decorator.py: IronPython doesn't have _getframes, unless FullFrames is set to true; comment added

File last commit:

r9190:20a102a5
r15208:301956c6
Show More
interengine.py
43 lines | 1.3 KiB | text/x-python | PythonLexer
MinRK
add inter-engine communication example
r3653 import sys
MinRK
move IPython.zmq.parallel to IPython.parallel
r3666 from IPython.parallel import Client
MinRK
add inter-engine communication example
r3653
MinRK
move IPython.zmq.parallel to IPython.parallel
r3666 rc = Client()
MinRK
add inter-engine communication example
r3653 rc.block=True
view = rc[:]
view.run('communicator.py')
view.execute('com = EngineCommunicator()')
# gather the connection information into a dict
MinRK
reflect revised apply_bound pattern
r3655 ar = view.apply_async(lambda : com.info)
MinRK
add inter-engine communication example
r3653 peers = ar.get_dict()
# this is a dict, keyed by engine ID, of the connection info for the EngineCommunicators
# connect the engines to each other:
MinRK
reflect revised apply_bound pattern
r3655 view.apply_sync(lambda pdict: com.connect(pdict), peers)
MinRK
add inter-engine communication example
r3653
# now all the engines are connected, and we can communicate between them:
def broadcast(client, sender, msg_name, dest_name=None, block=None):
"""broadcast a message from one engine to all others."""
dest_name = msg_name if dest_name is None else dest_name
client[sender].execute('com.publish(%s)'%msg_name, block=None)
targets = client.ids
targets.remove(sender)
return client[targets].execute('%s=com.consume()'%dest_name, block=None)
def send(client, sender, targets, msg_name, dest_name=None, block=None):
"""send a message from one to one-or-more engines."""
dest_name = msg_name if dest_name is None else dest_name
def _send(targets, m_name):
msg = globals()[m_name]
return com.send(targets, msg)
MinRK
reflect revised apply_bound pattern
r3655 client[sender].apply_async(_send, targets, msg_name)
MinRK
add inter-engine communication example
r3653
return client[targets].execute('%s=com.recv()'%dest_name, block=None)