Show More
@@ -164,20 +164,13 b' def display(*objs, **kwargs):' | |||||
164 | format = InteractiveShell.instance().display_formatter.format |
|
164 | format = InteractiveShell.instance().display_formatter.format | |
165 |
|
165 | |||
166 | for obj in objs: |
|
166 | for obj in objs: | |
167 |
|
||||
168 | # If _ipython_display_ is defined, use that to display this object. |
|
|||
169 | display_method = _safe_get_formatter_method(obj, '_ipython_display_') |
|
|||
170 | if display_method is not None: |
|
|||
171 | try: |
|
|||
172 | display_method(**kwargs) |
|
|||
173 | except NotImplementedError: |
|
|||
174 | pass |
|
|||
175 | else: |
|
|||
176 | continue |
|
|||
177 | if raw: |
|
167 | if raw: | |
178 | publish_display_data(data=obj, metadata=metadata) |
|
168 | publish_display_data(data=obj, metadata=metadata) | |
179 | else: |
|
169 | else: | |
180 | format_dict, md_dict = format(obj, include=include, exclude=exclude) |
|
170 | format_dict, md_dict = format(obj, include=include, exclude=exclude) | |
|
171 | if not format_dict: | |||
|
172 | # nothing to display (e.g. _ipython_display_ took over) | |||
|
173 | continue | |||
181 | if metadata: |
|
174 | if metadata: | |
182 | # kwarg-specified metadata gets precedence |
|
175 | # kwarg-specified metadata gets precedence | |
183 | _merge(md_dict, metadata) |
|
176 | _merge(md_dict, metadata) |
@@ -221,19 +221,12 b' class DisplayHook(Configurable):' | |||||
221 | """ |
|
221 | """ | |
222 | self.check_for_underscore() |
|
222 | self.check_for_underscore() | |
223 | if result is not None and not self.quiet(): |
|
223 | if result is not None and not self.quiet(): | |
224 | # If _ipython_display_ is defined, use that to display this object. |
|
|||
225 | display_method = _safe_get_formatter_method(result, '_ipython_display_') |
|
|||
226 | if display_method is not None: |
|
|||
227 | try: |
|
|||
228 | return display_method() |
|
|||
229 | except NotImplementedError: |
|
|||
230 | pass |
|
|||
231 |
|
||||
232 | self.start_displayhook() |
|
224 | self.start_displayhook() | |
233 | self.write_output_prompt() |
|
225 | self.write_output_prompt() | |
234 | format_dict, md_dict = self.compute_format_data(result) |
|
226 | format_dict, md_dict = self.compute_format_data(result) | |
235 | self.write_format_data(format_dict, md_dict) |
|
|||
236 | self.update_user_ns(result) |
|
227 | self.update_user_ns(result) | |
|
228 | if format_dict: | |||
|
229 | self.write_format_data(format_dict, md_dict) | |||
237 | self.log_output(format_dict) |
|
230 | self.log_output(format_dict) | |
238 | self.finish_displayhook() |
|
231 | self.finish_displayhook() | |
239 |
|
232 |
@@ -24,6 +24,7 b' from IPython.core.getipython import get_ipython' | |||||
24 | from IPython.lib import pretty |
|
24 | from IPython.lib import pretty | |
25 | from IPython.utils.traitlets import ( |
|
25 | from IPython.utils.traitlets import ( | |
26 | Bool, Dict, Integer, Unicode, CUnicode, ObjectName, List, |
|
26 | Bool, Dict, Integer, Unicode, CUnicode, ObjectName, List, | |
|
27 | Instance, | |||
27 | ) |
|
28 | ) | |
28 | from IPython.utils.py3compat import ( |
|
29 | from IPython.utils.py3compat import ( | |
29 | unicode_to_str, with_metaclass, PY3, string_types, unicode_type, |
|
30 | unicode_to_str, with_metaclass, PY3, string_types, unicode_type, | |
@@ -89,6 +90,10 b' class DisplayFormatter(Configurable):' | |||||
89 | else: |
|
90 | else: | |
90 | formatter.enabled = False |
|
91 | formatter.enabled = False | |
91 |
|
92 | |||
|
93 | self_formatter = Instance(__name__ +'.SelfDisplayingFormatter') | |||
|
94 | def _self_formatter_default(self): | |||
|
95 | return SelfDisplayingFormatter(parent=self) | |||
|
96 | ||||
92 | # A dict of formatter whose keys are format types (MIME types) and whose |
|
97 | # A dict of formatter whose keys are format types (MIME types) and whose | |
93 | # values are subclasses of BaseFormatter. |
|
98 | # values are subclasses of BaseFormatter. | |
94 | formatters = Dict() |
|
99 | formatters = Dict() | |
@@ -159,6 +164,10 b' class DisplayFormatter(Configurable):' | |||||
159 | format_dict = {} |
|
164 | format_dict = {} | |
160 | md_dict = {} |
|
165 | md_dict = {} | |
161 |
|
166 | |||
|
167 | if self.self_formatter(obj): | |||
|
168 | # object handled itself, don't proceed | |||
|
169 | return {}, {} | |||
|
170 | ||||
162 | for format_type, formatter in self.formatters.items(): |
|
171 | for format_type, formatter in self.formatters.items(): | |
163 | if include and format_type not in include: |
|
172 | if include and format_type not in include: | |
164 | continue |
|
173 | continue | |
@@ -831,6 +840,40 b' class PDFFormatter(BaseFormatter):' | |||||
831 |
|
840 | |||
832 | _return_type = (bytes, unicode_type) |
|
841 | _return_type = (bytes, unicode_type) | |
833 |
|
842 | |||
|
843 | class SelfDisplayingFormatter(BaseFormatter): | |||
|
844 | """A Formatter for objects that know how to display themselves. | |||
|
845 | ||||
|
846 | To define the callables that compute the representation of your | |||
|
847 | objects, define a :meth:`_ipython_display_` method or use the :meth:`for_type` | |||
|
848 | or :meth:`for_type_by_name` methods to register functions that handle | |||
|
849 | this. Unlike mime-type displays, this method should not return anything, | |||
|
850 | instead calling any appropriate display methods itself. | |||
|
851 | ||||
|
852 | This display formatter has highest priority. | |||
|
853 | If it fires, no other display formatter will be called. | |||
|
854 | """ | |||
|
855 | print_method = ObjectName('_ipython_display_') | |||
|
856 | _return_type = (type(None), bool) | |||
|
857 | ||||
|
858 | ||||
|
859 | @warn_format_error | |||
|
860 | def __call__(self, obj): | |||
|
861 | """Compute the format for an object.""" | |||
|
862 | if self.enabled: | |||
|
863 | # lookup registered printer | |||
|
864 | try: | |||
|
865 | printer = self.lookup(obj) | |||
|
866 | except KeyError: | |||
|
867 | pass | |||
|
868 | else: | |||
|
869 | printer(obj) | |||
|
870 | return True | |||
|
871 | # Finally look for special method names | |||
|
872 | method = _safe_get_formatter_method(obj, self.print_method) | |||
|
873 | if method is not None: | |||
|
874 | method() | |||
|
875 | return True | |||
|
876 | ||||
834 |
|
877 | |||
835 | FormatterABC.register(BaseFormatter) |
|
878 | FormatterABC.register(BaseFormatter) | |
836 | FormatterABC.register(PlainTextFormatter) |
|
879 | FormatterABC.register(PlainTextFormatter) | |
@@ -843,6 +886,7 b' FormatterABC.register(JPEGFormatter)' | |||||
843 | FormatterABC.register(LatexFormatter) |
|
886 | FormatterABC.register(LatexFormatter) | |
844 | FormatterABC.register(JSONFormatter) |
|
887 | FormatterABC.register(JSONFormatter) | |
845 | FormatterABC.register(JavascriptFormatter) |
|
888 | FormatterABC.register(JavascriptFormatter) | |
|
889 | FormatterABC.register(SelfDisplayingFormatter) | |||
846 |
|
890 | |||
847 |
|
891 | |||
848 | def format_display_data(obj, include=None, exclude=None): |
|
892 | def format_display_data(obj, include=None, exclude=None): |
General Comments 0
You need to be logged in to leave comments.
Login now