110
115
return ElementTree().parse(f)
113
# performance tuning for elementree's serialiser. This should be
114
# sent upstream - RBC 20060523.
115
# the functions here are patched into elementtree at runtime.
117
escape_re = re.compile("[&'\"<>]")
120
"'":"'", # FIXME: overkill
125
def _escape_replace(match, map=escape_map):
126
return map[match.group()]
128
def _escape_attrib(text, encoding=None, replace=None):
129
# escape attribute value
133
text = elementtree.ElementTree._encode(text, encoding)
135
return elementtree.ElementTree._encode_entity(text)
137
return escape_re.sub(_escape_replace, text)
139
text = replace(text, "&", "&")
140
text = replace(text, "'", "'") # FIXME: overkill
141
text = replace(text, "\"", """)
142
text = replace(text, "<", "<")
143
text = replace(text, ">", ">")
145
except (TypeError, AttributeError):
146
elementtree.ElementTree._raise_serialization_error(text)
148
elementtree.ElementTree._escape_attrib = _escape_attrib
150
escape_cdata_re = re.compile("[&<>]")
156
def _escape_cdata_replace(match, map=escape_cdata_map):
157
return map[match.group()]
159
def _escape_cdata(text, encoding=None, replace=None):
160
# escape character data
164
text = elementtree.ElementTree._encode(text, encoding)
166
return elementtree.ElementTree._encode_entity(text)
168
return escape_cdata_re.sub(_escape_cdata_replace, text)
170
text = replace(text, "&", "&")
171
text = replace(text, "<", "<")
172
text = replace(text, ">", ">")
174
except (TypeError, AttributeError):
175
elementtree.ElementTree._raise_serialization_error(text)
177
elementtree.ElementTree._escape_cdata = _escape_cdata
180
118
def escape_invalid_chars(message):
181
119
"""Escape the XML-invalid characters in a commit message.