mirror of
https://github.com/jupyter/notebook.git
synced 2025-01-06 11:35:24 +08:00
Merge pull request #7703 from ipython/revert-7554-interact-fix
Revert "Use Output widget with Interact"
This commit is contained in:
commit
274514cf73
@ -14,7 +14,7 @@ from inspect import getcallargs
|
||||
from IPython.core.getipython import get_ipython
|
||||
from IPython.html.widgets import (Widget, Text,
|
||||
FloatSlider, IntSlider, Checkbox, Dropdown,
|
||||
Box, Button, DOMWidget, Output)
|
||||
Box, Button, DOMWidget)
|
||||
from IPython.display import display, clear_output
|
||||
from IPython.utils.py3compat import string_types, unicode_type
|
||||
from IPython.utils.traitlets import HasTraits, Any, Unicode
|
||||
@ -204,15 +204,10 @@ def interactive(__interact_f, **kwargs):
|
||||
if manual:
|
||||
manual_button = Button(description="Run %s" % f.__name__)
|
||||
c.append(manual_button)
|
||||
|
||||
# Use an output widget to capture the output of interact.
|
||||
output = Output()
|
||||
c.append(output)
|
||||
container.children = c
|
||||
|
||||
# Build the callback
|
||||
def call_f(name=None, old=None, new=None):
|
||||
with output:
|
||||
container.kwargs = {}
|
||||
for widget in kwargs_widgets:
|
||||
value = widget.value
|
||||
|
@ -80,7 +80,6 @@ def check_widgets(container, **to_check):
|
||||
# build a widget dictionary, so it matches
|
||||
widgets = {}
|
||||
for w in container.children:
|
||||
if hasattr(w, 'description'):
|
||||
widgets[w.description] = w
|
||||
|
||||
for key, d in to_check.items():
|
||||
@ -139,7 +138,7 @@ def test_single_value_float():
|
||||
def test_single_value_int():
|
||||
for a in (1, 5, -3):
|
||||
c = interactive(f, a=a)
|
||||
nt.assert_equal(len(c.children), 2)
|
||||
nt.assert_equal(len(c.children), 1)
|
||||
w = c.children[0]
|
||||
check_widget(w,
|
||||
cls=widgets.IntSlider,
|
||||
@ -158,7 +157,7 @@ def test_list_tuple_2_int():
|
||||
c = interactive(f, tup=(1,-1))
|
||||
for min, max in [ (0,1), (1,10), (1,2), (-5,5), (-20,-19) ]:
|
||||
c = interactive(f, tup=(min, max), lis=[min, max])
|
||||
nt.assert_equal(len(c.children), 3)
|
||||
nt.assert_equal(len(c.children), 2)
|
||||
d = dict(
|
||||
cls=widgets.IntSlider,
|
||||
min=min,
|
||||
@ -175,7 +174,7 @@ def test_list_tuple_3_int():
|
||||
c = interactive(f, tup=(1,2,-1))
|
||||
for min, max, step in [ (0,2,1), (1,10,2), (1,100,2), (-5,5,4), (-100,-20,4) ]:
|
||||
c = interactive(f, tup=(min, max, step), lis=[min, max, step])
|
||||
nt.assert_equal(len(c.children), 3)
|
||||
nt.assert_equal(len(c.children), 2)
|
||||
d = dict(
|
||||
cls=widgets.IntSlider,
|
||||
min=min,
|
||||
@ -192,7 +191,7 @@ def test_list_tuple_2_float():
|
||||
c = interactive(f, tup=(0.5,-0.5))
|
||||
for min, max in [ (0.5, 1.5), (1.1,10.2), (1,2.2), (-5.,5), (-20,-19.) ]:
|
||||
c = interactive(f, tup=(min, max), lis=[min, max])
|
||||
nt.assert_equal(len(c.children), 3)
|
||||
nt.assert_equal(len(c.children), 2)
|
||||
d = dict(
|
||||
cls=widgets.FloatSlider,
|
||||
min=min,
|
||||
@ -211,7 +210,7 @@ def test_list_tuple_3_float():
|
||||
c = interactive(f, tup=(1,2.,-1.))
|
||||
for min, max, step in [ (0.,2,1), (1,10.,2), (1,100,2.), (-5.,5.,4), (-100,-20.,4.) ]:
|
||||
c = interactive(f, tup=(min, max, step), lis=[min, max, step])
|
||||
nt.assert_equal(len(c.children), 3)
|
||||
nt.assert_equal(len(c.children), 2)
|
||||
d = dict(
|
||||
cls=widgets.FloatSlider,
|
||||
min=min,
|
||||
@ -225,7 +224,7 @@ def test_list_tuple_str():
|
||||
values = ['hello', 'there', 'guy']
|
||||
first = values[0]
|
||||
c = interactive(f, tup=tuple(values), lis=list(values))
|
||||
nt.assert_equal(len(c.children), 3)
|
||||
nt.assert_equal(len(c.children), 2)
|
||||
d = dict(
|
||||
cls=widgets.Dropdown,
|
||||
value=first,
|
||||
@ -472,7 +471,7 @@ def test_call_decorated_kwargs_on_trait_change():
|
||||
|
||||
def test_fixed():
|
||||
c = interactive(f, a=widgets.fixed(5), b='text')
|
||||
nt.assert_equal(len(c.children), 2)
|
||||
nt.assert_equal(len(c.children), 1)
|
||||
w = c.children[0]
|
||||
check_widget(w,
|
||||
cls=widgets.Text,
|
||||
|
@ -34,24 +34,15 @@ class Output(DOMWidget):
|
||||
print('prints to output widget')"""
|
||||
_view_name = Unicode('OutputView', sync=True)
|
||||
|
||||
def __init__(self, *args, **kwargs):
|
||||
super(Output, self).__init__(*args, **kwargs)
|
||||
from IPython import get_ipython
|
||||
ip = get_ipython()
|
||||
if ip is not None and hasattr(ip, 'kernel'):
|
||||
self._kernel = ip.kernel
|
||||
else:
|
||||
self._kernel = None
|
||||
|
||||
def clear_output(self, *pargs, **kwargs):
|
||||
with self:
|
||||
clear_output(*pargs, **kwargs)
|
||||
|
||||
def __enter__(self):
|
||||
"""Called upon entering output widget context manager."""
|
||||
if self._kernel is not None:
|
||||
self._flush()
|
||||
session = self._kernel.session
|
||||
kernel = get_ipython().kernel
|
||||
session = kernel.session
|
||||
send = session.send
|
||||
self._original_send = send
|
||||
self._session = session
|
||||
@ -69,7 +60,7 @@ class Output(DOMWidget):
|
||||
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']:
|
||||
if stream is 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)
|
||||
@ -78,7 +69,6 @@ class Output(DOMWidget):
|
||||
|
||||
def __exit__(self, exception_type, exception_value, traceback):
|
||||
"""Called upon exiting output widget context manager."""
|
||||
if self._kernel is not None:
|
||||
self._flush()
|
||||
self._session.send = self._original_send
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user