Commit 20d46692 authored by Christian Heimes's avatar Christian Heimes

Issue #18347: ElementTree's html serializer now preserves the case of closing tags.

parent 0c503c2c
...@@ -1769,6 +1769,16 @@ def bug_200709_iter_comment(): ...@@ -1769,6 +1769,16 @@ def bug_200709_iter_comment():
""" """
def bug_18347():
"""
>>> e = ET.XML('<html><CamelCase>text</CamelCase></html>')
>>> serialize(e)
'<html><CamelCase>text</CamelCase></html>'
>>> serialize(e, method="html")
'<html><CamelCase>text</CamelCase></html>'
"""
# -------------------------------------------------------------------- # --------------------------------------------------------------------
# reported on bugs.python.org # reported on bugs.python.org
......
...@@ -988,15 +988,15 @@ def _serialize_html(write, elem, encoding, qnames, namespaces): ...@@ -988,15 +988,15 @@ def _serialize_html(write, elem, encoding, qnames, namespaces):
# FIXME: handle boolean attributes # FIXME: handle boolean attributes
write(" %s=\"%s\"" % (qnames[k], v)) write(" %s=\"%s\"" % (qnames[k], v))
write(">") write(">")
tag = tag.lower() ltag = tag.lower()
if text: if text:
if tag == "script" or tag == "style": if ltag == "script" or ltag == "style":
write(_encode(text, encoding)) write(_encode(text, encoding))
else: else:
write(_escape_cdata(text, encoding)) write(_escape_cdata(text, encoding))
for e in elem: for e in elem:
_serialize_html(write, e, encoding, qnames, None) _serialize_html(write, e, encoding, qnames, None)
if tag not in HTML_EMPTY: if ltag not in HTML_EMPTY:
write("</" + tag + ">") write("</" + tag + ">")
if elem.tail: if elem.tail:
write(_escape_cdata(elem.tail, encoding)) write(_escape_cdata(elem.tail, encoding))
......
...@@ -24,6 +24,9 @@ Core and Builtins ...@@ -24,6 +24,9 @@ Core and Builtins
Library Library
------- -------
- Issue #18347: ElementTree's html serializer now preserves the case of
closing tags.
- Issue #17261: Ensure multiprocessing's proxies use proper address. - Issue #17261: Ensure multiprocessing's proxies use proper address.
- Issue #17097: Make multiprocessing ignore EINTR. - Issue #17097: Make multiprocessing ignore EINTR.
......
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