diff env/lib/python3.7/site-packages/boto/compat.py @ 5:9b1c78e6ba9c draft default tip

"planemo upload commit 6c0a8142489327ece472c84e558c47da711a9142"
author shellac
date Mon, 01 Jun 2020 08:59:25 -0400
parents 79f47841a781
children
line wrap: on
line diff
--- a/env/lib/python3.7/site-packages/boto/compat.py	Thu May 14 16:47:39 2020 -0400
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,102 +0,0 @@
-# Copyright (c) 2012 Amazon.com, Inc. or its affiliates.  All Rights Reserved
-#
-# Permission is hereby granted, free of charge, to any person obtaining a
-# copy of this software and associated documentation files (the
-# "Software"), to deal in the Software without restriction, including
-# without limitation the rights to use, copy, modify, merge, publish, dis-
-# tribute, sublicense, and/or sell copies of the Software, and to permit
-# persons to whom the Software is furnished to do so, subject to the fol-
-# lowing conditions:
-#
-# The above copyright notice and this permission notice shall be included
-# in all copies or substantial portions of the Software.
-#
-# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
-# OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABIL-
-# ITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT
-# SHALL THE AUTHOR BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY,
-# WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
-# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
-# IN THE SOFTWARE.
-#
-import os
-
-# This allows boto modules to say "from boto.compat import json".  This is
-# preferred so that all modules don't have to repeat this idiom.
-try:
-    import simplejson as json
-except ImportError:
-    import json
-
-
-# Switch to use encodebytes, which deprecates encodestring in Python 3
-try:
-    from base64 import encodebytes
-except ImportError:
-    from base64 import encodestring as encodebytes
-
-
-# If running in Google App Engine there is no "user" and
-# os.path.expanduser() will fail. Attempt to detect this case and use a
-# no-op expanduser function in this case.
-try:
-    os.path.expanduser('~')
-    expanduser = os.path.expanduser
-except (AttributeError, ImportError):
-    # This is probably running on App Engine.
-    expanduser = (lambda x: x)
-
-from boto.vendored import six
-
-from boto.vendored.six import BytesIO, StringIO
-from boto.vendored.six.moves import filter, http_client, map, _thread, \
-                                    urllib, zip
-from boto.vendored.six.moves.queue import Queue
-from boto.vendored.six.moves.urllib.parse import parse_qs, quote, unquote, \
-                                                 urlparse, urlsplit
-from boto.vendored.six.moves.urllib.parse import unquote_plus
-from boto.vendored.six.moves.urllib.request import urlopen
-
-if six.PY3:
-    # StandardError was removed, so use the base exception type instead
-    StandardError = Exception
-    long_type = int
-    from configparser import ConfigParser, NoOptionError, NoSectionError
-    unquote_str = unquote_plus
-    parse_qs_safe = parse_qs
-else:
-    StandardError = StandardError
-    long_type = long
-    from ConfigParser import SafeConfigParser as ConfigParser
-    from ConfigParser import NoOptionError, NoSectionError
-
-    def unquote_str(value, encoding='utf-8'):
-        # In python2, unquote() gives us a string back that has the urldecoded
-        # bits, but not the unicode parts.  We need to decode this manually.
-        # unquote has special logic in which if it receives a unicode object it
-        # will decode it to latin1.  This is hard coded.  To avoid this, we'll
-        # encode the string with the passed in encoding before trying to
-        # unquote it.
-        byte_string = value.encode(encoding)
-        return unquote_plus(byte_string).decode(encoding)
-
-    # These are the same default arguments for python3's
-    # urllib.parse.parse_qs.
-    def parse_qs_safe(qs, keep_blank_values=False, strict_parsing=False,
-                      encoding='utf-8', errors='replace'):
-        """Parse a query handling unicode arguments properly in Python 2."""
-        is_text_type = isinstance(qs, six.text_type)
-        if is_text_type:
-            # URL encoding uses ASCII code points only.
-            qs = qs.encode('ascii')
-        qs_dict = parse_qs(qs, keep_blank_values, strict_parsing)
-        if is_text_type:
-            # Decode the parsed dictionary back to unicode.
-            result = {}
-            for (name, value) in qs_dict.items():
-                decoded_name = name.decode(encoding, errors)
-                decoded_value = [item.decode(encoding, errors)
-                                 for item in value]
-                result[decoded_name] = decoded_value
-            return result
-        return qs_dict