Skip to content

Commit

Permalink
Get rid of Python 2 basestring and unicode (#346)
Browse files Browse the repository at this point in the history
In Python 3, it's just str.
  • Loading branch information
DimitriPapadopoulos authored and martinblech committed Oct 8, 2024
1 parent 71b55aa commit 5b1b511
Showing 1 changed file with 11 additions and 24 deletions.
35 changes: 11 additions & 24 deletions xmltodict.py
Original file line number Diff line number Diff line change
Expand Up @@ -14,15 +14,6 @@

from inspect import isgenerator

try: # pragma no cover
_basestring = basestring
except NameError: # pragma no cover
_basestring = str
try: # pragma no cover
_unicode = unicode
except NameError: # pragma no cover
_unicode = str

__author__ = 'Martin Blech'
__version__ = '0.13.0'
__license__ = 'MIT'
Expand Down Expand Up @@ -327,9 +318,8 @@ def parse(xml_input, encoding=None, expat=expat, process_namespaces=False,
"""
handler = _DictSAXHandler(namespace_separator=namespace_separator,
**kwargs)
if isinstance(xml_input, _unicode):
if not encoding:
encoding = 'utf-8'
if isinstance(xml_input, str):
encoding = encoding or 'utf-8'
xml_input = xml_input.encode(encoding)
if not process_namespaces:
namespace_separator = None
Expand Down Expand Up @@ -404,24 +394,21 @@ def _emit(key, value, content_handler,
if result is None:
return
key, value = result
if not hasattr(value, '__iter__') or isinstance(value, (_basestring, dict)):
if not hasattr(value, '__iter__') or isinstance(value, (str, dict)):
value = [value]
for index, v in enumerate(value):
if full_document and depth == 0 and index > 0:
raise ValueError('document with multiple roots')
if v is None:
v = _dict()
elif isinstance(v, bool):
if v:
v = _unicode('true')
else:
v = _unicode('false')
elif not isinstance(v, dict):
if expand_iter and hasattr(v, '__iter__') and not isinstance(v, _basestring):
v = 'true' if v else 'false'
elif not isinstance(v, (dict, str)):
if expand_iter and hasattr(v, '__iter__'):
v = _dict(((expand_iter, v),))
else:
v = _unicode(v)
if isinstance(v, _basestring):
v = str(v)
if isinstance(v, str):
v = _dict(((cdata_key, v),))
cdata = None
attrs = _dict()
Expand All @@ -436,10 +423,10 @@ def _emit(key, value, content_handler,
if ik == '@xmlns' and isinstance(iv, dict):
for k, v in iv.items():
attr = 'xmlns{}'.format(f':{k}' if k else '')
attrs[attr] = _unicode(v)
attrs[attr] = str(v)
continue
if not isinstance(iv, _unicode):
iv = _unicode(iv)
if not isinstance(iv, str):
iv = str(iv)
attrs[ik[len(attr_prefix):]] = iv
continue
children.append((ik, iv))
Expand Down

0 comments on commit 5b1b511

Please sign in to comment.