##// END OF EJS Templates
fix some tests
fix some tests

File last commit:

r8620:66b7dfea
r8622:0ea9ae00
Show More
notebook.py
81 lines | 1.8 KiB | text/x-python | PythonLexer
from converters.base import Converter
from shutil import rmtree
import json
class ConverterNotebook(Converter):
"""
A converter that is essentially a null-op.
This exists so it can be subclassed
for custom handlers of .ipynb files
that create new .ipynb files.
What distinguishes this from JSONWriter is that
subclasses can specify what to do with each type of cell.
Writes out a notebook file.
"""
extension = 'ipynb'
def __init__(self, infile, outbase):
Converter.__init__(self, infile)
self.outbase = outbase
rmtree(self.files_dir)
def convert(self):
return json.dumps(json.loads(Converter.convert(self, ',')), indent=1, sort_keys=True)
def optional_header(self):
s = \
"""{
"metadata": {
"name": "%(name)s"
},
"nbformat": 3,
"worksheets": [
{
"cells": [""" % {'name':self.outbase}
return s.split('\n')
def optional_footer(self):
s = \
"""]
}
]
}"""
return s.split('\n')
def render_heading(self, cell):
return cell_to_lines(cell)
def render_code(self, cell):
return cell_to_lines(cell)
def render_markdown(self, cell):
return cell_to_lines(cell)
def render_raw(self, cell):
return cell_to_lines(cell)
def render_pyout(self, output):
return cell_to_lines(output)
def render_pyerr(self, output):
return cell_to_lines(output)
def render_display_format_text(self, output):
return [output.text]
def render_display_format_html(self, output):
return [output.html]
def render_display_format_latex(self, output):
return [output.latex]
def render_display_format_json(self, output):
return [output.json]
def render_display_format_javascript(self, output):
return [output.javascript]