Show More
@@ -14,7 +14,7 b' from inspect import getcallargs' | |||
|
14 | 14 | from IPython.core.getipython import get_ipython |
|
15 | 15 | from IPython.html.widgets import (Widget, Text, |
|
16 | 16 | FloatSlider, IntSlider, Checkbox, Dropdown, |
|
17 |
Box, Button, DOMWidget |
|
|
17 | Box, Button, DOMWidget) | |
|
18 | 18 | from IPython.display import display, clear_output |
|
19 | 19 | from IPython.utils.py3compat import string_types, unicode_type |
|
20 | 20 | from IPython.utils.traitlets import HasTraits, Any, Unicode |
@@ -204,34 +204,29 b' def interactive(__interact_f, **kwargs):' | |||
|
204 | 204 | if manual: |
|
205 | 205 | manual_button = Button(description="Run %s" % f.__name__) |
|
206 | 206 | c.append(manual_button) |
|
207 | ||
|
208 | # Use an output widget to capture the output of interact. | |
|
209 | output = Output() | |
|
210 | c.append(output) | |
|
211 | 207 | container.children = c |
|
212 | 208 | |
|
213 | 209 | # Build the callback |
|
214 | 210 | def call_f(name=None, old=None, new=None): |
|
215 | with output: | |
|
216 | container.kwargs = {} | |
|
217 | for widget in kwargs_widgets: | |
|
218 | value = widget.value | |
|
219 | container.kwargs[widget._kwarg] = value | |
|
220 | if co: | |
|
221 | clear_output(wait=True) | |
|
211 | container.kwargs = {} | |
|
212 | for widget in kwargs_widgets: | |
|
213 | value = widget.value | |
|
214 | container.kwargs[widget._kwarg] = value | |
|
215 | if co: | |
|
216 | clear_output(wait=True) | |
|
217 | if manual: | |
|
218 | manual_button.disabled = True | |
|
219 | try: | |
|
220 | container.result = f(**container.kwargs) | |
|
221 | except Exception as e: | |
|
222 | ip = get_ipython() | |
|
223 | if ip is None: | |
|
224 | container.log.warn("Exception in interact callback: %s", e, exc_info=True) | |
|
225 | else: | |
|
226 | ip.showtraceback() | |
|
227 | finally: | |
|
222 | 228 | if manual: |
|
223 |
manual_button.disabled = |
|
|
224 | try: | |
|
225 | container.result = f(**container.kwargs) | |
|
226 | except Exception as e: | |
|
227 | ip = get_ipython() | |
|
228 | if ip is None: | |
|
229 | container.log.warn("Exception in interact callback: %s", e, exc_info=True) | |
|
230 | else: | |
|
231 | ip.showtraceback() | |
|
232 | finally: | |
|
233 | if manual: | |
|
234 | manual_button.disabled = False | |
|
229 | manual_button.disabled = False | |
|
235 | 230 | |
|
236 | 231 | # Wire up the widgets |
|
237 | 232 | # If we are doing manual running, the callback is only triggered by the button |
@@ -80,8 +80,7 b' def check_widgets(container, **to_check):' | |||
|
80 | 80 | # build a widget dictionary, so it matches |
|
81 | 81 | widgets = {} |
|
82 | 82 | for w in container.children: |
|
83 |
|
|
|
84 | widgets[w.description] = w | |
|
83 | widgets[w.description] = w | |
|
85 | 84 | |
|
86 | 85 | for key, d in to_check.items(): |
|
87 | 86 | nt.assert_in(key, widgets) |
@@ -139,7 +138,7 b' def test_single_value_float():' | |||
|
139 | 138 | def test_single_value_int(): |
|
140 | 139 | for a in (1, 5, -3): |
|
141 | 140 | c = interactive(f, a=a) |
|
142 |
nt.assert_equal(len(c.children), |
|
|
141 | nt.assert_equal(len(c.children), 1) | |
|
143 | 142 | w = c.children[0] |
|
144 | 143 | check_widget(w, |
|
145 | 144 | cls=widgets.IntSlider, |
@@ -158,7 +157,7 b' def test_list_tuple_2_int():' | |||
|
158 | 157 | c = interactive(f, tup=(1,-1)) |
|
159 | 158 | for min, max in [ (0,1), (1,10), (1,2), (-5,5), (-20,-19) ]: |
|
160 | 159 | c = interactive(f, tup=(min, max), lis=[min, max]) |
|
161 |
nt.assert_equal(len(c.children), |
|
|
160 | nt.assert_equal(len(c.children), 2) | |
|
162 | 161 | d = dict( |
|
163 | 162 | cls=widgets.IntSlider, |
|
164 | 163 | min=min, |
@@ -175,7 +174,7 b' def test_list_tuple_3_int():' | |||
|
175 | 174 | c = interactive(f, tup=(1,2,-1)) |
|
176 | 175 | for min, max, step in [ (0,2,1), (1,10,2), (1,100,2), (-5,5,4), (-100,-20,4) ]: |
|
177 | 176 | c = interactive(f, tup=(min, max, step), lis=[min, max, step]) |
|
178 |
nt.assert_equal(len(c.children), |
|
|
177 | nt.assert_equal(len(c.children), 2) | |
|
179 | 178 | d = dict( |
|
180 | 179 | cls=widgets.IntSlider, |
|
181 | 180 | min=min, |
@@ -192,7 +191,7 b' def test_list_tuple_2_float():' | |||
|
192 | 191 | c = interactive(f, tup=(0.5,-0.5)) |
|
193 | 192 | for min, max in [ (0.5, 1.5), (1.1,10.2), (1,2.2), (-5.,5), (-20,-19.) ]: |
|
194 | 193 | c = interactive(f, tup=(min, max), lis=[min, max]) |
|
195 |
nt.assert_equal(len(c.children), |
|
|
194 | nt.assert_equal(len(c.children), 2) | |
|
196 | 195 | d = dict( |
|
197 | 196 | cls=widgets.FloatSlider, |
|
198 | 197 | min=min, |
@@ -211,7 +210,7 b' def test_list_tuple_3_float():' | |||
|
211 | 210 | c = interactive(f, tup=(1,2.,-1.)) |
|
212 | 211 | for min, max, step in [ (0.,2,1), (1,10.,2), (1,100,2.), (-5.,5.,4), (-100,-20.,4.) ]: |
|
213 | 212 | c = interactive(f, tup=(min, max, step), lis=[min, max, step]) |
|
214 |
nt.assert_equal(len(c.children), |
|
|
213 | nt.assert_equal(len(c.children), 2) | |
|
215 | 214 | d = dict( |
|
216 | 215 | cls=widgets.FloatSlider, |
|
217 | 216 | min=min, |
@@ -225,7 +224,7 b' def test_list_tuple_str():' | |||
|
225 | 224 | values = ['hello', 'there', 'guy'] |
|
226 | 225 | first = values[0] |
|
227 | 226 | c = interactive(f, tup=tuple(values), lis=list(values)) |
|
228 |
nt.assert_equal(len(c.children), |
|
|
227 | nt.assert_equal(len(c.children), 2) | |
|
229 | 228 | d = dict( |
|
230 | 229 | cls=widgets.Dropdown, |
|
231 | 230 | value=first, |
@@ -472,7 +471,7 b' def test_call_decorated_kwargs_on_trait_change():' | |||
|
472 | 471 | |
|
473 | 472 | def test_fixed(): |
|
474 | 473 | c = interactive(f, a=widgets.fixed(5), b='text') |
|
475 |
nt.assert_equal(len(c.children), |
|
|
474 | nt.assert_equal(len(c.children), 1) | |
|
476 | 475 | w = c.children[0] |
|
477 | 476 | check_widget(w, |
|
478 | 477 | cls=widgets.Text, |
@@ -34,53 +34,43 b' class Output(DOMWidget):' | |||
|
34 | 34 | print('prints to output widget')""" |
|
35 | 35 | _view_name = Unicode('OutputView', sync=True) |
|
36 | 36 | |
|
37 | def __init__(self, *args, **kwargs): | |
|
38 | super(Output, self).__init__(*args, **kwargs) | |
|
39 | from IPython import get_ipython | |
|
40 | ip = get_ipython() | |
|
41 | if ip is not None and hasattr(ip, 'kernel'): | |
|
42 | self._kernel = ip.kernel | |
|
43 | else: | |
|
44 | self._kernel = None | |
|
45 | ||
|
46 | 37 | def clear_output(self, *pargs, **kwargs): |
|
47 | 38 | with self: |
|
48 | 39 | clear_output(*pargs, **kwargs) |
|
49 | 40 | |
|
50 | 41 | def __enter__(self): |
|
51 | 42 | """Called upon entering output widget context manager.""" |
|
52 | if self._kernel is not None: | |
|
53 | self._flush() | |
|
54 |
|
|
|
55 |
|
|
|
56 |
|
|
|
57 |
|
|
|
58 | ||
|
59 |
|
|
|
60 |
|
|
|
61 | ||
|
62 |
|
|
|
63 |
|
|
|
64 |
|
|
|
65 |
|
|
|
66 |
|
|
|
67 |
|
|
|
68 |
|
|
|
69 |
|
|
|
70 | ||
|
71 |
|
|
|
72 |
|
|
|
73 |
|
|
|
74 |
|
|
|
75 |
|
|
|
76 | ||
|
77 |
|
|
|
43 | self._flush() | |
|
44 | kernel = get_ipython().kernel | |
|
45 | session = kernel.session | |
|
46 | send = session.send | |
|
47 | self._original_send = send | |
|
48 | self._session = session | |
|
49 | ||
|
50 | def send_hook(stream, msg_or_type, content=None, parent=None, ident=None, | |
|
51 | buffers=None, track=False, header=None, metadata=None): | |
|
52 | ||
|
53 | # Handle both prebuild messages and unbuilt messages. | |
|
54 | if isinstance(msg_or_type, (Message, dict)): | |
|
55 | msg_type = msg_or_type['msg_type'] | |
|
56 | msg = dict(msg_or_type) | |
|
57 | else: | |
|
58 | msg_type = msg_or_type | |
|
59 | msg = session.msg(msg_type, content=content, parent=parent, | |
|
60 | header=header, metadata=metadata) | |
|
61 | ||
|
62 | # If this is a message type that we want to forward, forward it. | |
|
63 | if stream is kernel.iopub_socket and msg_type in ['clear_output', 'stream', 'display_data']: | |
|
64 | self.send(msg) | |
|
65 | else: | |
|
66 | send(stream, msg, ident=ident, buffers=buffers, track=track) | |
|
67 | ||
|
68 | session.send = send_hook | |
|
78 | 69 | |
|
79 | 70 | def __exit__(self, exception_type, exception_value, traceback): |
|
80 | 71 | """Called upon exiting output widget context manager.""" |
|
81 | if self._kernel is not None: | |
|
82 | self._flush() | |
|
83 | self._session.send = self._original_send | |
|
72 | self._flush() | |
|
73 | self._session.send = self._original_send | |
|
84 | 74 | |
|
85 | 75 | def _flush(self): |
|
86 | 76 | """Flush stdout and stderr buffers.""" |
General Comments 0
You need to be logged in to leave comments.
Login now