Mercurial > repos > guerler > springsuite
diff planemo/lib/python3.7/site-packages/bleach/utils.py @ 0:d30785e31577 draft
"planemo upload commit 6eee67778febed82ddd413c3ca40b3183a3898f1"
| author | guerler | 
|---|---|
| date | Fri, 31 Jul 2020 00:18:57 -0400 | 
| parents | |
| children | 
line wrap: on
 line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/planemo/lib/python3.7/site-packages/bleach/utils.py Fri Jul 31 00:18:57 2020 -0400 @@ -0,0 +1,44 @@ +from collections import OrderedDict + +import six + + +def _attr_key(attr): + """Returns appropriate key for sorting attribute names + + Attribute names are a tuple of ``(namespace, name)`` where namespace can be + ``None`` or a string. These can't be compared in Python 3, so we conver the + ``None`` to an empty string. + + """ + key = (attr[0][0] or ''), attr[0][1] + return key + + +def alphabetize_attributes(attrs): + """Takes a dict of attributes (or None) and returns them alphabetized""" + if not attrs: + return attrs + + return OrderedDict( + [(k, v) for k, v in sorted(attrs.items(), key=_attr_key)] + ) + + +def force_unicode(text): + """Takes a text (Python 2: str/unicode; Python 3: unicode) and converts to unicode + + :arg str/unicode text: the text in question + + :returns: text as unicode + + :raises UnicodeDecodeError: if the text was a Python 2 str and isn't in + utf-8 + + """ + # If it's already unicode, then return it + if isinstance(text, six.text_type): + return text + + # If not, convert it + return six.text_type(text, 'utf-8', 'strict')
