##// END OF EJS Templates
logo link to current tree level...
logo link to current tree level rather than top level

File last commit:

r12221:017ada76
r13064:a2287526
Show More
base.py
111 lines | 3.7 KiB | text/x-python | PythonLexer
Matthias BUSSONNIER
move transformer in separate file
r9302 """
Paul Ivanov
replace 'transformer' with 'preprocessor'
r12219 Module that re-groups preprocessor that would be applied to ipynb files
Matthias BUSSONNIER
docs
r9528 before going through the templating machinery.
Matthias BUSSONNIER
move transformer in separate file
r9302
Jonathan Frederic
Cleanup and refactor, transformers
r10674 It exposes a convenient class to inherit from to access configurability.
Matthias BUSSONNIER
move transformer in separate file
r9302 """
Jonathan Frederic
Cleanup and refactor, transformers
r10674 #-----------------------------------------------------------------------------
# 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.
#-----------------------------------------------------------------------------
#-----------------------------------------------------------------------------
# Imports
#-----------------------------------------------------------------------------
Matthias BUSSONNIER
move transformer in separate file
r9302
Jonathan Frederic
Rename utils.config to utils.base
r11420 from ..utils.base import NbConvertBase
Jonathan Frederic
Removed ActivatableTransformer and moved enabled key into base.
r11388 from IPython.utils.traitlets import Bool
Matthias BUSSONNIER
create configurable preprocessors
r9307
Jonathan Frederic
Cleanup and refactor, transformers
r10674 #-----------------------------------------------------------------------------
# Classes and Functions
#-----------------------------------------------------------------------------
Paul Ivanov
replace 'transformer' with 'preprocessor'
r12219 class Preprocessor(NbConvertBase):
""" A configurable preprocessor
Matthias BUSSONNIER
docs
r9528
Inherit from this class if you wish to have configurability for your
Paul Ivanov
replace 'transformer' with 'preprocessor'
r12219 preprocessor.
Matthias BUSSONNIER
docs
r9528
Paul Ivanov
fixup minor typos from search/replace
r12220 Any configurable traitlets this class exposed will be configurable in
profiles using c.SubClassName.atribute=value
Matthias BUSSONNIER
docs
r9528
Paul Ivanov
fixup minor typos from search/replace
r12220 you can overwrite :meth:`preprocess_cell` to apply a transformation
independently on each cell or :meth:`preprocess` if you prefer your own
logic. See corresponding docstring for informations.
Jonathan Frederic
Removed ActivatableTransformer and moved enabled key into base.
r11388
Disabled by default and can be enabled via the config by
Paul Ivanov
replace 'transformer' with 'preprocessor'
r12219 'c.YourPreprocessorName.enabled = True'
Matthias BUSSONNIER
docs
r9528 """
Jonathan Frederic
Generator used to create figure indicies
r10772
Jonathan Frederic
Prefer new style of config passing, parent=self (replaces config=self.config)
r11382 enabled = Bool(False, config=True)
def __init__(self, **kw):
Jonathan Frederic
Cleanup and refactor, transformers
r10674 """
Public constructor
Parameters
----------
config : Config
Configuration file structure
**kw : misc
Additional arguments
"""
Paul Ivanov
replace 'transformer' with 'preprocessor'
r12219 super(Preprocessor, self).__init__(**kw)
Matthias BUSSONNIER
create configurable preprocessors
r9307
Jonathan Frederic
Generator used to create figure indicies
r10772
Jonathan Frederic
Cleanup and refactor, transformers
r10674 def __call__(self, nb, resources):
Jonathan Frederic
Removed ActivatableTransformer and moved enabled key into base.
r11388 if self.enabled:
Paul Ivanov
replace 'transformer' with 'preprocessor'
r12219 return self.preprocess(nb,resources)
Jonathan Frederic
Removed ActivatableTransformer and moved enabled key into base.
r11388 else:
return nb, resources
Matthias BUSSONNIER
do not ask to inherit __call__ but call
r10834
Paul Ivanov
replace 'transformer' with 'preprocessor'
r12219 def preprocess(self, nb, resources):
Jonathan Frederic
Cleanup and refactor, transformers
r10674 """
Paul Ivanov
fixup minor typos from search/replace
r12220 Preprocessing to apply on each notebook.
Jonathan Frederic
Cleanup and refactor, transformers
r10674
You should return modified nb, resources.
Paul Ivanov
fixup minor typos from search/replace
r12220 If you wish to apply your preprocessing to each cell, you might want
to overwrite preprocess_cell method instead.
Jonathan Frederic
Cleanup and refactor, transformers
r10674
Parameters
----------
nb : NotebookNode
Notebook being converted
resources : dictionary
Additional resources used in the conversion process. Allows
Paul Ivanov
replace 'transformer' with 'preprocessor'
r12219 preprocessors to pass variables into the Jinja engine.
Matthias BUSSONNIER
docs
r9528 """
Paul Ivanov
replace 'transformer' with 'preprocessor'
r12219 self.log.debug("Applying preprocess: %s", self.__class__.__name__)
Matthias BUSSONNIER
create configurable preprocessors
r9307 try :
MinRK
add basic logging to NbConvert stages
r11842 for worksheet in nb.worksheets:
Matthias BUSSONNIER
create configurable preprocessors
r9307 for index, cell in enumerate(worksheet.cells):
Paul Ivanov
replace 'transformer' with 'preprocessor'
r12219 worksheet.cells[index], resources = self.preprocess_cell(cell, resources, index)
Jonathan Frederic
Cleanup and refactor, transformers
r10674 return nb, resources
Matthias BUSSONNIER
pylint
r9491 except NotImplementedError:
Matthias BUSSONNIER
create configurable preprocessors
r9307 raise NotImplementedError('should be implemented by subclass')
Matthias BUSSONNIER
docs
r9528
Paul Ivanov
replace 'transformer' with 'preprocessor'
r12219 def preprocess_cell(self, cell, resources, index):
Jonathan Frederic
Cleanup and refactor, transformers
r10674 """
Paul Ivanov
fixup minor typos from search/replace
r12220 Overwrite if you want to apply some preprocessing to each cell. You
Jonathan Frederic
Cleanup and refactor, transformers
r10674 should return modified cell and resource dictionary.
Parameters
----------
cell : NotebookNode cell
Notebook cell being processed
resources : dictionary
Additional resources used in the conversion process. Allows
Paul Ivanov
replace 'transformer' with 'preprocessor'
r12219 preprocessors to pass variables into the Jinja engine.
Jonathan Frederic
Cleanup and refactor, transformers
r10674 index : int
Index of the cell being processed
Matthias BUSSONNIER
create configurable preprocessors
r9307 """
Jonathan Frederic
Post code-review, extended refactor.
r10485
Matthias BUSSONNIER
create configurable preprocessors
r9307 raise NotImplementedError('should be implemented by subclass')
Jonathan Frederic
Cleanup and refactor, transformers
r10674 return cell, resources
Matthias BUSSONNIER
do not ask to inherit __call__ but call
r10834