highlight.py
88 lines
| 2.6 KiB
| text/x-python
|
PythonLexer
Jonathan Frederic
|
r10676 | """ | ||
Module containing filter functions that allow code to be highlighted | ||||
from within Jinja templates. | ||||
""" | ||||
#----------------------------------------------------------------------------- | ||||
# 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 | ||||
#----------------------------------------------------------------------------- | ||||
Jonathan Frederic
|
r10630 | |||
from pygments import highlight as pygements_highlight | ||||
from pygments.lexers import get_lexer_by_name | ||||
from pygments.formatters import HtmlFormatter | ||||
from pygments.formatters import LatexFormatter | ||||
Jonathan Frederic
|
r10485 | # Our own imports | ||
Brian E. Granger
|
r11089 | from IPython.nbconvert.utils.lexers import IPythonLexer | ||
Jonathan Frederic
|
r10485 | |||
#----------------------------------------------------------------------------- | ||||
# Globals and constants | ||||
#----------------------------------------------------------------------------- | ||||
Jonathan Frederic
|
r10676 | MULTILINE_OUTPUTS = ['text', 'html', 'svg', 'latex', 'javascript', 'json'] | ||
Jonathan Frederic
|
r10485 | |||
#----------------------------------------------------------------------------- | ||||
# Utility functions | ||||
#----------------------------------------------------------------------------- | ||||
Jonathan Frederic
|
r10676 | |||
Brian E. Granger
|
r11088 | __all__ = [ | ||
Jonathan Frederic
|
r11685 | 'highlight2html', | ||
Brian E. Granger
|
r11088 | 'highlight2latex' | ||
] | ||||
Jonathan Frederic
|
r11685 | def highlight2html(source, language='ipython'): | ||
Jonathan Frederic
|
r10485 | """ | ||
Return a syntax-highlighted version of the input source as html output. | ||||
Jonathan Frederic
|
r10676 | |||
Parameters | ||||
---------- | ||||
source : str | ||||
Source code to highlight the syntax of. | ||||
language : str | ||||
Language to highlight the syntax of. | ||||
Jonathan Frederic
|
r10485 | """ | ||
Jonathan Frederic
|
r10630 | |||
Jonathan Frederic
|
r10676 | return _pygment_highlight(source, HtmlFormatter(), language) | ||
Jonathan Frederic
|
r10485 | |||
Jonathan Frederic
|
r10676 | def highlight2latex(source, language='ipython'): | ||
Jonathan Frederic
|
r10485 | """ | ||
Return a syntax-highlighted version of the input source as latex output. | ||||
Jonathan Frederic
|
r10676 | |||
Parameters | ||||
---------- | ||||
source : str | ||||
Source code to highlight the syntax of. | ||||
language : str | ||||
Language to highlight the syntax of. | ||||
Jonathan Frederic
|
r10485 | """ | ||
Jonathan Frederic
|
r10676 | return _pygment_highlight(source, LatexFormatter(), language) | ||
Jonathan Frederic
|
r10485 | |||
Jonathan Frederic
|
r10676 | |||
def _pygment_highlight(source, output_formatter, language='ipython'): | ||||
Jonathan Frederic
|
r10485 | """ | ||
Return a syntax-highlighted version of the input source | ||||
Jonathan Frederic
|
r10676 | |||
Parameters | ||||
---------- | ||||
source : str | ||||
Source code to highlight the syntax of. | ||||
output_formatter : Pygments formatter | ||||
language : str | ||||
Language to highlight the syntax of. | ||||
Jonathan Frederic
|
r10485 | """ | ||
Jonathan Frederic
|
r10676 | |||
if language == 'ipython': | ||||
Jonathan Frederic
|
r10485 | lexer = IPythonLexer() | ||
else: | ||||
Jonathan Frederic
|
r10676 | lexer = get_lexer_by_name(language, stripall=True) | ||
Jonathan Frederic
|
r10485 | |||
Jonathan Frederic
|
r10676 | return pygements_highlight(source, lexer, output_formatter) | ||