##// END OF EJS Templates
Backport PR #10496: Define `_repr_mimebundle_`...
Backport PR #10496: Define `_repr_mimebundle_` Allows objects to display arbitrary mime-types by returning a mimebundle. This is getting increasingly important as custom mime-types are growing in popularity. - mime-bundle is computed first, but other formatters are still called - if a mime-type is present in repr-mimebundle, `_repr_<mime>_` will not be called (avoids redundant calls for backward-compatible objects) closes 10090 cc rgbkrk Alternative design: rather than single method returning the mimebundle itself, return mime-keyed mapping to callables, e.g.: ```python def _repr_mime_methods_(self): return { 'text/html': self._repr_html_, } ``` Another more minor alternative: rather than allowing return of `data` or `(data, metadata)`, require returning the full mime-bundle with `data`, `metadata` keys: ```python def _repr_mimebundle(self): return { 'data': { 'application/vnd.foo+json': [1,2,3], }, } ```

File last commit:

r22310:b51ccffc
r23619:abbf312f
Show More
display.py
65 lines | 2.1 KiB | text/x-python | PythonLexer
MinRK
add %%javascript, %%svg, and %%latex display magics...
r7946 """Simple magics for display formats"""
#-----------------------------------------------------------------------------
# Copyright (c) 2012 The IPython Development Team.
#
# Distributed under the terms of the Modified BSD License.
#
# The full license is in the file COPYING.txt, distributed with this software.
#-----------------------------------------------------------------------------
#-----------------------------------------------------------------------------
# Imports
#-----------------------------------------------------------------------------
# Our own packages
MinRK
add %%html cell magic
r9999 from IPython.core.display import display, Javascript, Latex, SVG, HTML
MinRK
add %%javascript, %%svg, and %%latex display magics...
r7946 from IPython.core.magic import (
Thomas Kluyver
Remove unused imports
r9399 Magics, magics_class, cell_magic
MinRK
add %%javascript, %%svg, and %%latex display magics...
r7946 )
#-----------------------------------------------------------------------------
# Magic implementation classes
#-----------------------------------------------------------------------------
@magics_class
class DisplayMagics(Magics):
"""Magics for displaying various output types with literals
Jonathan Frederic
Add %%js alias for %%javascript
r22307
Defines javascript/latex/svg/html cell magics for writing
Mikhail Korobov
fix DisplayMagics.html docstring
r10054 blocks in those languages, to be rendered in the frontend.
MinRK
add %%javascript, %%svg, and %%latex display magics...
r7946 """
Jonathan Frederic
Add %%js alias for %%javascript
r22307
@cell_magic
def js(self, line, cell):
Matthias Bussonnier
Precise that %%js is an alias of %%javascript
r22310 """Run the cell block of Javascript code
Alias of `%%javascript`
"""
Jonathan Frederic
Add %%js alias for %%javascript
r22307 self.javascript(line, cell)
MinRK
add %%javascript, %%svg, and %%latex display magics...
r7946 @cell_magic
def javascript(self, line, cell):
"""Run the cell block of Javascript code"""
display(Javascript(cell))
Jonathan Frederic
Add %%js alias for %%javascript
r22307
MinRK
add %%javascript, %%svg, and %%latex display magics...
r7946 @cell_magic
def latex(self, line, cell):
Jonathan Frederic
Better document the %%latex magic latex support.
r21735 """Render the cell as a block of latex
Jonathan Frederic
Add %%js alias for %%javascript
r22307
Jonathan Frederic
Clarify that the MathJax comment is Notebook specific.
r21738 The subset of latex which is support depends on the implementation in
Jonathan Frederic
Add %%js alias for %%javascript
r22307 the client. In the Jupyter Notebook, this magic only renders the subset
of latex defined by MathJax
Jonathan Frederic
Better document the %%latex magic latex support.
r21735 [here](https://docs.mathjax.org/en/v2.5-latest/tex.html)."""
MinRK
add %%javascript, %%svg, and %%latex display magics...
r7946 display(Latex(cell))
@cell_magic
def svg(self, line, cell):
"""Render the cell as an SVG literal"""
display(SVG(cell))
MinRK
add %%html cell magic
r9999
@cell_magic
def html(self, line, cell):
Mikhail Korobov
fix DisplayMagics.html docstring
r10054 """Render the cell as a block of HTML"""
MinRK
add %%html cell magic
r9999 display(HTML(cell))