##// END OF EJS Templates
invoke css
invoke css

File last commit:

r20234:79b63be3
r20314:7b103415
Show More
widget_output.py
88 lines | 3.1 KiB | text/x-python | PythonLexer
Jonathan Frederic
Output Widget
r18953 """Output class.
Represents a widget that can be used to display output within the widget area.
"""
# Copyright (c) IPython Development Team.
# Distributed under the terms of the Modified BSD License.
from .widget import DOMWidget
import sys
from IPython.utils.traitlets import Unicode, List
from IPython.display import clear_output
Jonathan Frederic
Add doc string to Output widget
r18960 from IPython.testing.skipdoctest import skip_doctest
Jonathan Frederic
Add support for Message class.
r20073 from IPython.kernel.zmq.session import Message
Jonathan Frederic
Output Widget
r18953
Jonathan Frederic
Add doc string to Output widget
r18960 @skip_doctest
Jonathan Frederic
Output Widget
r18953 class Output(DOMWidget):
Jonathan Frederic
Add doc string to Output widget
r18960 """Widget used as a context manager to display output.
This widget can capture and display stdout, stderr, and rich output. To use
it, create an instance of it and display it. Then use it as a context
manager. Any output produced while in it's context will be captured and
displayed in it instead of the standard output area.
Example
from IPython.html import widgets
from IPython.display import display
out = widgets.Output()
display(out)
print('prints to output area')
with out:
print('prints to output widget')"""
Jonathan Frederic
Output Widget
r18953 _view_name = Unicode('OutputView', sync=True)
Jonathan Frederic
Move get_ipython call into output widget constructor
r20102 def __init__(self, *args, **kwargs):
super(Output, self).__init__(*args, **kwargs)
Jonathan Frederic
Import `get_ipython` function
r20203 from IPython import get_ipython
Jonathan Frederic
Fix interact test
r20234 ip = get_ipython()
if ip is not None and hasattr(ip, 'kernel'):
self._kernel = ip.kernel
else:
self._kernel = None
Jonathan Frederic
Move get_ipython call into output widget constructor
r20102
Jonathan Frederic
Output Widget
r18953 def clear_output(self, *pargs, **kwargs):
with self:
clear_output(*pargs, **kwargs)
def __enter__(self):
Jonathan Frederic
Finished changing output widget logic.
r20060 """Called upon entering output widget context manager."""
Jonathan Frederic
Fix interact test
r20234 if self._kernel is not None:
self._flush()
session = self._kernel.session
send = session.send
self._original_send = send
self._session = session
def send_hook(stream, msg_or_type, content=None, parent=None, ident=None,
buffers=None, track=False, header=None, metadata=None):
# Handle both prebuild messages and unbuilt messages.
if isinstance(msg_or_type, (Message, dict)):
msg_type = msg_or_type['msg_type']
msg = dict(msg_or_type)
else:
msg_type = msg_or_type
msg = session.msg(msg_type, content=content, parent=parent,
header=header, metadata=metadata)
# If this is a message type that we want to forward, forward it.
if stream is self._kernel.iopub_socket and msg_type in ['clear_output', 'stream', 'display_data']:
self.send(msg)
else:
send(stream, msg, ident=ident, buffers=buffers, track=track)
session.send = send_hook
Jonathan Frederic
Output Widget
r18953
def __exit__(self, exception_type, exception_value, traceback):
Jonathan Frederic
Finished changing output widget logic.
r20060 """Called upon exiting output widget context manager."""
Jonathan Frederic
Fix interact test
r20234 if self._kernel is not None:
self._flush()
self._session.send = self._original_send
Jonathan Frederic
Output Widget
r18953
def _flush(self):
Jonathan Frederic
Finished changing output widget logic.
r20060 """Flush stdout and stderr buffers."""
Jonathan Frederic
Output Widget
r18953 sys.stdout.flush()
sys.stderr.flush()