50 lines
1.3 KiB
Python
50 lines
1.3 KiB
Python
#!/usr/bin/env python
|
|
#coding:utf-8
|
|
# Author: mozman
|
|
# Purpose: a hack to generate XML containing CDATA by ElementTree
|
|
# Created: 26.05.2012
|
|
# Copyright (C) 2012, Manfred Moitzi
|
|
# License: MIT License
|
|
|
|
# usage:
|
|
#
|
|
# from svgwrite.etree import etree, CDATA
|
|
#
|
|
# element = etree.Element('myTag')
|
|
# element.append(CDATA("< and >"))
|
|
#
|
|
# assert etree.tostring(element) == "<myTag><![CDATA[< and >]]></myTag>"
|
|
|
|
|
|
import sys
|
|
PY3 = sys.version_info[0] > 2
|
|
|
|
import xml.etree.ElementTree as etree
|
|
|
|
CDATA_TPL = "<![CDATA[%s]]>"
|
|
CDATA_TAG = CDATA_TPL
|
|
|
|
|
|
def CDATA(text):
|
|
element = etree.Element(CDATA_TAG)
|
|
element.text = text
|
|
return element
|
|
|
|
original_serialize_xml = etree._serialize_xml
|
|
|
|
if PY3:
|
|
def _serialize_xml_with_CDATA_support(write, elem, qnames, namespaces, **kwargs):
|
|
if elem.tag == CDATA_TAG:
|
|
write(CDATA_TPL % elem.text)
|
|
else:
|
|
original_serialize_xml(write, elem, qnames, namespaces, **kwargs)
|
|
else:
|
|
def _serialize_xml_with_CDATA_support(write, elem, encoding, qnames, namespaces):
|
|
if elem.tag == CDATA_TAG:
|
|
write(CDATA_TPL % elem.text.encode(encoding))
|
|
else:
|
|
original_serialize_xml(write, elem, encoding, qnames, namespaces)
|
|
|
|
# ugly, ugly, ugly patching
|
|
etree._serialize_xml = _serialize_xml_with_CDATA_support
|