summaryrefslogtreecommitdiffstats
path: root/Lib/xml
diff options
context:
space:
mode:
authorGuido van Rossum <guido@python.org>2001-02-05 18:50:15 (GMT)
committerGuido van Rossum <guido@python.org>2001-02-05 18:50:15 (GMT)
commit795ad56b319daa610766327b99a74e5ba1ae41b2 (patch)
treedcd730f80f8ba2052e06f8fa84a0577b45d67ff6 /Lib/xml
parent1b26b6a5f16636c58296b852d7adaa10a44640f7 (diff)
downloadcpython-795ad56b319daa610766327b99a74e5ba1ae41b2.zip
cpython-795ad56b319daa610766327b99a74e5ba1ae41b2.tar.gz
cpython-795ad56b319daa610766327b99a74e5ba1ae41b2.tar.bz2
Don't get fooled by an empty prefix with a valid namespaceURI -- in
this case, the code used to generate invalid tags and attribute names with a leading colon, e.g. <:tag> or <tag :attr="foo">.
Diffstat (limited to 'Lib/xml')
-rw-r--r--Lib/xml/dom/pulldom.py12
1 files changed, 10 insertions, 2 deletions
diff --git a/Lib/xml/dom/pulldom.py b/Lib/xml/dom/pulldom.py
index 66794f3..c400742 100644
--- a/Lib/xml/dom/pulldom.py
+++ b/Lib/xml/dom/pulldom.py
@@ -56,7 +56,11 @@ class PullDOM(xml.sax.ContentHandler):
# provide us with the original name. If not, create
# *a* valid tagName from the current context.
if tagName is None:
- tagName = self._current_context[uri] + ":" + localname
+ prefix = self._current_context[uri]
+ if prefix:
+ tagName = prefix + ":" + localname
+ else:
+ tagName = localname
node = self.document.createElementNS(uri, tagName)
else:
# When the tagname is not prefixed, it just appears as
@@ -66,7 +70,11 @@ class PullDOM(xml.sax.ContentHandler):
for aname,value in attrs.items():
a_uri, a_localname = aname
if a_uri:
- qname = self._current_context[a_uri] + ":" + a_localname
+ prefix = self._current_context[a_uri]
+ if prefix:
+ qname = prefix + ":" + a_localname
+ else:
+ qname = a_localname
attr = self.document.createAttributeNS(a_uri, qname)
else:
attr = self.document.createAttribute(a_localname)