Fix for mishandled " and & characters
This commit is contained in:
parent
865ece2e24
commit
d84266182a
1 changed files with 12 additions and 6 deletions
18
secretary.py
18
secretary.py
|
|
@ -306,20 +306,26 @@ class Renderer(object):
|
||||||
parent.removeChild(discard)
|
parent.removeChild(discard)
|
||||||
|
|
||||||
|
|
||||||
def _unescape_entities(self, xml_text):
|
@staticmethod
|
||||||
|
def _unescape_entities(xml_text):
|
||||||
# unescape XML entities gt and lt
|
# unescape XML entities gt and lt
|
||||||
unescape_rules = {
|
unescape_rules = {
|
||||||
r'(?is)({[{|%].*)(>)(.*[%|}]})': r'\1>\3',
|
r'(?is)({[{|%].*)(>)(.*[%|}]})': r'\1>\3',
|
||||||
r'(?is)({[{|%].*)(<)(.*[%|}]})': r'\1<\3',
|
r'(?is)({[{|%].*)(<)(.*[%|}]})': r'\1<\3',
|
||||||
r'(?is)({[{|%].*)(<.?text:s.?>)(.*[%|}]})': r'\1 \3',
|
r'(?is)({[{|%].*)(&)(.*[%|}]})': r'\1&\3',
|
||||||
|
r'(?is)({[{|%].*)(")(.*[%|}]})': r'\1"\3',
|
||||||
|
r'(?is)({[{|%].*)(<.?text:s.?>)(.*[%|}]})': r'\1 \3'
|
||||||
}
|
}
|
||||||
|
|
||||||
for p, r in unescape_rules.items():
|
for p, r in unescape_rules.items():
|
||||||
xml_text = re.sub(p, r, xml_text)
|
count = None
|
||||||
|
while count != 0:
|
||||||
|
xml_text, count = re.subn(p, r, xml_text)
|
||||||
|
|
||||||
return xml_text
|
return xml_text
|
||||||
|
|
||||||
def _encode_escape_chars(self, xml_text):
|
@staticmethod
|
||||||
|
def _encode_escape_chars(xml_text):
|
||||||
# Replace line feed and/or tabs within text span entities.
|
# Replace line feed and/or tabs within text span entities.
|
||||||
find_pattern = r'(?is)<text:([\S]+?)>([^>]*?([\n|\t])[^<]*?)</text:\1>'
|
find_pattern = r'(?is)<text:([\S]+?)>([^>]*?([\n|\t])[^<]*?)</text:\1>'
|
||||||
for m in re.findall(find_pattern, xml_text):
|
for m in re.findall(find_pattern, xml_text):
|
||||||
|
|
@ -441,10 +447,10 @@ class Renderer(object):
|
||||||
try:
|
try:
|
||||||
self.template_images = dict()
|
self.template_images = dict()
|
||||||
self._prepare_template_tags(xml_document)
|
self._prepare_template_tags(xml_document)
|
||||||
template_string = self._unescape_entities(xml_document.toxml())
|
template_string = Renderer._unescape_entities(xml_document.toxml())
|
||||||
jinja_template = self.environment.from_string(template_string)
|
jinja_template = self.environment.from_string(template_string)
|
||||||
result = jinja_template.render(**kwargs)
|
result = jinja_template.render(**kwargs)
|
||||||
result = self._encode_escape_chars(result)
|
result = Renderer._encode_escape_chars(result)
|
||||||
|
|
||||||
final_xml = parseString(result.encode('ascii', 'xmlcharrefreplace'))
|
final_xml = parseString(result.encode('ascii', 'xmlcharrefreplace'))
|
||||||
if self.template_images:
|
if self.template_images:
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue