##// END OF EJS Templates
Revert "Ruffisation"
Revert "Ruffisation"

File last commit:

r28959:969bfa68
r29045:40a85cce
Show More
formatters.py
1090 lines | 35.6 KiB | text/x-python | PythonLexer
Robert Kern
ENH: Implement and test the default pretty formatter.
r3209 # -*- coding: utf-8 -*-
Brian Granger
Display system is fully working now....
r3278 """Display formatters.
M Bussonnier
Some documentations about custom formatters
r28959 This module defines the base instances in order to implement custom
formatters/mimetypes
got objects:
As we want to see internal IPython working we are going to use the following
function to diaply objects instead of the normal print or display method:
>>> ip = get_ipython()
>>> ip.display_formatter.format(...)
({'text/plain': 'Ellipsis'}, {})
This return a tuple with the mimebumdle for the current object, and the
associated metadata.
We can now define our own formatter and register it:
>>> from IPython.core.formatters import BaseFormatter, FormatterABC
>>> class LLMFormatter(BaseFormatter):
...
... format_type = 'x-vendor/llm'
... print_method = '_repr_llm_'
... _return_type = (dict, str)
>>> llm_formatter = LLMFormatter(parent=ip.display_formatter)
>>> ip.display_formatter.formatters[LLMFormatter.format_type] = llm_formatter
Now any class that define `_repr_llm_` will return a x-vendor/llm as part of
it's display data:
>>> class A:
...
... def _repr_llm_(self, *kwargs):
... return 'This a A'
...
>>> ip.display_formatter.format(A())
({'text/plain': '<IPython.core.formatters.A at ...>', 'x-vendor/llm': 'This a A'}, {})
As usual, you can register methods for third party types (see
:ref:`third_party_formatting`)
>>> def llm_int(obj):
... return 'This is the integer %s, in between %s and %s'%(obj, obj-1, obj+1)
>>> llm_formatter.for_type(int, llm_int)
>>> ip.display_formatter.format(42)
({'text/plain': '42', 'x-vendor/llm': 'This is the integer 42, in between 41 and 43'}, {})
Thomas Kluyver
Only include inheritance diagram where it's useful.
r8795 Inheritance diagram:
.. inheritance-diagram:: IPython.core.formatters
:parts: 3
Robert Kern
ENH: Implement and test the default pretty formatter.
r3209 """
MinRK
show tracebacks for errors in formatters...
r18025 # Copyright (c) IPython Development Team.
# Distributed under the terms of the Modified BSD License.
Brian Granger
More improvements to the display system....
r3279
Robert Kern
ENH: Implement and test the default pretty formatter.
r3209 import abc
MinRK
reorder stdlib imports...
r3352 import sys
Thomas Kluyver
Fix static analysis errors in IPython.core.formatters...
r19105 import traceback
MinRK
add missing warnings import
r9813 import warnings
Srinivas Reddy Thatiparthy
remove CUnicodeIO and replace it with StringIO
r23119 from io import StringIO
Robert Kern
ENH: Implement and test the default pretty formatter.
r3209
MinRK
remove decorator from external
r20813 from decorator import decorator
MinRK
warn on failed formatter calls
r13977
Min RK
update dependency imports...
r21253 from traitlets.config.configurable import Configurable
Srinivas Reddy Thatiparthy
Change absolute imports to relative imports to facilitate processes embedding kernel or debugger
r25227 from .getipython import get_ipython
from ..utils.sentinel import Sentinel
from ..utils.dir2 import get_real_method
from ..lib import pretty
Min RK
update dependency imports...
r21253 from traitlets import (
MinRK
add DisplayFormatter.active_types...
r9811 Bool, Dict, Integer, Unicode, CUnicode, ObjectName, List,
Min RK
s/SelfDisplaying/IPythonDisplay/
r19382 ForwardDeclaredInstance,
Min RK
adopt traitlets 4.2 API...
r22340 default, observe,
MinRK
add DisplayFormatter.active_types...
r9811 )
Thomas Kluyver
Use StringIO.StringIO on Python 2....
r13366
Matthias Bussonnier
MAINT: refactor/please mypy....
r28167 from typing import Any
Robert Kern
ENH: Implement and test the default pretty formatter.
r3209
Brian Granger
Display system is fully working now....
r3278 class DisplayFormatter(Configurable):
Min RK
adopt traitlets 4.2 API...
r22340 active_types = List(Unicode(),
MinRK
expand active_types help string
r10182 help="""List of currently active mime-types to display.
You can use this to set a white-list for formats to display.
M Bussonnier
Some documentations about custom formatters
r28959
MinRK
expand active_types help string
r10182 Most users will not need to change this value.
M Bussonnier
Some documentations about custom formatters
r28959 """,
).tag(config=True)
Min RK
adopt traitlets 4.2 API...
r22340
@default('active_types')
MinRK
add DisplayFormatter.active_types...
r9811 def _active_types_default(self):
return self.format_types
Min RK
adopt traitlets 4.2 API...
r22340
@observe('active_types')
def _active_types_changed(self, change):
MinRK
use items, not keys, duh
r10130 for key, formatter in self.formatters.items():
Min RK
adopt traitlets 4.2 API...
r22340 if key in change['new']:
MinRK
implement active_types via formatter.enabled attributes...
r10128 formatter.enabled = True
else:
formatter.enabled = False
Min RK
Define `_repr_mimebundle_`...
r23578
Matthias Bussonnier
Some minimal typing and removal of allow-none
r28628 ipython_display_formatter = ForwardDeclaredInstance("FormatterABC") # type: ignore
Matthias Bussonnier
fix types in utils/text.py
r28626
@default("ipython_display_formatter")
Min RK
adopt traitlets 4.2 API...
r22340 def _default_formatter(self):
Min RK
s/SelfDisplaying/IPythonDisplay/
r19382 return IPythonDisplayFormatter(parent=self)
Min RK
Define `_repr_mimebundle_`...
r23578
Matthias Bussonnier
Some minimal typing and removal of allow-none
r28628 mimebundle_formatter = ForwardDeclaredInstance("FormatterABC") # type: ignore
Matthias Bussonnier
fix types in utils/text.py
r28626
@default("mimebundle_formatter")
Min RK
Define `_repr_mimebundle_`...
r23578 def _default_mime_formatter(self):
return MimeBundleFormatter(parent=self)
Brian Granger
Display system is fully working now....
r3278 # A dict of formatter whose keys are format types (MIME types) and whose
# values are subclasses of BaseFormatter.
MinRK
DisplayFormatter.formatters should not be configurable...
r5228 formatters = Dict()
Matthias Bussonnier
fix types in utils/text.py
r28626
@default("formatters")
Brian Granger
Display system is fully working now....
r3278 def _formatters_default(self):
"""Activate the default formatters."""
formatter_classes = [
PlainTextFormatter,
HTMLFormatter,
Andrew Jesaitis
Adds markdown formatting to output cells
r16364 MarkdownFormatter,
Brian Granger
Display system is fully working now....
r3278 SVGFormatter,
PNGFormatter,
Brian E. Granger
Adding PDFFormatter and kernel side handling of PDF display data.
r15121 PDFFormatter,
Brian E. Granger
Finishing display system work....
r4528 JPEGFormatter,
Brian Granger
Display system is fully working now....
r3278 LatexFormatter,
Brian Granger
Renaming the special methods of the formatters....
r3878 JSONFormatter,
JavascriptFormatter
Brian Granger
Display system is fully working now....
r3278 ]
d = {}
for cls in formatter_classes:
MinRK
use `parent=self` throughout IPython...
r11064 f = cls(parent=self)
Brian Granger
Display system is fully working now....
r3278 d[f.format_type] = f
return d
def format(self, obj, include=None, exclude=None):
"""Return a format data dict for an object.
By default all format types will be computed.
Matthias Bussonnier
Respect the ignore and include keyword in display
r23612 The following MIME types are usually implemented:
Brian Granger
Display system is fully working now....
r3278
* text/plain
* text/html
Andrew Jesaitis
Adds markdown formatting to output cells
r16364 * text/markdown
Brian Granger
Display system is fully working now....
r3278 * text/latex
* application/json
Brian E. Granger
Updates to the display system....
r4526 * application/javascript
Brian E. Granger
Adding PDFFormatter and kernel side handling of PDF display data.
r15121 * application/pdf
Brian Granger
Display system is fully working now....
r3278 * image/png
Brian E. Granger
Finishing display system work....
r4528 * image/jpeg
Brian E. Granger
Updates to the display system....
r4526 * image/svg+xml
Brian Granger
Display system is fully working now....
r3278
Parameters
----------
obj : object
The Python object whose format data will be computed.
Matthias Bussonnier
Respect the ignore and include keyword in display
r23612 include : list, tuple or set; optional
Brian Granger
Fixed docstring in formatter.py.
r3282 A list of format type strings (MIME types) to include in the
format data dict. If this is set *only* the format types included
in this list will be computed.
Matthias Bussonnier
Respect the ignore and include keyword in display
r23612 exclude : list, tuple or set; optional
MinRK
add DisplayFormatter.active_types...
r9811 A list of format type string (MIME types) to exclude in the format
Brian Granger
Fixed docstring in formatter.py.
r3282 data dict. If this is set all format types will be computed,
except for those included in this argument.
Matthias Bussonnier
Respect the ignore and include keyword in display
r23612 Mimetypes present in exclude will take precedence over the ones in include
Brian Granger
Display system is fully working now....
r3278
Returns
-------
MinRK
format-related docstrings!
r10446 (format_dict, metadata_dict) : tuple of two dicts
format_dict is a dictionary of key/value pairs, one of each format that was
Brian Granger
Display system is fully working now....
r3278 generated for the object. The keys are the format types, which
will usually be MIME type strings and the values and JSON'able
data structure containing the raw data for the representation in
that format.
Matthias Bussonnier
DOC: More autoreformatting of docstrings....
r26498
MinRK
format-related docstrings!
r10446 metadata_dict is a dictionary of metadata about each mime-type output.
Its keys will be a strict subset of the keys in format_dict.
Matthias Bussonnier
Respect the ignore and include keyword in display
r23612
Notes
-----
If an object implement `_repr_mimebundle_` as well as various
`_repr_*_`, the data returned by `_repr_mimebundle_` will take
precedence and the corresponding `_repr_*_` for this mimetype will
not be called.
Brian Granger
Display system is fully working now....
r3278 """
format_dict = {}
MinRK
allow formatters to publish metadata...
r10443 md_dict = {}
M Bussonnier
Some documentations about custom formatters
r28959
Min RK
s/SelfDisplaying/IPythonDisplay/
r19382 if self.ipython_display_formatter(obj):
Min RK
add SelfDisplayingFormatter...
r19381 # object handled itself, don't proceed
return {}, {}
Min RK
Define `_repr_mimebundle_`...
r23578
Matthias Bussonnier
Pass down include and exclude as kwarg to repr_mimebundle
r23618 format_dict, md_dict = self.mimebundle_formatter(obj, include=include, exclude=exclude)
Min RK
Define `_repr_mimebundle_`...
r23578
Matthias Bussonnier
Respect the ignore and include keyword in display
r23612 if format_dict or md_dict:
if include:
format_dict = {k:v for k,v in format_dict.items() if k in include}
md_dict = {k:v for k,v in md_dict.items() if k in include}
if exclude:
format_dict = {k:v for k,v in format_dict.items() if k not in exclude}
md_dict = {k:v for k,v in md_dict.items() if k not in exclude}
Brian Granger
Display system is fully working now....
r3278 for format_type, formatter in self.formatters.items():
Min RK
Define `_repr_mimebundle_`...
r23578 if format_type in format_dict:
Min RK
preserve priority of user-registered per-mime renderers...
r23839 # already got it from mimebundle, maybe don't render again.
# exception: manually registered per-mime renderer
# check priority:
# 1. user-registered per-mime formatter
# 2. mime-bundle (user-registered or repr method)
# 3. default per-mime formatter (e.g. repr method)
try:
formatter.lookup(obj)
except KeyError:
# no special formatter, use mime-bundle-provided value
continue
MinRK
simplify include/exclude conditions
r10129 if include and format_type not in include:
continue
if exclude and format_type in exclude:
MinRK
add DisplayFormatter.active_types...
r9811 continue
M Bussonnier
Some documentations about custom formatters
r28959
MinRK
allow formatters to publish metadata...
r10443 md = None
Brian Granger
Display system is fully working now....
r3278 try:
data = formatter(obj)
except:
# FIXME: log the exception
raise
M Bussonnier
Some documentations about custom formatters
r28959
MinRK
allow formatters to publish metadata...
r10443 # formatters can return raw data or (data, metadata)
if isinstance(data, tuple) and len(data) == 2:
data, md = data
M Bussonnier
Some documentations about custom formatters
r28959
Brian Granger
Display system is fully working now....
r3278 if data is not None:
format_dict[format_type] = data
MinRK
allow formatters to publish metadata...
r10443 if md is not None:
md_dict[format_type] = md
return format_dict, md_dict
Brian Granger
Display system is fully working now....
r3278
@property
def format_types(self):
"""Return the format types (MIME types) of the active formatters."""
Thomas Kluyver
Miscellaneous Python 3 fixes
r13364 return list(self.formatters.keys())
Brian Granger
Display system is fully working now....
r3278
#-----------------------------------------------------------------------------
# Formatters for specific format types (text, html, svg, etc.)
#-----------------------------------------------------------------------------
MinRK
show tracebacks for errors in formatters...
r18025
def _safe_repr(obj):
"""Try to return a repr of an object
always returns a string, at least.
"""
try:
return repr(obj)
except Exception as e:
return "un-repr-able object (%r)" % e
MinRK
use real Warnings for formatter errors...
r14637 class FormatterWarning(UserWarning):
"""Warning class for errors in formatters"""
MinRK
warn on failed formatter calls
r13977 @decorator
Min RK
update name, docstring for warn_format_error...
r19929 def catch_format_error(method, self, *args, **kwargs):
"""show traceback on failed format call"""
MinRK
warn on failed formatter calls
r13977 try:
MinRK
check return types of formatters...
r14152 r = method(self, *args, **kwargs)
Thomas Kluyver
Fix static analysis errors in IPython.core.formatters...
r19105 except NotImplementedError:
MinRK
allow NotImplementedError in formatters...
r14635 # don't warn on NotImplementedErrors
Thomas Kluyver
Ensure that MimeBundleFormatter always returns a 2-tuple
r24042 return self._check_return(None, args[0])
MinRK
show tracebacks for errors in formatters...
r18025 except Exception:
exc_info = sys.exc_info()
ip = get_ipython()
if ip is not None:
ip.showtraceback(exc_info)
else:
traceback.print_exception(*exc_info)
Thomas Kluyver
Ensure that MimeBundleFormatter always returns a 2-tuple
r24042 return self._check_return(None, args[0])
Min RK
JSON formatter expects JSONable dict/list...
r19557 return self._check_return(r, args[0])
MinRK
warn on failed formatter calls
r13977
Thomas Kluyver
Remove uses of with_metaclass compatibility hack
r23071 class FormatterABC(metaclass=abc.ABCMeta):
Brian Granger
Display system is fully working now....
r3278 """ Abstract base class for Formatters.
A formatter is a callable class that is responsible for computing the
raw format data for a particular format type (MIME type). For example,
an HTML formatter would have a format type of `text/html` and would return
the HTML representation of the object when called.
Robert Kern
ENH: Implement and test the default pretty formatter.
r3209 """
Brian Granger
Display system is fully working now....
r3278 # The format type of the data returned, usually a MIME type.
format_type = 'text/plain'
Robert Kern
ENH: Implement and test the default pretty formatter.
r3209
Brian Granger
Lots of work on the display system, focused on pylab stuff....
r3280 # Is the formatter enabled...
enabled = True
M Bussonnier
Some documentations about custom formatters
r28959
Brian Granger
Display system is fully working now....
r3278 @abc.abstractmethod
def __call__(self, obj):
"""Return a JSON'able representation of the object.
MinRK
warn on failed formatter calls
r13977 If the object cannot be formatted by this formatter,
warn and return None.
Brian Granger
Display system is fully working now....
r3278 """
MinRK
warn on failed formatter calls
r13977 return repr(obj)
Brian Granger
Display system is fully working now....
r3278
MinRK
add lookup logic based on apptools.type_registry...
r13781 def _mod_name_key(typ):
MinRK
another pass on formatter lookup...
r13788 """Return a (__module__, __name__) tuple for a type.
Matthias Bussonnier
DOC: More autoreformatting of docstrings....
r26498
MinRK
another pass on formatter lookup...
r13788 Used as key in Formatter.deferred_printers.
"""
MinRK
add lookup logic based on apptools.type_registry...
r13781 module = getattr(typ, '__module__', None)
name = getattr(typ, '__name__', None)
return (module, name)
def _get_type(obj):
"""Return the type of an instance (old and new-style)"""
return getattr(obj, '__class__', None) or type(obj)
Matthias Bussonnier
make sentinel class for some kwargs....
r21045
M Bussonnier
Some documentations about custom formatters
r28959 _raise_key_error = Sentinel(
"_raise_key_error",
__name__,
"""
Matthias Bussonnier
make sentinel class for some kwargs....
r21045 Special value to raise a KeyError
Raise KeyError in `BaseFormatter.pop` if passed as the default value to `pop`
M Bussonnier
Some documentations about custom formatters
r28959 """,
)
MinRK
add lookup logic based on apptools.type_registry...
r13781
MinRK
warn on failed formatter calls
r13977
Brian Granger
Display system is fully working now....
r3278 class BaseFormatter(Configurable):
"""A base formatter class that is configurable.
This formatter should usually be used as the base class of all formatters.
It is a traited :class:`Configurable` class and includes an extensible
API for users to determine how their objects are formatted. The following
logic is used to find a function to format an given object.
1. The object is introspected to see if it has a method with the name
:attr:`print_method`. If is does, that object is passed to that method
for formatting.
2. If no print method is found, three internal dictionaries are consulted
to find print method: :attr:`singleton_printers`, :attr:`type_printers`
and :attr:`deferred_printers`.
Brian Granger
Final work on display system....
r3288 Users should use these dictionaries to register functions that will be
used to compute the format data for their objects (if those objects don't
have the special print methods). The easiest way of using these
dictionaries is through the :meth:`for_type` and :meth:`for_type_by_name`
methods.
Brian Granger
Display system is fully working now....
r3278
If no function/callable is found to compute the format data, ``None`` is
returned and this format type is not used.
"""
Matthias Bussonnier
MAINT: refactor/please mypy....
r28167 format_type = Unicode("text/plain")
_return_type: Any = str
Brian Granger
Display system is fully working now....
r3278
Matthias Bussonnier
Update IPython/core/formatters.py to use new traitlets API....
r22331 enabled = Bool(True).tag(config=True)
Brian Granger
Lots of work on the display system, focused on pylab stuff....
r3280
Thomas Kluyver
Add ObjectName and DottedObjectName trait types for referring to Python identifiers.
r4047 print_method = ObjectName('__repr__')
Brian Granger
Display system is fully working now....
r3278
# The singleton printers.
# Maps the IDs of the builtin singleton objects to the format functions.
Matthias Bussonnier
Update IPython/core/formatters.py to use new traitlets API....
r22331 singleton_printers = Dict().tag(config=True)
Brian Granger
Display system is fully working now....
r3278
# The type-specific printers.
# Map type objects to the format functions.
Matthias Bussonnier
Update IPython/core/formatters.py to use new traitlets API....
r22331 type_printers = Dict().tag(config=True)
Brian Granger
Display system is fully working now....
r3278
# The deferred-import type-specific printers.
# Map (modulename, classname) pairs to the format functions.
Matthias Bussonnier
Update IPython/core/formatters.py to use new traitlets API....
r22331 deferred_printers = Dict().tag(config=True)
M Bussonnier
Some documentations about custom formatters
r28959
Min RK
update name, docstring for warn_format_error...
r19929 @catch_format_error
Brian Granger
Display system is fully working now....
r3278 def __call__(self, obj):
"""Compute the format for an object."""
Brian Granger
Lots of work on the display system, focused on pylab stuff....
r3280 if self.enabled:
MinRK
warn on failed formatter calls
r13977 # lookup registered printer
Brian Granger
Display system is fully working now....
r3278 try:
MinRK
warn on failed formatter calls
r13977 printer = self.lookup(obj)
except KeyError:
Brian Granger
Lots of work on the display system, focused on pylab stuff....
r3280 pass
MinRK
warn on failed formatter calls
r13977 else:
return printer(obj)
# Finally look for special method names
Thomas Kluyver
Consolidate code to check for method in IPython.utils.dir2
r22148 method = get_real_method(obj, self.print_method)
MinRK
get _ipython_display_ method safely...
r15486 if method is not None:
MinRK
warn on failed formatter calls
r13977 return method()
return None
Brian Granger
Lots of work on the display system, focused on pylab stuff....
r3280 else:
Brian Granger
Display system is fully working now....
r3278 return None
M Bussonnier
Some documentations about custom formatters
r28959
MinRK
another pass on formatter lookup...
r13788 def __contains__(self, typ):
"""map in to lookup_by_type"""
try:
self.lookup_by_type(typ)
except KeyError:
return False
else:
return True
M Bussonnier
Some documentations about custom formatters
r28959
Min RK
JSON formatter expects JSONable dict/list...
r19557 def _check_return(self, r, obj):
"""Check that a return value is appropriate
Matthias Bussonnier
DOC: More autoreformatting of docstrings....
r26498
Min RK
JSON formatter expects JSONable dict/list...
r19557 Return the value if so, None otherwise, warning if invalid.
"""
if r is None or isinstance(r, self._return_type) or \
(isinstance(r, tuple) and r and isinstance(r[0], self._return_type)):
return r
else:
warnings.warn(
"%s formatter returned invalid type %s (expected %s) for object: %s" % \
(self.format_type, type(r), self._return_type, _safe_repr(obj)),
FormatterWarning
)
M Bussonnier
Some documentations about custom formatters
r28959
MinRK
add lookup logic based on apptools.type_registry...
r13781 def lookup(self, obj):
"""Look up the formatter for a given instance.
Matthias Bussonnier
DOC: More autoreformatting of docstrings....
r26498
MinRK
add lookup logic based on apptools.type_registry...
r13781 Parameters
----------
Matthias Bussonnier
DOC: More autoreformatting of docstrings....
r26498 obj : object instance
MinRK
add lookup logic based on apptools.type_registry...
r13781
Returns
-------
f : callable
MinRK
another pass on formatter lookup...
r13788 The registered formatting callable for the type.
MinRK
add lookup logic based on apptools.type_registry...
r13781
Raises
------
KeyError if the type has not been registered.
"""
# look for singleton first
obj_id = id(obj)
if obj_id in self.singleton_printers:
return self.singleton_printers[obj_id]
# then lookup by type
return self.lookup_by_type(_get_type(obj))
M Bussonnier
Some documentations about custom formatters
r28959
MinRK
add lookup logic based on apptools.type_registry...
r13781 def lookup_by_type(self, typ):
MinRK
another pass on formatter lookup...
r13788 """Look up the registered formatter for a type.
MinRK
add lookup logic based on apptools.type_registry...
r13781
Parameters
----------
Matthias Bussonnier
DOC: More autoreformatting of docstrings....
r26498 typ : type or '__module__.__name__' string for a type
MinRK
add lookup logic based on apptools.type_registry...
r13781
Returns
-------
f : callable
MinRK
another pass on formatter lookup...
r13788 The registered formatting callable for the type.
Brian Granger
Display system is fully working now....
r3278
MinRK
add lookup logic based on apptools.type_registry...
r13781 Raises
------
KeyError if the type has not been registered.
"""
Srinivas Reddy Thatiparthy
convert string_types to str
r23037 if isinstance(typ, str):
MinRK
another pass on formatter lookup...
r13788 typ_key = tuple(typ.rsplit('.',1))
if typ_key not in self.deferred_printers:
# We may have it cached in the type map. We will have to
# iterate over all of the types to check.
for cls in self.type_printers:
if _mod_name_key(cls) == typ_key:
return self.type_printers[cls]
else:
return self.deferred_printers[typ_key]
else:
for cls in pretty._get_mro(typ):
if cls in self.type_printers or self._in_deferred_types(cls):
return self.type_printers[cls]
M Bussonnier
Some documentations about custom formatters
r28959
MinRK
add lookup logic based on apptools.type_registry...
r13781 # If we have reached here, the lookup failed.
raise KeyError("No registered printer for {0!r}".format(typ))
def for_type(self, typ, func=None):
Brian Granger
Display system is fully working now....
r3278 """Add a format function for a given type.
Matthias Bussonnier
DOC: More autoreformatting of docstrings....
r26498
Brian Granger
Final work on display system....
r3288 Parameters
Matthias Bussonnier
Compatibility with traitlets 5.0....
r25932 ----------
MinRK
formatter docstring consistency
r13790 typ : type or '__module__.__name__' string for a type
Brian Granger
Display system is fully working now....
r3278 The class of the object that will be formatted using `func`.
Matthias Bussonnier
reformat all of core
r27290
Brian Granger
Display system is fully working now....
r3278 func : callable
MinRK
tweak formatter.for_type...
r13654 A callable for computing the format data.
`func` will be called with the object to be formatted,
and will return the raw data in this formatter's format.
Subclasses may use a different call signature for the
Brian Granger
Display system is fully working now....
r3278 `func` argument.
Matthias Bussonnier
DOC: More autoreformatting of docstrings....
r26498
MinRK
add lookup logic based on apptools.type_registry...
r13781 If `func` is None or not specified, there will be no change,
MinRK
tweak formatter.for_type...
r13654 only returning the current value.
Matthias Bussonnier
DOC: More autoreformatting of docstrings....
r26498
MinRK
tweak formatter.for_type...
r13654 Returns
-------
oldfunc : callable
The currently registered callable.
If you are registering a new formatter,
this will be the previous value (to enable restoring later).
Brian Granger
Display system is fully working now....
r3278 """
MinRK
add lookup logic based on apptools.type_registry...
r13781 # if string given, interpret as 'pkg.module.class_name'
Srinivas Reddy Thatiparthy
convert string_types to str
r23037 if isinstance(typ, str):
MinRK
add lookup logic based on apptools.type_registry...
r13781 type_module, type_name = typ.rsplit('.', 1)
return self.for_type_by_name(type_module, type_name, func)
M Bussonnier
Some documentations about custom formatters
r28959
MinRK
add lookup logic based on apptools.type_registry...
r13781 try:
oldfunc = self.lookup_by_type(typ)
except KeyError:
oldfunc = None
M Bussonnier
Some documentations about custom formatters
r28959
MinRK
add lookup logic based on apptools.type_registry...
r13781 if func is not None:
Brian Granger
Display system is fully working now....
r3278 self.type_printers[typ] = func
M Bussonnier
Some documentations about custom formatters
r28959
Brian Granger
Display system is fully working now....
r3278 return oldfunc
MinRK
add lookup logic based on apptools.type_registry...
r13781 def for_type_by_name(self, type_module, type_name, func=None):
Brian Granger
Display system is fully working now....
r3278 """Add a format function for a type specified by the full dotted
module and name of the type, rather than the type of the object.
Parameters
----------
type_module : str
The full dotted name of the module the type is defined in, like
``numpy``.
Matthias Bussonnier
reformat all of core
r27290
Brian Granger
Display system is fully working now....
r3278 type_name : str
The name of the type (the class name), like ``dtype``
Matthias Bussonnier
reformat all of core
r27290
Brian Granger
Display system is fully working now....
r3278 func : callable
MinRK
tweak formatter.for_type...
r13654 A callable for computing the format data.
`func` will be called with the object to be formatted,
and will return the raw data in this formatter's format.
Subclasses may use a different call signature for the
Brian Granger
Display system is fully working now....
r3278 `func` argument.
Matthias Bussonnier
DOC: More autoreformatting of docstrings....
r26498
MinRK
add lookup logic based on apptools.type_registry...
r13781 If `func` is None or unspecified, there will be no change,
MinRK
tweak formatter.for_type...
r13654 only returning the current value.
Matthias Bussonnier
DOC: More autoreformatting of docstrings....
r26498
MinRK
tweak formatter.for_type...
r13654 Returns
-------
oldfunc : callable
The currently registered callable.
If you are registering a new formatter,
this will be the previous value (to enable restoring later).
Brian Granger
Display system is fully working now....
r3278 """
key = (type_module, type_name)
M Bussonnier
Some documentations about custom formatters
r28959
MinRK
another pass on formatter lookup...
r13788 try:
oldfunc = self.lookup_by_type("%s.%s" % key)
except KeyError:
oldfunc = None
M Bussonnier
Some documentations about custom formatters
r28959
MinRK
add lookup logic based on apptools.type_registry...
r13781 if func is not None:
Brian Granger
Display system is fully working now....
r3278 self.deferred_printers[key] = func
return oldfunc
M Bussonnier
Some documentations about custom formatters
r28959
MinRK
another pass on formatter lookup...
r13788 def pop(self, typ, default=_raise_key_error):
"""Pop a formatter for the given type.
MinRK
add lookup logic based on apptools.type_registry...
r13781
Parameters
----------
typ : type or '__module__.__name__' string for a type
MinRK
another pass on formatter lookup...
r13788 default : object
value to be returned if no formatter is registered for typ.
MinRK
add lookup logic based on apptools.type_registry...
r13781
Returns
-------
obj : object
The last registered object for the type.
Raises
------
MinRK
another pass on formatter lookup...
r13788 KeyError if the type is not registered and default is not specified.
MinRK
add lookup logic based on apptools.type_registry...
r13781 """
M Bussonnier
Some documentations about custom formatters
r28959
Srinivas Reddy Thatiparthy
convert string_types to str
r23037 if isinstance(typ, str):
MinRK
add lookup logic based on apptools.type_registry...
r13781 typ_key = tuple(typ.rsplit('.',1))
if typ_key not in self.deferred_printers:
# We may have it cached in the type map. We will have to
# iterate over all of the types to check.
for cls in self.type_printers:
if _mod_name_key(cls) == typ_key:
old = self.type_printers.pop(cls)
break
else:
MinRK
another pass on formatter lookup...
r13788 old = default
MinRK
add lookup logic based on apptools.type_registry...
r13781 else:
MinRK
more formatter type lookup tests
r13783 old = self.deferred_printers.pop(typ_key)
MinRK
add lookup logic based on apptools.type_registry...
r13781 else:
if typ in self.type_printers:
old = self.type_printers.pop(typ)
else:
MinRK
another pass on formatter lookup...
r13788 old = self.deferred_printers.pop(_mod_name_key(typ), default)
if old is _raise_key_error:
raise KeyError("No registered value for {0!r}".format(typ))
MinRK
add lookup logic based on apptools.type_registry...
r13781 return old
Brian Granger
Display system is fully working now....
r3278
Brian Granger
More improvements to the display system....
r3279 def _in_deferred_types(self, cls):
"""
Check if the given class is specified in the deferred type registry.
MinRK
add lookup logic based on apptools.type_registry...
r13781 Successful matches will be moved to the regular type registry for future use.
Brian Granger
More improvements to the display system....
r3279 """
mod = getattr(cls, '__module__', None)
name = getattr(cls, '__name__', None)
key = (mod, name)
if key in self.deferred_printers:
# Move the printer over to the regular registry.
printer = self.deferred_printers.pop(key)
self.type_printers[cls] = printer
MinRK
add lookup logic based on apptools.type_registry...
r13781 return True
return False
Brian Granger
Display system is fully working now....
r3278
Brian Granger
Lots of work on the display system, focused on pylab stuff....
r3280
Brian Granger
Display system is fully working now....
r3278 class PlainTextFormatter(BaseFormatter):
"""The default pretty-printer.
Robert Kern
DOC: Fix references to IPython.lib.pretty instead of the old location IPython.external.pretty
r6292 This uses :mod:`IPython.lib.pretty` to compute the format data of
Brian Granger
Display system is fully working now....
r3278 the object. If the object cannot be pretty printed, :func:`repr` is used.
Robert Kern
DOC: Fix references to IPython.lib.pretty instead of the old location IPython.external.pretty
r6292 See the documentation of :mod:`IPython.lib.pretty` for details on
Brian Granger
Display system is fully working now....
r3278 how to write pretty printers. Here is a simple example::
def dtype_pprinter(obj, p, cycle):
if cycle:
return p.text('dtype(...)')
if hasattr(obj, 'fields'):
if obj.fields is None:
p.text(repr(obj))
else:
p.begin_group(7, 'dtype([')
for i, field in enumerate(obj.descr):
if i > 0:
p.text(',')
p.breakable()
p.pretty(field)
p.end_group(7, '])')
"""
# The format type of data returned.
Thomas Kluyver
Eliminate Str and CStr trait types except in IPython.parallel
r4046 format_type = Unicode('text/plain')
Brian Granger
Display system is fully working now....
r3278
Brian Granger
Lots of work on the display system, focused on pylab stuff....
r3280 # This subclass ignores this attribute as it always need to return
# something.
Matthias Bussonnier
Update IPython/core/formatters.py to use new traitlets API....
r22331 enabled = Bool(True).tag(config=False)
M Bussonnier
Some documentations about custom formatters
r28959
Min RK
adopt traitlets 4.2 API...
r22340 max_seq_length = Integer(pretty.MAX_SEQ_LENGTH,
Min RK
make pretty.max_seq_length configurable...
r18518 help="""Truncate large collections (lists, dicts, tuples, sets) to this size.
M Bussonnier
Some documentations about custom formatters
r28959
Min RK
make pretty.max_seq_length configurable...
r18518 Set to 0 to disable truncation.
M Bussonnier
Some documentations about custom formatters
r28959 """,
Min RK
adopt traitlets 4.2 API...
r22340 ).tag(config=True)
M Bussonnier
Some documentations about custom formatters
r28959
Brian Granger
Renamed __pretty__ to _repr_pretty_ and changed updated pretty.py...
r3879 # Look for a _repr_pretty_ methods to use for pretty printing.
Thomas Kluyver
Add ObjectName and DottedObjectName trait types for referring to Python identifiers.
r4047 print_method = ObjectName('_repr_pretty_')
Robert Kern
ENH: Implement and test the default pretty formatter.
r3209
# Whether to pretty-print or not.
Matthias Bussonnier
Update IPython/core/formatters.py to use new traitlets API....
r22331 pprint = Bool(True).tag(config=True)
Robert Kern
ENH: Implement and test the default pretty formatter.
r3209
# Whether to be verbose or not.
Matthias Bussonnier
Update IPython/core/formatters.py to use new traitlets API....
r22331 verbose = Bool(False).tag(config=True)
Robert Kern
ENH: Implement and test the default pretty formatter.
r3209
# The maximum width.
Matthias Bussonnier
Update IPython/core/formatters.py to use new traitlets API....
r22331 max_width = Integer(79).tag(config=True)
Robert Kern
ENH: Implement and test the default pretty formatter.
r3209
# The newline character.
Matthias Bussonnier
Update IPython/core/formatters.py to use new traitlets API....
r22331 newline = Unicode('\n').tag(config=True)
Bernardo B. Marques
remove all trailling spaces
r4872
MinRK
add `float_precision` trait to PlainTextFormatter...
r3350 # format-string for pprinting floats
Thomas Kluyver
Eliminate Str and CStr trait types except in IPython.parallel
r4046 float_format = Unicode('%r')
MinRK
add `float_precision` trait to PlainTextFormatter...
r3350 # setter for float precision, either int or direct format-string
Matthias Bussonnier
Update IPython/core/formatters.py to use new traitlets API....
r22331 float_precision = CUnicode('').tag(config=True)
Bernardo B. Marques
remove all trailling spaces
r4872
Min RK
fix some deprecations...
r22742 @observe('float_precision')
def _float_precision_changed(self, change):
MinRK
add `float_precision` trait to PlainTextFormatter...
r3350 """float_precision changed, set float_format accordingly.
Bernardo B. Marques
remove all trailling spaces
r4872
MinRK
add `float_precision` trait to PlainTextFormatter...
r3350 float_precision can be set by int or str.
This will set float_format, after interpreting input.
If numpy has been imported, numpy print precision will also be set.
Bernardo B. Marques
remove all trailling spaces
r4872
MinRK
add `float_precision` trait to PlainTextFormatter...
r3350 integer `n` sets format to '%.nf', otherwise, format set directly.
Bernardo B. Marques
remove all trailling spaces
r4872
MinRK
add `float_precision` trait to PlainTextFormatter...
r3350 An empty string returns to defaults (repr for float, 8 for numpy).
Bernardo B. Marques
remove all trailling spaces
r4872
MinRK
add `float_precision` trait to PlainTextFormatter...
r3350 This parameter can be set via the '%precision' magic.
"""
Min RK
fix some deprecations...
r22742 new = change['new']
MinRK
add `float_precision` trait to PlainTextFormatter...
r3350 if '%' in new:
# got explicit format string
fmt = new
try:
fmt%3.14159
Ram Rachum
Fix exception causes in 7 modules
r25827 except Exception as e:
raise ValueError("Precision must be int or format string, not %r"%new) from e
MinRK
add `float_precision` trait to PlainTextFormatter...
r3350 elif new:
# otherwise, should be an int
try:
i = int(new)
assert i >= 0
Ram Rachum
Fix exception causes in 7 modules
r25827 except ValueError as e:
raise ValueError("Precision must be int or format string, not %r"%new) from e
except AssertionError as e:
raise ValueError("int precision must be non-negative, not %r"%i) from e
Bernardo B. Marques
remove all trailling spaces
r4872
MinRK
add `float_precision` trait to PlainTextFormatter...
r3350 fmt = '%%.%if'%i
if 'numpy' in sys.modules:
# set numpy precision if it has been imported
import numpy
numpy.set_printoptions(precision=i)
else:
# default back to repr
fmt = '%r'
if 'numpy' in sys.modules:
import numpy
# numpy default is 8
numpy.set_printoptions(precision=8)
self.float_format = fmt
Robert Kern
ENH: Implement and test the default pretty formatter.
r3209
Robert Kern
DOC: Fix references to IPython.lib.pretty instead of the old location IPython.external.pretty
r6292 # Use the default pretty printers from IPython.lib.pretty.
Min RK
adopt traitlets 4.2 API...
r22340 @default('singleton_printers')
Brian Granger
Display system is fully working now....
r3278 def _singleton_printers_default(self):
Robert Kern
ENH: Implement and test the default pretty formatter.
r3209 return pretty._singleton_pprinters.copy()
Min RK
adopt traitlets 4.2 API...
r22340 @default('type_printers')
Brian Granger
Display system is fully working now....
r3278 def _type_printers_default(self):
MinRK
add `float_precision` trait to PlainTextFormatter...
r3350 d = pretty._type_pprinters.copy()
d[float] = lambda obj,p,cycle: p.text(self.float_format%obj)
Peter Corke
add local numpy import
r26449 # if NumPy is used, set precision for its float64 type
Peter Corke
update formatting as per PR tests
r26450 if "numpy" in sys.modules:
Peter Corke
add local numpy import
r26449 import numpy
Peter Corke
update formatting as per PR tests
r26450
d[numpy.float64] = lambda obj, p, cycle: p.text(self.float_format % obj)
MinRK
add `float_precision` trait to PlainTextFormatter...
r3350 return d
Robert Kern
ENH: Implement and test the default pretty formatter.
r3209
Min RK
adopt traitlets 4.2 API...
r22340 @default('deferred_printers')
Brian Granger
Display system is fully working now....
r3278 def _deferred_printers_default(self):
Robert Kern
ENH: Implement and test the default pretty formatter.
r3209 return pretty._deferred_type_pprinters.copy()
#### FormatterABC interface ####
Min RK
update name, docstring for warn_format_error...
r19929 @catch_format_error
Robert Kern
ENH: Implement and test the default pretty formatter.
r3209 def __call__(self, obj):
Brian Granger
Display system is fully working now....
r3278 """Compute the pretty representation of the object."""
Robert Kern
ENH: Implement and test the default pretty formatter.
r3209 if not self.pprint:
MinRK
show tracebacks for errors in formatters...
r18025 return repr(obj)
Robert Kern
ENH: Implement and test the default pretty formatter.
r3209 else:
Srinivas Reddy Thatiparthy
remove CUnicodeIO and replace it with StringIO
r23119 stream = StringIO()
Robert Kern
ENH: Implement and test the default pretty formatter.
r3209 printer = pretty.RepresentationPrinter(stream, self.verbose,
Min RK
handle unicode/str in pretty, str formatter...
r20486 self.max_width, self.newline,
Min RK
make pretty.max_seq_length configurable...
r18518 max_seq_length=self.max_seq_length,
Brian Granger
Display system is fully working now....
r3278 singleton_pprinters=self.singleton_printers,
type_pprinters=self.type_printers,
deferred_pprinters=self.deferred_printers)
Robert Kern
ENH: Implement and test the default pretty formatter.
r3209 printer.pretty(obj)
printer.flush()
return stream.getvalue()
Brian Granger
Display system is fully working now....
r3278 class HTMLFormatter(BaseFormatter):
"""An HTML formatter.
Robert Kern
ENH: Implement and test the default pretty formatter.
r3209
Brian Granger
Display system is fully working now....
r3278 To define the callables that compute the HTML representation of your
Brian Granger
Renaming the special methods of the formatters....
r3878 objects, define a :meth:`_repr_html_` method or use the :meth:`for_type`
Brian Granger
Display system is fully working now....
r3278 or :meth:`for_type_by_name` methods to register functions that handle
this.
Brian Granger
Misc updates the display system....
r3880
The return value of this formatter should be a valid HTML snippet that
Bernardo B. Marques
remove all trailling spaces
r4872 could be injected into an existing DOM. It should *not* include the
Brian Granger
Misc updates the display system....
r3880 ```<html>`` or ```<body>`` tags.
Brian Granger
Display system is fully working now....
r3278 """
Thomas Kluyver
Eliminate Str and CStr trait types except in IPython.parallel
r4046 format_type = Unicode('text/html')
Robert Kern
ENH: Implement and test the default pretty formatter.
r3209
Thomas Kluyver
Add ObjectName and DottedObjectName trait types for referring to Python identifiers.
r4047 print_method = ObjectName('_repr_html_')
Robert Kern
ENH: Implement and test the default pretty formatter.
r3209
Andrew Jesaitis
Adds markdown formatting to output cells
r16364 class MarkdownFormatter(BaseFormatter):
"""A Markdown formatter.
To define the callables that compute the Markdown representation of your
objects, define a :meth:`_repr_markdown_` method or use the :meth:`for_type`
or :meth:`for_type_by_name` methods to register functions that handle
this.
The return value of this formatter should be a valid Markdown.
"""
format_type = Unicode('text/markdown')
print_method = ObjectName('_repr_markdown_')
Brian Granger
Display system is fully working now....
r3278 class SVGFormatter(BaseFormatter):
"""An SVG formatter.
To define the callables that compute the SVG representation of your
Brian Granger
Renaming the special methods of the formatters....
r3878 objects, define a :meth:`_repr_svg_` method or use the :meth:`for_type`
Brian Granger
Display system is fully working now....
r3278 or :meth:`for_type_by_name` methods to register functions that handle
this.
Brian Granger
Misc updates the display system....
r3880
The return value of this formatter should be valid SVG enclosed in
```<svg>``` tags, that could be injected into an existing DOM. It should
*not* include the ```<html>`` or ```<body>`` tags.
Robert Kern
ENH: Implement and test the default pretty formatter.
r3209 """
Thomas Kluyver
Eliminate Str and CStr trait types except in IPython.parallel
r4046 format_type = Unicode('image/svg+xml')
Robert Kern
ENH: Implement and test the default pretty formatter.
r3209
Thomas Kluyver
Add ObjectName and DottedObjectName trait types for referring to Python identifiers.
r4047 print_method = ObjectName('_repr_svg_')
Robert Kern
ENH: Implement and test the default pretty formatter.
r3209
Brian Granger
Display system is fully working now....
r3278 class PNGFormatter(BaseFormatter):
"""A PNG formatter.
Robert Kern
ENH: Use text/plain for the format string of the DefaultFormatter....
r3214
Brian Granger
Display system is fully working now....
r3278 To define the callables that compute the PNG representation of your
Brian Granger
Renaming the special methods of the formatters....
r3878 objects, define a :meth:`_repr_png_` method or use the :meth:`for_type`
Brian Granger
Display system is fully working now....
r3278 or :meth:`for_type_by_name` methods to register functions that handle
Brian Granger
Renaming the special methods of the formatters....
r3878 this.
Brian Granger
Misc updates the display system....
r3880 The return value of this formatter should be raw PNG data, *not*
base64 encoded.
Brian Granger
Display system is fully working now....
r3278 """
Thomas Kluyver
Eliminate Str and CStr trait types except in IPython.parallel
r4046 format_type = Unicode('image/png')
Brian Granger
Display system is fully working now....
r3278
Thomas Kluyver
Add ObjectName and DottedObjectName trait types for referring to Python identifiers.
r4047 print_method = ObjectName('_repr_png_')
M Bussonnier
Some documentations about custom formatters
r28959
Srinivas Reddy Thatiparthy
remove unicode_type function
r23044 _return_type = (bytes, str)
Brian Granger
Display system is fully working now....
r3278
Brian E. Granger
Finishing display system work....
r4528 class JPEGFormatter(BaseFormatter):
"""A JPEG formatter.
To define the callables that compute the JPEG representation of your
objects, define a :meth:`_repr_jpeg_` method or use the :meth:`for_type`
or :meth:`for_type_by_name` methods to register functions that handle
this.
The return value of this formatter should be raw JPEG data, *not*
base64 encoded.
"""
format_type = Unicode('image/jpeg')
print_method = ObjectName('_repr_jpeg_')
Srinivas Reddy Thatiparthy
remove unicode_type function
r23044 _return_type = (bytes, str)
MinRK
check return types of formatters...
r14152
Brian E. Granger
Finishing display system work....
r4528
Brian Granger
Display system is fully working now....
r3278 class LatexFormatter(BaseFormatter):
"""A LaTeX formatter.
To define the callables that compute the LaTeX representation of your
Brian Granger
Renaming the special methods of the formatters....
r3878 objects, define a :meth:`_repr_latex_` method or use the :meth:`for_type`
Brian Granger
Display system is fully working now....
r3278 or :meth:`for_type_by_name` methods to register functions that handle
this.
Brian Granger
Misc updates the display system....
r3880
The return value of this formatter should be a valid LaTeX equation,
Brian Granger
Changes to Math class and added Latex class....
r6065 enclosed in either ```$```, ```$$``` or another LaTeX equation
environment.
Brian Granger
Display system is fully working now....
r3278 """
Thomas Kluyver
Eliminate Str and CStr trait types except in IPython.parallel
r4046 format_type = Unicode('text/latex')
Brian Granger
Display system is fully working now....
r3278
Thomas Kluyver
Add ObjectName and DottedObjectName trait types for referring to Python identifiers.
r4047 print_method = ObjectName('_repr_latex_')
Brian Granger
Display system is fully working now....
r3278
class JSONFormatter(BaseFormatter):
"""A JSON string formatter.
Min RK
JSON formatter expects JSONable dict/list...
r19557 To define the callables that compute the JSONable representation of
Brian Granger
Renaming the special methods of the formatters....
r3878 your objects, define a :meth:`_repr_json_` method or use the :meth:`for_type`
Brian Granger
Display system is fully working now....
r3278 or :meth:`for_type_by_name` methods to register functions that handle
this.
Brian Granger
Misc updates the display system....
r3880
Min RK
JSON formatter expects JSONable dict/list...
r19557 The return value of this formatter should be a JSONable list or dict.
JSON scalars (None, number, string) are not allowed, only dict or list containers.
Brian Granger
Display system is fully working now....
r3278 """
Thomas Kluyver
Eliminate Str and CStr trait types except in IPython.parallel
r4046 format_type = Unicode('application/json')
Min RK
JSON formatter expects JSONable dict/list...
r19557 _return_type = (list, dict)
Brian Granger
Display system is fully working now....
r3278
Thomas Kluyver
Add ObjectName and DottedObjectName trait types for referring to Python identifiers.
r4047 print_method = ObjectName('_repr_json_')
M Bussonnier
Some documentations about custom formatters
r28959
Min RK
JSON formatter expects JSONable dict/list...
r19557 def _check_return(self, r, obj):
"""Check that a return value is appropriate
Matthias Bussonnier
DOC: More autoreformatting of docstrings....
r26498
Min RK
JSON formatter expects JSONable dict/list...
r19557 Return the value if so, None otherwise, warning if invalid.
"""
if r is None:
return
md = None
if isinstance(r, tuple):
# unpack data, metadata tuple for type checking on first element
r, md = r
Matthias Bussonnier
Remove many deprecation and bump traitlets to 5+...
r27272
assert not isinstance(
r, str
), "JSON-as-string has been deprecated since IPython < 3"
Min RK
JSON formatter expects JSONable dict/list...
r19557 if md is not None:
# put the tuple back together
r = (r, md)
return super(JSONFormatter, self)._check_return(r, obj)
Brian Granger
Renaming the special methods of the formatters....
r3878
class JavascriptFormatter(BaseFormatter):
"""A Javascript formatter.
To define the callables that compute the Javascript representation of
Bernardo B. Marques
remove all trailling spaces
r4872 your objects, define a :meth:`_repr_javascript_` method or use the
Brian Granger
Renaming the special methods of the formatters....
r3878 :meth:`for_type` or :meth:`for_type_by_name` methods to register functions
that handle this.
Brian Granger
Misc updates the display system....
r3880
The return value of this formatter should be valid Javascript code and
should *not* be enclosed in ```<script>``` tags.
Brian Granger
Renaming the special methods of the formatters....
r3878 """
Thomas Kluyver
Eliminate Str and CStr trait types except in IPython.parallel
r4046 format_type = Unicode('application/javascript')
Brian Granger
Display system is fully working now....
r3278
Thomas Kluyver
Add ObjectName and DottedObjectName trait types for referring to Python identifiers.
r4047 print_method = ObjectName('_repr_javascript_')
Brian Granger
Display system is fully working now....
r3278
Brian E. Granger
Adding PDFFormatter and kernel side handling of PDF display data.
r15121
class PDFFormatter(BaseFormatter):
"""A PDF formatter.
Jim Garrison
fixed a typo in IPython.core.formatters
r16283 To define the callables that compute the PDF representation of your
Brian E. Granger
Adding PDFFormatter and kernel side handling of PDF display data.
r15121 objects, define a :meth:`_repr_pdf_` method or use the :meth:`for_type`
or :meth:`for_type_by_name` methods to register functions that handle
this.
The return value of this formatter should be raw PDF data, *not*
base64 encoded.
"""
format_type = Unicode('application/pdf')
print_method = ObjectName('_repr_pdf_')
Srinivas Reddy Thatiparthy
remove unicode_type function
r23044 _return_type = (bytes, str)
MinRK
allow PDFFormatter to return bytes
r18123
Min RK
s/SelfDisplaying/IPythonDisplay/
r19382 class IPythonDisplayFormatter(BaseFormatter):
Min RK
Define `_repr_mimebundle_`...
r23578 """An escape-hatch Formatter for objects that know how to display themselves.
M Bussonnier
Some documentations about custom formatters
r28959
Min RK
add SelfDisplayingFormatter...
r19381 To define the callables that compute the representation of your
objects, define a :meth:`_ipython_display_` method or use the :meth:`for_type`
or :meth:`for_type_by_name` methods to register functions that handle
this. Unlike mime-type displays, this method should not return anything,
instead calling any appropriate display methods itself.
M Bussonnier
Some documentations about custom formatters
r28959
Min RK
add SelfDisplayingFormatter...
r19381 This display formatter has highest priority.
If it fires, no other display formatter will be called.
Min RK
Define `_repr_mimebundle_`...
r23578
Prior to IPython 6.1, `_ipython_display_` was the only way to display custom mime-types
without registering a new Formatter.
M Bussonnier
Some documentations about custom formatters
r28959
Min RK
Define `_repr_mimebundle_`...
r23578 IPython 6.1 introduces `_repr_mimebundle_` for displaying custom mime-types,
so `_ipython_display_` should only be used for objects that require unusual
display patterns, such as multiple display calls.
Min RK
add SelfDisplayingFormatter...
r19381 """
print_method = ObjectName('_ipython_display_')
_return_type = (type(None), bool)
Min RK
update name, docstring for warn_format_error...
r19929 @catch_format_error
Min RK
add SelfDisplayingFormatter...
r19381 def __call__(self, obj):
"""Compute the format for an object."""
if self.enabled:
# lookup registered printer
try:
printer = self.lookup(obj)
except KeyError:
pass
else:
printer(obj)
return True
# Finally look for special method names
Thomas Kluyver
Consolidate code to check for method in IPython.utils.dir2
r22148 method = get_real_method(obj, self.print_method)
Min RK
add SelfDisplayingFormatter...
r19381 if method is not None:
method()
return True
Brian E. Granger
Adding PDFFormatter and kernel side handling of PDF display data.
r15121
Min RK
Define `_repr_mimebundle_`...
r23578 class MimeBundleFormatter(BaseFormatter):
"""A Formatter for arbitrary mime-types.
Unlike other `_repr_<mimetype>_` methods,
`_repr_mimebundle_` should return mime-bundle data,
either the mime-keyed `data` dictionary or the tuple `(data, metadata)`.
Any mime-type is valid.
To define the callables that compute the mime-bundle representation of your
objects, define a :meth:`_repr_mimebundle_` method or use the :meth:`for_type`
or :meth:`for_type_by_name` methods to register functions that handle
this.
.. versionadded:: 6.1
"""
print_method = ObjectName('_repr_mimebundle_')
_return_type = dict
M Bussonnier
Some documentations about custom formatters
r28959
Min RK
Define `_repr_mimebundle_`...
r23578 def _check_return(self, r, obj):
r = super(MimeBundleFormatter, self)._check_return(r, obj)
# always return (data, metadata):
if r is None:
return {}, {}
if not isinstance(r, tuple):
return r, {}
return r
Matthias Bussonnier
Pass down include and exclude as kwarg to repr_mimebundle
r23618 @catch_format_error
def __call__(self, obj, include=None, exclude=None):
"""Compute the format for an object.
Identical to parent's method but we pass extra parameters to the method.
Unlike other _repr_*_ `_repr_mimebundle_` should allow extra kwargs, in
particular `include` and `exclude`.
"""
if self.enabled:
# lookup registered printer
try:
printer = self.lookup(obj)
except KeyError:
pass
else:
return printer(obj)
# Finally look for special method names
method = get_real_method(obj, self.print_method)
if method is not None:
Min RK
implement GIF support without registering a new formatter...
r23849 return method(include=include, exclude=exclude)
Matthias Bussonnier
Pass down include and exclude as kwarg to repr_mimebundle
r23618 return None
else:
return None
Min RK
Define `_repr_mimebundle_`...
r23578
Brian Granger
Display system is fully working now....
r3278 FormatterABC.register(BaseFormatter)
FormatterABC.register(PlainTextFormatter)
FormatterABC.register(HTMLFormatter)
Andrew Jesaitis
Adds markdown formatting to output cells
r16364 FormatterABC.register(MarkdownFormatter)
Brian Granger
Display system is fully working now....
r3278 FormatterABC.register(SVGFormatter)
FormatterABC.register(PNGFormatter)
Brian E. Granger
Adding PDFFormatter and kernel side handling of PDF display data.
r15121 FormatterABC.register(PDFFormatter)
Brian E. Granger
Finishing display system work....
r4528 FormatterABC.register(JPEGFormatter)
Brian Granger
Display system is fully working now....
r3278 FormatterABC.register(LatexFormatter)
FormatterABC.register(JSONFormatter)
Brian Granger
Renaming the special methods of the formatters....
r3878 FormatterABC.register(JavascriptFormatter)
Min RK
s/SelfDisplaying/IPythonDisplay/
r19382 FormatterABC.register(IPythonDisplayFormatter)
Min RK
Define `_repr_mimebundle_`...
r23578 FormatterABC.register(MimeBundleFormatter)
Brian Granger
Display system is fully working now....
r3278
def format_display_data(obj, include=None, exclude=None):
"""Return a format data dict for an object.
By default all format types will be computed.
Parameters
----------
obj : object
The Python object whose format data will be computed.
Returns
-------
format_dict : dict
A dictionary of key/value pairs, one or each format that was
generated for the object. The keys are the format types, which
will usually be MIME type strings and the values and JSON'able
data structure containing the raw data for the representation in
that format.
include : list or tuple, optional
A list of format type strings (MIME types) to include in the
format data dict. If this is set *only* the format types included
in this list will be computed.
exclude : list or tuple, optional
Min ho Kim
Fixed typos
r25167 A list of format type string (MIME types) to exclude in the format
Brian Granger
Display system is fully working now....
r3278 data dict. If this is set all format types will be computed,
except for those included in this argument.
"""
Srinivas Reddy Thatiparthy
Change absolute imports to relative imports to facilitate processes embedding kernel or debugger
r25227 from .interactiveshell import InteractiveShell
Robert Kern
ENH: Implement and test the default pretty formatter.
r3209
Thomas Kluyver
Return value from format_display_data...
r22250 return InteractiveShell.instance().display_formatter.format(
Brian Granger
Display system is fully working now....
r3278 obj,
include,
exclude
)