"""Notebook export to reStructuredText (rST). This file provides a converter class for rendering IPython notebooks as valid reStructuredText, suitable for inclusion in e.g. Sphinx documentation. """ #----------------------------------------------------------------------------- # 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 #----------------------------------------------------------------------------- # IPython imports from IPython.utils.text import indent # Our own imports from .base import Converter from .utils import markdown2rst, rst_directive, remove_ansi #----------------------------------------------------------------------------- # Class declarations #----------------------------------------------------------------------------- class ConverterRST(Converter): #------------------------------------------------------------------------- # Class-level attributes determining the behaviour of the class but # probably not varying from instance to instance. #------------------------------------------------------------------------- extension = 'rst' heading_level = {1: '=', 2: '-', 3: '`', 4: '\'', 5: '.', 6: '~'} def render_heading(self, cell): marker = self.heading_level[cell.level] return ['{0}\n{1}\n'.format(cell.source, marker * len(cell.source))] def render_code(self, cell): # Note: cell has type 'IPython.nbformat.v3.nbbase.NotebookNode' if not cell.input: return [] lines = [] if 'source' not in self.exclude_cells: lines.extend(['In[%s]:' % self._get_prompt_number(cell), '']) lines.extend(rst_directive('.. code:: python', cell.input)) if 'output' not in self.exclude_cells: for output in cell.outputs: conv_fn = self.dispatch(output.output_type) lines.extend(conv_fn(output)) return lines def render_markdown(self, cell): #return [cell.source] return [markdown2rst(cell.source)] def render_raw(self, cell): if self.raw_as_verbatim: return ['::', '', indent(cell.source), ''] else: return [cell.source] def render_pyout(self, output): lines = ['Out[%s]:' % self._get_prompt_number(output), ''] # output is a dictionary like object with type as a key if 'latex' in output: lines.extend(rst_directive('.. math::', output.latex)) if 'text' in output: lines.extend(rst_directive('.. parsed-literal::', output.text)) return lines def render_pyerr(self, output): # Note: a traceback is a *list* of frames. return ['::', '', indent(remove_ansi('\n'.join(output.traceback))), ''] def _img_lines(self, img_file): return ['.. image:: %s' % img_file, ''] def render_display_format_text(self, output): return rst_directive('.. parsed-literal::', output.text) def _unknown_lines(self, data): return rst_directive('.. warning:: Unknown cell') + [data] def render_display_format_html(self, output): return rst_directive('.. raw:: html', output.html) def render_display_format_latex(self, output): return rst_directive('.. math::', output.latex) def render_display_format_json(self, output): return rst_directive('.. raw:: json', output.json) def render_display_format_javascript(self, output): return rst_directive('.. raw:: javascript', output.javascript)