Commit d02b657f by Chris Wanstrath

implement unescape tag, make escape tag actually escape

parent 24bdeb2d
import re import re
import cgi
SECTION_RE = re.compile(r"{{\#([^\}]*)}}\s*(.+?)\s*{{/\1}}", re.M | re.S) SECTION_RE = re.compile(r"{{\#([^\}]*)}}\s*(.+?)\s*{{/\1}}", re.M | re.S)
TAG_RE = re.compile(r"{{(#|=|!|<|>|\{)?(.+?)\1?}}+") TAG_RE = re.compile(r"{{(#|=|!|<|>|\{)?(.+?)\1?}}+")
...@@ -6,7 +7,8 @@ TAG_RE = re.compile(r"{{(#|=|!|<|>|\{)?(.+?)\1?}}+") ...@@ -6,7 +7,8 @@ TAG_RE = re.compile(r"{{(#|=|!|<|>|\{)?(.+?)\1?}}+")
class Template(object): class Template(object):
tag_types = { tag_types = {
None: 'tag', None: 'tag',
'!': 'comment' '!': 'comment',
'{': 'unescaped'
} }
def __init__(self, template, context=None): def __init__(self, template, context=None):
...@@ -62,8 +64,12 @@ class Template(object): ...@@ -62,8 +64,12 @@ class Template(object):
def render_tag(self, tag_name, context): def render_tag(self, tag_name, context):
"""Given a tag name and context, finds and renders the tag.""" """Given a tag name and context, finds and renders the tag."""
return context.get(tag_name, '') return cgi.escape(context.get(tag_name, ''))
def render_comment(self, tag_name=None, context=None): def render_comment(self, tag_name=None, context=None):
"""Rendering a comment always returns nothing.""" """Rendering a comment always returns nothing."""
return '' return ''
def render_unescaped(self, tag_name=None, context=None):
"""Render a tag without escaping it."""
return context.get(tag_name, '')
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment