mirror of
https://github.com/correl/SleekXMPP.git
synced 2024-11-24 03:00:15 +00:00
Modified sleekxmpp.xmlstream.tostring to import ToString class based on Python version.
The package sleekxmpp.xmlstream.tostring26 remains for now until stanzabase is updated, but is no longer needed.
This commit is contained in:
parent
aa1dbe97e0
commit
c54466596f
3 changed files with 137 additions and 58 deletions
|
@ -1,60 +1,14 @@
|
||||||
|
"""
|
||||||
|
|
||||||
class ToString(object):
|
"""
|
||||||
def __str__(self, xml=None, xmlns='', stringbuffer=''):
|
|
||||||
if xml is None:
|
|
||||||
xml = self.xml
|
|
||||||
newoutput = [stringbuffer]
|
|
||||||
#TODO respect ET mapped namespaces
|
|
||||||
itag = xml.tag.split('}', 1)[-1]
|
|
||||||
if '}' in xml.tag:
|
|
||||||
ixmlns = xml.tag.split('}', 1)[0][1:]
|
|
||||||
else:
|
|
||||||
ixmlns = ''
|
|
||||||
nsbuffer = ''
|
|
||||||
if xmlns != ixmlns and ixmlns != '' and ixmlns != self.namespace:
|
|
||||||
if self.stream is not None and ixmlns in self.stream.namespace_map:
|
|
||||||
if self.stream.namespace_map[ixmlns] != '':
|
|
||||||
itag = "%s:%s" % (self.stream.namespace_map[ixmlns], itag)
|
|
||||||
else:
|
|
||||||
nsbuffer = """ xmlns="%s\"""" % ixmlns
|
|
||||||
if ixmlns not in ('', xmlns, self.namespace):
|
|
||||||
nsbuffer = """ xmlns="%s\"""" % ixmlns
|
|
||||||
newoutput.append("<%s" % itag)
|
|
||||||
newoutput.append(nsbuffer)
|
|
||||||
for attrib in xml.attrib:
|
|
||||||
if '{' not in attrib:
|
|
||||||
newoutput.append(""" %s="%s\"""" % (attrib, self.xmlesc(xml.attrib[attrib])))
|
|
||||||
if len(xml) or xml.text or xml.tail:
|
|
||||||
newoutput.append(">")
|
|
||||||
if xml.text:
|
|
||||||
newoutput.append(self.xmlesc(xml.text))
|
|
||||||
if len(xml):
|
|
||||||
for child in xml.getchildren():
|
|
||||||
newoutput.append(self.__str__(child, ixmlns))
|
|
||||||
newoutput.append("</%s>" % (itag, ))
|
|
||||||
if xml.tail:
|
|
||||||
newoutput.append(self.xmlesc(xml.tail))
|
|
||||||
elif xml.text:
|
|
||||||
newoutput.append(">%s</%s>" % (self.xmlesc(xml.text), itag))
|
|
||||||
else:
|
|
||||||
newoutput.append(" />")
|
|
||||||
return ''.join(newoutput)
|
|
||||||
|
|
||||||
def xmlesc(self, text):
|
import sys
|
||||||
text = list(text)
|
|
||||||
cc = 0
|
|
||||||
matches = ('&', '<', '"', '>', "'")
|
# Import the correct ToString class based on the Python version.
|
||||||
for c in text:
|
if sys.version_info < (3, 0):
|
||||||
if c in matches:
|
from sleekxmpp.xmlstream.tostring.tostring26 import ToString
|
||||||
if c == '&':
|
|
||||||
text[cc] = '&'
|
|
||||||
elif c == '<':
|
|
||||||
text[cc] = '<'
|
|
||||||
elif c == '>':
|
|
||||||
text[cc] = '>'
|
|
||||||
elif c == "'":
|
|
||||||
text[cc] = '''
|
|
||||||
else:
|
else:
|
||||||
text[cc] = '"'
|
from sleekxmpp.xmlstream.tostring.tostring import ToString
|
||||||
cc += 1
|
|
||||||
return ''.join(text)
|
__all__ = ['ToString']
|
||||||
|
|
60
sleekxmpp/xmlstream/tostring/tostring.py
Normal file
60
sleekxmpp/xmlstream/tostring/tostring.py
Normal file
|
@ -0,0 +1,60 @@
|
||||||
|
|
||||||
|
class ToString(object):
|
||||||
|
def __str__(self, xml=None, xmlns='', stringbuffer=''):
|
||||||
|
if xml is None:
|
||||||
|
xml = self.xml
|
||||||
|
newoutput = [stringbuffer]
|
||||||
|
#TODO respect ET mapped namespaces
|
||||||
|
itag = xml.tag.split('}', 1)[-1]
|
||||||
|
if '}' in xml.tag:
|
||||||
|
ixmlns = xml.tag.split('}', 1)[0][1:]
|
||||||
|
else:
|
||||||
|
ixmlns = ''
|
||||||
|
nsbuffer = ''
|
||||||
|
if xmlns != ixmlns and ixmlns != '' and ixmlns != self.namespace:
|
||||||
|
if self.stream is not None and ixmlns in self.stream.namespace_map:
|
||||||
|
if self.stream.namespace_map[ixmlns] != '':
|
||||||
|
itag = "%s:%s" % (self.stream.namespace_map[ixmlns], itag)
|
||||||
|
else:
|
||||||
|
nsbuffer = """ xmlns="%s\"""" % ixmlns
|
||||||
|
if ixmlns not in ('', xmlns, self.namespace):
|
||||||
|
nsbuffer = """ xmlns="%s\"""" % ixmlns
|
||||||
|
newoutput.append("<%s" % itag)
|
||||||
|
newoutput.append(nsbuffer)
|
||||||
|
for attrib in xml.attrib:
|
||||||
|
if '{' not in attrib:
|
||||||
|
newoutput.append(""" %s="%s\"""" % (attrib, self.xmlesc(xml.attrib[attrib])))
|
||||||
|
if len(xml) or xml.text or xml.tail:
|
||||||
|
newoutput.append(">")
|
||||||
|
if xml.text:
|
||||||
|
newoutput.append(self.xmlesc(xml.text))
|
||||||
|
if len(xml):
|
||||||
|
for child in xml.getchildren():
|
||||||
|
newoutput.append(self.__str__(child, ixmlns))
|
||||||
|
newoutput.append("</%s>" % (itag, ))
|
||||||
|
if xml.tail:
|
||||||
|
newoutput.append(self.xmlesc(xml.tail))
|
||||||
|
elif xml.text:
|
||||||
|
newoutput.append(">%s</%s>" % (self.xmlesc(xml.text), itag))
|
||||||
|
else:
|
||||||
|
newoutput.append(" />")
|
||||||
|
return ''.join(newoutput)
|
||||||
|
|
||||||
|
def xmlesc(self, text):
|
||||||
|
text = list(text)
|
||||||
|
cc = 0
|
||||||
|
matches = ('&', '<', '"', '>', "'")
|
||||||
|
for c in text:
|
||||||
|
if c in matches:
|
||||||
|
if c == '&':
|
||||||
|
text[cc] = '&'
|
||||||
|
elif c == '<':
|
||||||
|
text[cc] = '<'
|
||||||
|
elif c == '>':
|
||||||
|
text[cc] = '>'
|
||||||
|
elif c == "'":
|
||||||
|
text[cc] = '''
|
||||||
|
else:
|
||||||
|
text[cc] = '"'
|
||||||
|
cc += 1
|
||||||
|
return ''.join(text)
|
65
sleekxmpp/xmlstream/tostring/tostring26.py
Normal file
65
sleekxmpp/xmlstream/tostring/tostring26.py
Normal file
|
@ -0,0 +1,65 @@
|
||||||
|
import types
|
||||||
|
|
||||||
|
class ToString(object):
|
||||||
|
def __str__(self, xml=None, xmlns='', stringbuffer=''):
|
||||||
|
if xml is None:
|
||||||
|
xml = self.xml
|
||||||
|
newoutput = [stringbuffer]
|
||||||
|
#TODO respect ET mapped namespaces
|
||||||
|
itag = xml.tag.split('}', 1)[-1]
|
||||||
|
if '}' in xml.tag:
|
||||||
|
ixmlns = xml.tag.split('}', 1)[0][1:]
|
||||||
|
else:
|
||||||
|
ixmlns = ''
|
||||||
|
nsbuffer = ''
|
||||||
|
if xmlns != ixmlns and ixmlns != u'' and ixmlns != self.namespace:
|
||||||
|
if self.stream is not None and ixmlns in self.stream.namespace_map:
|
||||||
|
if self.stream.namespace_map[ixmlns] != u'':
|
||||||
|
itag = "%s:%s" % (self.stream.namespace_map[ixmlns], itag)
|
||||||
|
else:
|
||||||
|
nsbuffer = """ xmlns="%s\"""" % ixmlns
|
||||||
|
if ixmlns not in ('', xmlns, self.namespace):
|
||||||
|
nsbuffer = """ xmlns="%s\"""" % ixmlns
|
||||||
|
newoutput.append("<%s" % itag)
|
||||||
|
newoutput.append(nsbuffer)
|
||||||
|
for attrib in xml.attrib:
|
||||||
|
if '{' not in attrib:
|
||||||
|
newoutput.append(""" %s="%s\"""" % (attrib, self.xmlesc(xml.attrib[attrib])))
|
||||||
|
if len(xml) or xml.text or xml.tail:
|
||||||
|
newoutput.append(u">")
|
||||||
|
if xml.text:
|
||||||
|
newoutput.append(self.xmlesc(xml.text))
|
||||||
|
if len(xml):
|
||||||
|
for child in xml.getchildren():
|
||||||
|
newoutput.append(self.__str__(child, ixmlns))
|
||||||
|
newoutput.append(u"</%s>" % (itag, ))
|
||||||
|
if xml.tail:
|
||||||
|
newoutput.append(self.xmlesc(xml.tail))
|
||||||
|
elif xml.text:
|
||||||
|
newoutput.append(">%s</%s>" % (self.xmlesc(xml.text), itag))
|
||||||
|
else:
|
||||||
|
newoutput.append(" />")
|
||||||
|
return u''.join(newoutput)
|
||||||
|
|
||||||
|
def xmlesc(self, text):
|
||||||
|
if type(text) != types.UnicodeType:
|
||||||
|
text = list(unicode(text, 'utf-8', 'ignore'))
|
||||||
|
else:
|
||||||
|
text = list(text)
|
||||||
|
|
||||||
|
cc = 0
|
||||||
|
matches = (u'&', u'<', u'"', u'>', u"'")
|
||||||
|
for c in text:
|
||||||
|
if c in matches:
|
||||||
|
if c == u'&':
|
||||||
|
text[cc] = u'&'
|
||||||
|
elif c == u'<':
|
||||||
|
text[cc] = u'<'
|
||||||
|
elif c == u'>':
|
||||||
|
text[cc] = u'>'
|
||||||
|
elif c == u"'":
|
||||||
|
text[cc] = u'''
|
||||||
|
else:
|
||||||
|
text[cc] = u'"'
|
||||||
|
cc += 1
|
||||||
|
return ''.join(text)
|
Loading…
Reference in a new issue