##// END OF EJS Templates
Merge pull request #3733 from ivanov/pandoc-missing...
Merge pull request #3733 from ivanov/pandoc-missing Nicer message when pandoc is missing, closes #3730

File last commit:

r11453:14d699e2
r11627:53e0d8b6 merge
Show More
export.py
226 lines | 6.3 KiB | text/x-python | PythonLexer
Jonathan Frederic
Cleanup and refactor of API, almost complete....
r10677 """
Jonathan Frederic
Finished rename/refact on API namespace
r10690 Module containing single call export functions.
Jonathan Frederic
Post code-review, extended refactor.
r10485 """
#-----------------------------------------------------------------------------
# Copyright (c) 2013, 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.
#-----------------------------------------------------------------------------
Jonathan Frederic
Finished rename/refact on API namespace
r10690 #-----------------------------------------------------------------------------
# Imports
#-----------------------------------------------------------------------------
Jonathan Frederic
Docstring decorator
r10771 from functools import wraps
Jonathan Frederic
Finished rename/refact on API namespace
r10690
Jonathan Frederic
Fixed all broken references, refactored some stuff here and there,...
r10624 from IPython.nbformat.v3.nbbase import NotebookNode
Jonathan Frederic
Added writers and supporting code.
r11367 from IPython.config import Config
Jonathan Frederic
Fixed all broken references, refactored some stuff here and there,...
r10624
Jonathan Frederic
Moved export.py back into exporters directory
r10788 from .exporter import Exporter
MinRK
fix HTML capitalization in exporter classes
r11108 from .basichtml import BasicHTMLExporter
from .fullhtml import FullHTMLExporter
Jonathan Frederic
Moved export.py back into exporters directory
r10788 from .latex import LatexExporter
from .markdown import MarkdownExporter
from .python import PythonExporter
from .reveal import RevealExporter
MinRK
RST class capitalization
r11449 from .rst import RSTExporter
Jonathan Frederic
Moved export.py back into exporters directory
r10788 from .sphinx_howto import SphinxHowtoExporter
from .sphinx_manual import SphinxManualExporter
Jonathan Frederic
Import fix for renamed /api/ to /exporters/
r10768
Jonathan Frederic
Post code-review, extended refactor.
r10485 #-----------------------------------------------------------------------------
Jonathan Frederic
Docstring decorator
r10771 # Classes
Jonathan Frederic
Post code-review, extended refactor.
r10485 #-----------------------------------------------------------------------------
Jonathan Frederic
Finished a rough draft of the exporters.
r10588
MinRK
populate exporter list in NbConvertApp.classes
r11451 def DocDecorator(f):
Jonathan Frederic
Finished rename/refact on API namespace
r10690
Jonathan Frederic
Docstring decorator
r10771 #Set docstring of function
f.__doc__ = f.__doc__ + """
nb : Notebook node
Jonathan Frederic
Added writers and supporting code.
r11367 config : config (optional, keyword arg)
Jonathan Frederic
Finished rename/refact on API namespace
r10690 User configuration instance.
Jonathan Frederic
Added writers and supporting code.
r11367 resources : dict (optional, keyword arg)
Resources used in the conversion process.
Jonathan Frederic
Finished rename/refact on API namespace
r10690
Returns
----------
tuple- output, resources, exporter_instance
output : str
Jinja 2 output. This is the resulting converted notebook.
resources : dictionary
Dictionary of resources used prior to and during the conversion
process.
exporter_instance : Exporter
Instance of the Exporter class used to export the document. Useful
to caller because it provides a 'file_extension' property which
Jonathan Frederic
Docstring decorator
r10771 specifies what extension the output should be saved as."""
@wraps(f)
def decorator(*args, **kwargs):
return f(*args, **kwargs)
return decorator
#-----------------------------------------------------------------------------
# Functions
#-----------------------------------------------------------------------------
Brian E. Granger
Fixing import logic.
r11088 __all__ = [
'export',
'export_sphinx_manual',
'export_sphinx_howto',
'export_basic_html',
'export_full_html',
'export_latex',
'export_markdown',
'export_python',
'export_reveal',
'export_rst',
Paul Ivanov
added listing of known exporters on error
r11250 'export_by_name',
Jonathan Frederic
Added ExporterNameError to exported names
r11395 'get_export_names',
'ExporterNameError'
Brian E. Granger
Fixing import logic.
r11088 ]
Jonathan Frederic
Added ExporterNameError to exported names
r11395
Jonathan Frederic
Catch export specific name error only
r11372 class ExporterNameError(NameError):
pass
Jonathan Frederic
Added ExporterNameError to exported names
r11395
Jonathan Frederic
Docstring decorator
r10771 @DocDecorator
Jonathan Frederic
Added ability support for already instanciate exporter
r11426 def export(exporter, nb, **kw):
Jonathan Frederic
Docstring decorator
r10771 """
Export a notebook object using specific exporter class.
Jonathan Frederic
Added ability support for already instanciate exporter
r11426 exporter : Exporter class type or instance
Class type or instance of the exporter that should be used. If the
method initializes it's own instance of the class, it is ASSUMED that
the class type provided exposes a constructor (__init__) with the same
signature as the base Exporter class.
Jonathan Frederic
Finished rename/refact on API namespace
r10690 """
Jonathan Frederic
Fixed all broken references, refactored some stuff here and there,...
r10624
#Check arguments
Jonathan Frederic
Added ability support for already instanciate exporter
r11426 if exporter is None:
Jonathan Frederic
Fixed all broken references, refactored some stuff here and there,...
r10624 raise TypeError("Exporter is None")
Jonathan Frederic
Added ability support for already instanciate exporter
r11426 elif not isinstance(exporter, Exporter) and not issubclass(exporter, Exporter):
raise TypeError("exporter does not inherit from Exporter (base)")
Jonathan Frederic
Fixed all broken references, refactored some stuff here and there,...
r10624 if nb is None:
raise TypeError("nb is None")
#Create the exporter
Jonathan Frederic
Changes after in person review with @ellisonbg including TODO tags
r11379 resources = kw.pop('resources', None)
Jonathan Frederic
Added ability support for already instanciate exporter
r11426 if isinstance(exporter, Exporter):
exporter_instance = exporter
else:
exporter_instance = exporter(**kw)
Jonathan Frederic
Fixed all broken references, refactored some stuff here and there,...
r10624
#Try to convert the notebook using the appropriate conversion function.
if isinstance(nb, NotebookNode):
Jonathan Frederic
Added writers and supporting code.
r11367 output, resources = exporter_instance.from_notebook_node(nb, resources)
Jonathan Frederic
Got RST exporting to work... Sort of.
r10626 elif isinstance(nb, basestring):
Jonathan Frederic
Added writers and supporting code.
r11367 output, resources = exporter_instance.from_filename(nb, resources)
Jonathan Frederic
Fixed all broken references, refactored some stuff here and there,...
r10624 else:
Jonathan Frederic
Added writers and supporting code.
r11367 output, resources = exporter_instance.from_file(nb, resources)
return output, resources
Jonathan Frederic
Fixed all broken references, refactored some stuff here and there,...
r10624
Jonathan Frederic
Cleanup and refactor of API, almost complete....
r10677
Jonathan Frederic
Docstring decorator
r10771 @DocDecorator
Jonathan Frederic
Added writers and supporting code.
r11367 def export_sphinx_manual(nb, **kw):
Jonathan Frederic
Finished rename/refact on API namespace
r10690 """
Export a notebook object to Sphinx Manual LaTeX
"""
Jonathan Frederic
Added writers and supporting code.
r11367 return export(SphinxManualExporter, nb, **kw)
Jonathan Frederic
Finished rename/refact on API namespace
r10690
Jonathan Frederic
Docstring decorator
r10771 @DocDecorator
Jonathan Frederic
Added writers and supporting code.
r11367 def export_sphinx_howto(nb, **kw):
Jonathan Frederic
Finished rename/refact on API namespace
r10690 """
Export a notebook object to Sphinx HowTo LaTeX
"""
Jonathan Frederic
Added writers and supporting code.
r11367 return export(SphinxHowtoExporter, nb, **kw)
Jonathan Frederic
Finished rename/refact on API namespace
r10690
Jonathan Frederic
Docstring decorator
r10771 @DocDecorator
Jonathan Frederic
Added writers and supporting code.
r11367 def export_basic_html(nb, **kw):
Jonathan Frederic
Finished rename/refact on API namespace
r10690 """
Export a notebook object to Basic HTML
"""
Jonathan Frederic
Added writers and supporting code.
r11367 return export(BasicHTMLExporter, nb, **kw)
Jonathan Frederic
Finished rename/refact on API namespace
r10690
Jonathan Frederic
Docstring decorator
r10771 @DocDecorator
Jonathan Frederic
Added writers and supporting code.
r11367 def export_full_html(nb, **kw):
Jonathan Frederic
Finished rename/refact on API namespace
r10690 """
Export a notebook object to Full HTML
"""
Jonathan Frederic
Added writers and supporting code.
r11367 return export(FullHTMLExporter, nb, **kw)
Jonathan Frederic
Finished rename/refact on API namespace
r10690
Jonathan Frederic
Docstring decorator
r10771 @DocDecorator
Jonathan Frederic
Added writers and supporting code.
r11367 def export_latex(nb, **kw):
Jonathan Frederic
Finished rename/refact on API namespace
r10690 """
Export a notebook object to LaTeX
"""
Jonathan Frederic
Added writers and supporting code.
r11367 return export(LatexExporter, nb, **kw)
Jonathan Frederic
Finished rename/refact on API namespace
r10690
Jonathan Frederic
Docstring decorator
r10771 @DocDecorator
Jonathan Frederic
Added writers and supporting code.
r11367 def export_markdown(nb, **kw):
Jonathan Frederic
Finished rename/refact on API namespace
r10690 """
Export a notebook object to Markdown
"""
Jonathan Frederic
Added writers and supporting code.
r11367 return export(MarkdownExporter, nb, **kw)
Jonathan Frederic
Finished rename/refact on API namespace
r10690
Jonathan Frederic
Docstring decorator
r10771 @DocDecorator
Jonathan Frederic
Added writers and supporting code.
r11367 def export_python(nb, **kw):
Jonathan Frederic
Finished rename/refact on API namespace
r10690 """
Export a notebook object to Python
"""
Jonathan Frederic
Added writers and supporting code.
r11367 return export(PythonExporter, nb, **kw)
Jonathan Frederic
Finished rename/refact on API namespace
r10690
Jonathan Frederic
Docstring decorator
r10771 @DocDecorator
Jonathan Frederic
Added writers and supporting code.
r11367 def export_reveal(nb, **kw):
Jonathan Frederic
Finished rename/refact on API namespace
r10690 """
MinRK
RST class capitalization
r11449 Export a notebook object to a Reveal.js presentation
Jonathan Frederic
Finished rename/refact on API namespace
r10690 """
Jonathan Frederic
Added writers and supporting code.
r11367 return export(RevealExporter, nb, **kw)
Jonathan Frederic
Finished rename/refact on API namespace
r10690
Jonathan Frederic
Docstring decorator
r10771 @DocDecorator
Jonathan Frederic
Added writers and supporting code.
r11367 def export_rst(nb, **kw):
Jonathan Frederic
Finished rename/refact on API namespace
r10690 """
MinRK
RST class capitalization
r11449 Export a notebook object to reStructuredText
Jonathan Frederic
Finished rename/refact on API namespace
r10690 """
MinRK
RST class capitalization
r11449 return export(RSTExporter, nb, **kw)
Jonathan Frederic
Post code-review, extended refactor.
r10485
Jonathan Frederic
Cleanup and refactor of API, almost complete....
r10677
Jonathan Frederic
Docstring decorator
r10771 @DocDecorator
Jonathan Frederic
Added writers and supporting code.
r11367 def export_by_name(format_name, nb, **kw):
Jonathan Frederic
Finished rename/refact on API namespace
r10690 """
Export a notebook object to a template type by its name. Reflection
(Inspect) is used to find the template's corresponding explicit export
method defined in this module. That method is then called directly.
Jonathan Frederic
Added writers and supporting code.
r11367 format_name : str
Jonathan Frederic
Finished rename/refact on API namespace
r10690 Name of the template style to export to.
"""
Jonathan Frederic
Added writers and supporting code.
r11367 function_name = "export_" + format_name.lower()
Jonathan Frederic
Finished rename/refact on API namespace
r10690
Jonathan Frederic
Use globals dict to find right export function instead of...
r10769 if function_name in globals():
Jonathan Frederic
Added writers and supporting code.
r11367 return globals()[function_name](nb, **kw)
Jonathan Frederic
Use globals dict to find right export function instead of...
r10769 else:
Jonathan Frederic
Catch export specific name error only
r11372 raise ExporterNameError("template for `%s` not found" % function_name)
Matthias BUSSONNIER
pylint plus sphinx default to non-interactive.
r10875
Jonathan Frederic
Added ExporterNameError to exported names
r11395
Paul Ivanov
added listing of known exporters on error
r11250 def get_export_names():
"Return a list of the currently supported export targets"
# grab everything after 'export_'
l = [x[len('export_'):] for x in __all__ if x.startswith('export_')]
Jonathan Frederic
Added writers and supporting code.
r11367
Jonathan Frederic
Indent fix
r11377 # filter out the one method that is not a template
Paul Ivanov
added listing of known exporters on error
r11250 l = [x for x in l if 'by_name' not in x]
return sorted(l)