##// END OF EJS Templates
worjk latex completion and back
worjk latex completion and back

File last commit:

r21073:ff373955
r21101:c9147225
Show More
comm.py
169 lines | 5.7 KiB | text/x-python | PythonLexer
MinRK
rename widget to comm
r13195 """Base class for a Comm"""
MinRK
apply json_clean to comm_msg content...
r16623 # Copyright (c) IPython Development Team.
# Distributed under the terms of the Modified BSD License.
MinRK
rename widget to comm
r13195
Min RK
make Comm's publishing threadsafe...
r20365 import threading
MinRK
rename widget to comm
r13195 import uuid
Min RK
make Comm's publishing threadsafe...
r20365 from zmq.eventloop.ioloop import IOLoop
MinRK
rename widget to comm
r13195 from IPython.config import LoggingConfigurable
Min RK
remove ipython_kernel.zmq sub-pkg
r20957 from ipython_kernel.kernelbase import Kernel
MinRK
rename widget to comm
r13195
Min RK
import jsonutil from jupyter_client
r21073 from jupyter_client.jsonutil import json_clean
MinRK
rename widget to comm
r13195 from IPython.utils.traitlets import Instance, Unicode, Bytes, Bool, Dict, Any
class Comm(LoggingConfigurable):
Min RK
make Comm's publishing threadsafe...
r20365 """Class for communicating between a Frontend and a Kernel"""
Thomas Kluyver
Make comm manager (mostly) independent of InteractiveShell...
r17964 # If this is instantiated by a non-IPython kernel, shell will be None
shell = Instance('IPython.core.interactiveshell.InteractiveShellABC',
allow_none=True)
Min RK
remove ipython_kernel.zmq sub-pkg
r20957 kernel = Instance('ipython_kernel.kernelbase.Kernel')
Thomas Kluyver
Make comm_manager a property of kernel, not shell
r17987 def _kernel_default(self):
if Kernel.initialized():
return Kernel.instance()
Min RK
bigsplit: ipython_kernel
r20955
MinRK
rename widget to comm
r13195 iopub_socket = Any()
def _iopub_socket_default(self):
Thomas Kluyver
Make comm manager (mostly) independent of InteractiveShell...
r17964 return self.kernel.iopub_socket
Min RK
remove ipython_kernel.zmq sub-pkg
r20957 session = Instance('ipython_kernel.session.Session')
MinRK
rename widget to comm
r13195 def _session_default(self):
Thomas Kluyver
Safeguard against comm instantiation with both session and kernel (corner case)
r18081 if self.kernel is not None:
return self.kernel.session
Min RK
bigsplit: ipython_kernel
r20955
MinRK
s/target/target_name
r13204 target_name = Unicode('comm')
Thomas Kluyver
Support specifying requirejs modules for comm targets
r18467 target_module = Unicode(None, allow_none=True, help="""requirejs module from
which to load comm target.""")
Min RK
bigsplit: ipython_kernel
r20955
MinRK
rename widget to comm
r13195 topic = Bytes()
def _topic_default(self):
return ('comm-%s' % self.comm_id).encode('ascii')
Min RK
bigsplit: ipython_kernel
r20955
MinRK
open is not an event...
r13205 _open_data = Dict(help="data dict, if any, to be included in comm_open")
MinRK
rename widget to comm
r13195 _close_data = Dict(help="data dict, if any, to be included in comm_close")
Min RK
bigsplit: ipython_kernel
r20955
MinRK
rename widget to comm
r13195 _msg_callback = Any()
_close_callback = Any()
Min RK
bigsplit: ipython_kernel
r20955
Jason Grout
Handle some tricky Comm lifecycle issues...
r18454 _closed = Bool(True)
MinRK
rename widget to comm
r13195 comm_id = Unicode()
def _comm_id_default(self):
return uuid.uuid4().hex
Min RK
bigsplit: ipython_kernel
r20955
MinRK
rename widget to comm
r13195 primary = Bool(True, help="Am I the primary or secondary Comm?")
Min RK
bigsplit: ipython_kernel
r20955
MinRK
add target_name as first arg to Comm constructor
r13228 def __init__(self, target_name='', data=None, **kwargs):
if target_name:
kwargs['target_name'] = target_name
MinRK
rename widget to comm
r13195 super(Comm, self).__init__(**kwargs)
if self.primary:
MinRK
open is not an event...
r13205 # I am primary, open my peer.
MinRK
pass whole message to Comm handlers
r13197 self.open(data)
Jason Grout
Handle some tricky Comm lifecycle issues...
r18454 else:
self._closed = False
Min RK
bigsplit: ipython_kernel
r20955
MinRK
support buffers in comm messages...
r18329 def _publish_msg(self, msg_type, data=None, metadata=None, buffers=None, **keys):
MinRK
rename widget to comm
r13195 """Helper for sending a comm message on IOPub"""
Min RK
make Comm's publishing threadsafe...
r20365 if threading.current_thread().name != 'MainThread' and IOLoop.initialized():
# make sure we never send on a zmq socket outside the main IOLoop thread
IOLoop.instance().add_callback(lambda : self._publish_msg(msg_type, data, metadata, buffers, **keys))
return
Thomas Kluyver
Make comm_manager a property of kernel, not shell
r17987 data = {} if data is None else data
metadata = {} if metadata is None else metadata
content = json_clean(dict(data=data, comm_id=self.comm_id, **keys))
self.session.send(self.iopub_socket, msg_type,
content,
metadata=json_clean(metadata),
parent=self.kernel._parent_header,
ident=self.topic,
MinRK
support buffers in comm messages...
r18329 buffers=buffers,
Thomas Kluyver
Make comm_manager a property of kernel, not shell
r17987 )
Min RK
bigsplit: ipython_kernel
r20955
MinRK
rename widget to comm
r13195 def __del__(self):
"""trigger close on gc"""
self.close()
Min RK
bigsplit: ipython_kernel
r20955
MinRK
rename widget to comm
r13195 # publishing messages
Min RK
bigsplit: ipython_kernel
r20955
MinRK
support buffers in comm messages...
r18329 def open(self, data=None, metadata=None, buffers=None):
MinRK
rename widget to comm
r13195 """Open the frontend-side version of this comm"""
if data is None:
data = self._open_data
Thomas Kluyver
Make comm_manager a property of kernel, not shell
r17987 comm_manager = getattr(self.kernel, 'comm_manager', None)
if comm_manager is None:
raise RuntimeError("Comms cannot be opened without a kernel "
"and a comm_manager attached to that kernel.")
comm_manager.register_comm(self)
Jason Grout
Unregister comm if there is an error in publishing the comm open message
r18456 try:
self._publish_msg('comm_open',
data=data, metadata=metadata, buffers=buffers,
Thomas Kluyver
Support specifying requirejs modules for comm targets
r18467 target_name=self.target_name,
target_module=self.target_module,
)
Jason Grout
Unregister comm if there is an error in publishing the comm open message
r18456 self._closed = False
except:
comm_manager.unregister_comm(self)
raise
Min RK
bigsplit: ipython_kernel
r20955
MinRK
support buffers in comm messages...
r18329 def close(self, data=None, metadata=None, buffers=None):
MinRK
rename widget to comm
r13195 """Close the frontend-side version of this comm"""
if self._closed:
# only close once
return
Jason Grout
Handle some tricky Comm lifecycle issues...
r18454 self._closed = True
MinRK
rename widget to comm
r13195 if data is None:
data = self._close_data
MinRK
support buffers in comm messages...
r18329 self._publish_msg('comm_close',
data=data, metadata=metadata, buffers=buffers,
)
Thomas Kluyver
Make comm_manager a property of kernel, not shell
r17987 self.kernel.comm_manager.unregister_comm(self)
Min RK
bigsplit: ipython_kernel
r20955
MinRK
support buffers in comm messages...
r18329 def send(self, data=None, metadata=None, buffers=None):
MinRK
pass whole message to Comm handlers
r13197 """Send a message to the frontend-side version of this comm"""
MinRK
support buffers in comm messages...
r18329 self._publish_msg('comm_msg',
data=data, metadata=metadata, buffers=buffers,
)
Min RK
bigsplit: ipython_kernel
r20955
MinRK
rename widget to comm
r13195 # registering callbacks
Min RK
bigsplit: ipython_kernel
r20955
MinRK
rename widget to comm
r13195 def on_close(self, callback):
"""Register a callback for comm_close
Min RK
bigsplit: ipython_kernel
r20955
MinRK
rename widget to comm
r13195 Will be called with the `data` of the close message.
Min RK
bigsplit: ipython_kernel
r20955
MinRK
rename widget to comm
r13195 Call `on_close(None)` to disable an existing callback.
"""
self._close_callback = callback
Min RK
bigsplit: ipython_kernel
r20955
MinRK
rename widget to comm
r13195 def on_msg(self, callback):
"""Register a callback for comm_msg
Min RK
bigsplit: ipython_kernel
r20955
MinRK
rename widget to comm
r13195 Will be called with the `data` of any comm_msg messages.
Min RK
bigsplit: ipython_kernel
r20955
MinRK
rename widget to comm
r13195 Call `on_msg(None)` to disable an existing callback.
"""
self._msg_callback = callback
Min RK
bigsplit: ipython_kernel
r20955
MinRK
rename widget to comm
r13195 # handling of incoming messages
Min RK
bigsplit: ipython_kernel
r20955
MinRK
pass whole message to Comm handlers
r13197 def handle_close(self, msg):
MinRK
rename widget to comm
r13195 """Handle a comm_close message"""
MinRK
pass whole message to Comm handlers
r13197 self.log.debug("handle_close[%s](%s)", self.comm_id, msg)
MinRK
rename widget to comm
r13195 if self._close_callback:
MinRK
pass whole message to Comm handlers
r13197 self._close_callback(msg)
Min RK
bigsplit: ipython_kernel
r20955
MinRK
pass whole message to Comm handlers
r13197 def handle_msg(self, msg):
MinRK
rename widget to comm
r13195 """Handle a comm_msg message"""
MinRK
pass whole message to Comm handlers
r13197 self.log.debug("handle_msg[%s](%s)", self.comm_id, msg)
MinRK
rename widget to comm
r13195 if self._msg_callback:
Thomas Kluyver
Make comm manager (mostly) independent of InteractiveShell...
r17964 if self.shell:
self.shell.events.trigger('pre_execute')
MinRK
pass whole message to Comm handlers
r13197 self._msg_callback(msg)
Thomas Kluyver
Make comm manager (mostly) independent of InteractiveShell...
r17964 if self.shell:
self.shell.events.trigger('post_execute')
MinRK
rename widget to comm
r13195
__all__ = ['Comm']