##// END OF EJS Templates
HighlightMagics: Add new default languages
Pablo de Oliveira -
Show More
@@ -1,111 +1,116 b''
1 """This preprocessor detect cells using a different language through
1 """This preprocessor detect cells using a different language through
2 magic extensions such as `%%R` or `%%octave`. Cell's metadata is marked
2 magic extensions such as `%%R` or `%%octave`. Cell's metadata is marked
3 so that the appropriate highlighter can be used in the `highlight`
3 so that the appropriate highlighter can be used in the `highlight`
4 filter.
4 filter.
5 """
5 """
6
6
7 #-----------------------------------------------------------------------------
7 #-----------------------------------------------------------------------------
8 # Copyright (c) 2013, the IPython Development Team.
8 # Copyright (c) 2013, the IPython Development Team.
9 #
9 #
10 # Distributed under the terms of the Modified BSD License.
10 # Distributed under the terms of the Modified BSD License.
11 #
11 #
12 # The full license is in the file COPYING.txt, distributed with this software.
12 # The full license is in the file COPYING.txt, distributed with this software.
13 #-----------------------------------------------------------------------------
13 #-----------------------------------------------------------------------------
14
14
15 #-----------------------------------------------------------------------------
15 #-----------------------------------------------------------------------------
16 # Imports
16 # Imports
17 #-----------------------------------------------------------------------------
17 #-----------------------------------------------------------------------------
18
18
19 from __future__ import print_function, absolute_import
19 from __future__ import print_function, absolute_import
20
20
21 import re
21 import re
22
22
23 # Our own imports
23 # Our own imports
24 # Needed to override preprocessor
24 # Needed to override preprocessor
25 from .base import (Preprocessor)
25 from .base import (Preprocessor)
26 from IPython.utils.traitlets import Dict
26 from IPython.utils.traitlets import Dict
27
27
28 #-----------------------------------------------------------------------------
28 #-----------------------------------------------------------------------------
29 # Classes
29 # Classes
30 #-----------------------------------------------------------------------------
30 #-----------------------------------------------------------------------------
31
31
32
32
33 class HighlightMagicsPreprocessor(Preprocessor):
33 class HighlightMagicsPreprocessor(Preprocessor):
34 """
34 """
35 Detects and tags code cells that use a different languages than Python.
35 Detects and tags code cells that use a different languages than Python.
36 """
36 """
37
37
38 # list of magic language extensions and their associated pygment lexers
38 # list of magic language extensions and their associated pygment lexers
39 default_languages = Dict(
39 default_languages = Dict(
40 default_value={
40 default_value={
41 '%%R': 'r',
41 '%%R': 'r',
42 '%%bash': 'bash',
42 '%%bash': 'bash',
43 '%%cython': 'cython',
44 '%%javascript': 'javascript',
45 '%%julia': 'julia',
46 '%%latex': 'latex',
43 '%%octave': 'octave',
47 '%%octave': 'octave',
44 '%%perl': 'perl',
48 '%%perl': 'perl',
45 '%%ruby': 'ruby'},
49 '%%ruby': 'ruby',
50 '%%sh': 'sh'},
46 config=False)
51 config=False)
47
52
48 # user defined language extensions
53 # user defined language extensions
49 languages = Dict(
54 languages = Dict(
50 config=True,
55 config=True,
51 help=("Syntax highlighting for magic's extension languages. "
56 help=("Syntax highlighting for magic's extension languages. "
52 "Each item associates a language magic extension such as %%R, "
57 "Each item associates a language magic extension such as %%R, "
53 "with a pygments lexer such as r."))
58 "with a pygments lexer such as r."))
54
59
55 def __init__(self, config=None, **kw):
60 def __init__(self, config=None, **kw):
56 """Public constructor"""
61 """Public constructor"""
57
62
58 super(HighlightMagicsPreprocessor, self).__init__(config=config, **kw)
63 super(HighlightMagicsPreprocessor, self).__init__(config=config, **kw)
59
64
60 # Update the default languages dict with the user configured ones
65 # Update the default languages dict with the user configured ones
61 self.default_languages.update(self.languages)
66 self.default_languages.update(self.languages)
62
67
63 # build a regular expression to catch language extensions and choose
68 # build a regular expression to catch language extensions and choose
64 # an adequate pygments lexer
69 # an adequate pygments lexer
65 any_language = "|".join(self.default_languages.keys())
70 any_language = "|".join(self.default_languages.keys())
66 self.re_magic_language = re.compile(
71 self.re_magic_language = re.compile(
67 r'^\s*({0})\s+'.format(any_language))
72 r'^\s*({0})\s+'.format(any_language))
68
73
69 def which_magic_language(self, source):
74 def which_magic_language(self, source):
70 """
75 """
71 When a cell uses another language through a magic extension,
76 When a cell uses another language through a magic extension,
72 the other language is returned.
77 the other language is returned.
73 If no language magic is detected, this function returns None.
78 If no language magic is detected, this function returns None.
74
79
75 Parameters
80 Parameters
76 ----------
81 ----------
77 source: str
82 source: str
78 Source code of the cell to highlight
83 Source code of the cell to highlight
79 """
84 """
80
85
81 m = self.re_magic_language.match(source)
86 m = self.re_magic_language.match(source)
82
87
83 if m:
88 if m:
84 # By construction of the re, the matched language must be in the
89 # By construction of the re, the matched language must be in the
85 # languages dictionnary
90 # languages dictionnary
86 assert(m.group(1) in self.default_languages)
91 assert(m.group(1) in self.default_languages)
87 return self.default_languages[m.group(1)]
92 return self.default_languages[m.group(1)]
88 else:
93 else:
89 return None
94 return None
90
95
91 def preprocess_cell(self, cell, resources, cell_index):
96 def preprocess_cell(self, cell, resources, cell_index):
92 """
97 """
93 Tags cells using a magic extension language
98 Tags cells using a magic extension language
94
99
95 Parameters
100 Parameters
96 ----------
101 ----------
97 cell : NotebookNode cell
102 cell : NotebookNode cell
98 Notebook cell being processed
103 Notebook cell being processed
99 resources : dictionary
104 resources : dictionary
100 Additional resources used in the conversion process. Allows
105 Additional resources used in the conversion process. Allows
101 preprocessors to pass variables into the Jinja engine.
106 preprocessors to pass variables into the Jinja engine.
102 cell_index : int
107 cell_index : int
103 Index of the cell being processed (see base.py)
108 Index of the cell being processed (see base.py)
104 """
109 """
105
110
106 # Only tag code cells
111 # Only tag code cells
107 if hasattr(cell, "input") and cell.cell_type == "code":
112 if hasattr(cell, "input") and cell.cell_type == "code":
108 magic_language = self.which_magic_language(cell.input)
113 magic_language = self.which_magic_language(cell.input)
109 if magic_language:
114 if magic_language:
110 cell['metadata']['magics_language'] = magic_language
115 cell['metadata']['magics_language'] = magic_language
111 return cell, resources
116 return cell, resources
General Comments 0
You need to be logged in to leave comments. Login now