Browse Source

Added syntax tag and filter

main
Lakshmi Vyasarajan 14 years ago
parent
commit
a9a72dfe96
1 changed files with 58 additions and 0 deletions
  1. +58
    -0
      hyde/ext/templates/jinja.py

+ 58
- 0
hyde/ext/templates/jinja.py View File

@@ -50,6 +50,7 @@ def markdown(env, value):
try: try:
import markdown import markdown
except ImportError: except ImportError:
logger.error(u"Cannot load the markdown library.")
raise TemplateError("Cannot load the markdown library") raise TemplateError("Cannot load the markdown library")
output = value output = value
d = {} d = {}
@@ -59,6 +60,34 @@ def markdown(env, value):
md = markdown.Markdown(**d) md = markdown.Markdown(**d)
return md.convert(output) return md.convert(output)



@environmentfilter
def syntax(env, value, lexer=None):
"""
Processes the contained block using `pygments`
"""

try:
import pygments
from pygments import lexers
self.lexers = lexers
from pygments import formatters
except ImportError:
logger.error(u"pygments library is required to use syntax highlighting tags.")
raise TemplateError("Cannot load pygments")

pyg = (self.lexers.get_lexer_by_name(lexer)
if lexer else
self.lexers.guess_lexer(value))
settings = {}
if hasattr(env.config, 'syntax'):
settings = getattr(env.config.syntax, 'options', {})

formatter = formatters.HtmlFormatter(**settings)
code = pygments.highlight(value, lexer, formatter)
code = code.replace('\n\n', '\n&nbsp;\n').replace('\n', '<br />')
return safestring.mark_safe('\n\n<div class="code">%s</div>\n\n' % code)

class Markdown(Extension): class Markdown(Extension):
""" """
A wrapper around the markdown filter for syntactic sugar. A wrapper around the markdown filter for syntactic sugar.
@@ -85,6 +114,33 @@ class Markdown(Extension):
output = caller().strip() output = caller().strip()
return markdown(self.environment, output) return markdown(self.environment, output)


class Syntax(Extension):
"""
A wrapper around the syntax filter for syntactic sugar.
"""
tags = set(['syntax'])

def parse(self, parser):
"""
Parses the statements and defers to the callback for pygments processing.
"""
lineno = parser.stream.next().lineno
lex = parser.stream.next_if('name')
body = parser.parse_statements(['name:endsyntax'], drop_needle=True)

return nodes.CallBlock(
self.call_method('_render_syntax', nodes.Const(lex)),
[], [], body).set_lineno(lineno)

def _render_syntax(self, lex, caller=None):
"""
Calls the syntax filter to transform the output.
"""
if not caller:
return ''
output = caller().strip()
return syntax(self.environment, output, lex)

class IncludeText(Extension): class IncludeText(Extension):
""" """
Automatically runs `markdown` and `typogrify` on included Automatically runs `markdown` and `typogrify` on included
@@ -255,6 +311,7 @@ class Jinja2Template(Template):
trim_blocks=True, trim_blocks=True,
extensions=[IncludeText, extensions=[IncludeText,
Markdown, Markdown,
Syntax,
Reference, Reference,
Refer, Refer,
'jinja2.ext.do', 'jinja2.ext.do',
@@ -264,6 +321,7 @@ class Jinja2Template(Template):
self.env.globals['content_url'] = content_url self.env.globals['content_url'] = content_url
self.env.globals['engine'] = engine self.env.globals['engine'] = engine
self.env.filters['markdown'] = markdown self.env.filters['markdown'] = markdown
self.env.filters['syntax'] = syntax


config = {} config = {}
if hasattr(site, 'config'): if hasattr(site, 'config'):


Loading…
Cancel
Save