GRAYBYTE WORDPRESS FILE MANAGER9634

Server IP : 198.54.121.189 / Your IP : 216.73.216.140
System : Linux premium69.web-hosting.com 4.18.0-553.44.1.lve.el8.x86_64 #1 SMP Thu Mar 13 14:29:12 UTC 2025 x86_64
PHP Version : 7.4.33
Disable Function : NONE
cURL : ON | WGET : ON | Sudo : OFF | Pkexec : OFF
Directory : /usr/lib64/python3.8/lib2to3/fixes/
Upload Files :
Current_dir [ Not Writeable ] Document_root [ Writeable ]

Command :


Current File : /usr/lib64/python3.8/lib2to3/fixes//fix_urllib.py
"""Fix changes imports of urllib which are now incompatible.
   This is rather similar to fix_imports, but because of the more
   complex nature of the fixing for urllib, it has its own fixer.
"""
# Author: Nick Edds

# Local imports
from lib2to3.fixes.fix_imports import alternates, FixImports
from lib2to3.fixer_util import (Name, Comma, FromImport, Newline,
                                find_indentation, Node, syms)

MAPPING = {"urllib":  [
                ("urllib.request",
                    ["URLopener", "FancyURLopener", "urlretrieve",
                     "_urlopener", "urlopen", "urlcleanup",
                     "pathname2url", "url2pathname"]),
                ("urllib.parse",
                    ["quote", "quote_plus", "unquote", "unquote_plus",
                     "urlencode", "splitattr", "splithost", "splitnport",
                     "splitpasswd", "splitport", "splitquery", "splittag",
                     "splittype", "splituser", "splitvalue", ]),
                ("urllib.error",
                    ["ContentTooShortError"])],
           "urllib2" : [
                ("urllib.request",
                    ["urlopen", "install_opener", "build_opener",
                     "Request", "OpenerDirector", "BaseHandler",
                     "HTTPDefaultErrorHandler", "HTTPRedirectHandler",
                     "HTTPCookieProcessor", "ProxyHandler",
                     "HTTPPasswordMgr",
                     "HTTPPasswordMgrWithDefaultRealm",
                     "AbstractBasicAuthHandler",
                     "HTTPBasicAuthHandler", "ProxyBasicAuthHandler",
                     "AbstractDigestAuthHandler",
                     "HTTPDigestAuthHandler", "ProxyDigestAuthHandler",
                     "HTTPHandler", "HTTPSHandler", "FileHandler",
                     "FTPHandler", "CacheFTPHandler",
                     "UnknownHandler"]),
                ("urllib.error",
                    ["URLError", "HTTPError"]),
           ]
}

# Duplicate the url parsing functions for urllib2.
MAPPING["urllib2"].append(MAPPING["urllib"][1])


def build_pattern():
    bare = set()
    for old_module, changes in MAPPING.items():
        for change in changes:
            new_module, members = change
            members = alternates(members)
            yield """import_name< 'import' (module=%r
                                  | dotted_as_names< any* module=%r any* >) >
                  """ % (old_module, old_module)
            yield """import_from< 'from' mod_member=%r 'import'
                       ( member=%s | import_as_name< member=%s 'as' any > |
                         import_as_names< members=any*  >) >
                  """ % (old_module, members, members)
            yield """import_from< 'from' module_star=%r 'import' star='*' >
                  """ % old_module
            yield """import_name< 'import'
                                  dotted_as_name< module_as=%r 'as' any > >
                  """ % old_module
            # bare_with_attr has a special significance for FixImports.match().
            yield """power< bare_with_attr=%r trailer< '.' member=%s > any* >
                  """ % (old_module, members)


class FixUrllib(FixImports):

    def build_pattern(self):
        return "|".join(build_pattern())

    def transform_import(self, node, results):
        """Transform for the basic import case. Replaces the old
           import name with a comma separated list of its
           replacements.
        """
        import_mod = results.get("module")
        pref = import_mod.prefix

        names = []

        # create a Node list of the replacement modules
        for name in MAPPING[import_mod.value][:-1]:
            names.extend([Name(name[0], prefix=pref), Comma()])
        names.append(Name(MAPPING[import_mod.value][-1][0], prefix=pref))
        import_mod.replace(names)

    def transform_member(self, node, results):
        """Transform for imports of specific module elements. Replaces
           the module to be imported from with the appropriate new
           module.
        """
        mod_member = results.get("mod_member")
        pref = mod_member.prefix
        member = results.get("member")

        # Simple case with only a single member being imported
        if member:
            # this may be a list of length one, or just a node
            if isinstance(member, list):
                member = member[0]
            new_name = None
            for change in MAPPING[mod_member.value]:
                if member.value in change[1]:
                    new_name = change[0]
                    break
            if new_name:
                mod_member.replace(Name(new_name, prefix=pref))
            else:
                self.cannot_convert(node, "This is an invalid module element")

        # Multiple members being imported
        else:
            # a dictionary for replacements, order matters
            modules = []
            mod_dict = {}
            members = results["members"]
            for member in members:
                # we only care about the actual members
                if member.type == syms.import_as_name:
                    as_name = member.children[2].value
                    member_name = member.children[0].value
                else:
                    member_name = member.value
                    as_name = None
                if member_name != ",":
                    for change in MAPPING[mod_member.value]:
                        if member_name in change[1]:
                            if change[0] not in mod_dict:
                                modules.append(change[0])
                            mod_dict.setdefault(change[0], []).append(member)

            new_nodes = []
            indentation = find_indentation(node)
            first = True
            def handle_name(name, prefix):
                if name.type == syms.import_as_name:
                    kids = [Name(name.children[0].value, prefix=prefix),
                            name.children[1].clone(),
                            name.children[2].clone()]
                    return [Node(syms.import_as_name, kids)]
                return [Name(name.value, prefix=prefix)]
            for module in modules:
                elts = mod_dict[module]
                names = []
                for elt in elts[:-1]:
                    names.extend(handle_name(elt, pref))
                    names.append(Comma())
                names.extend(handle_name(elts[-1], pref))
                new = FromImport(module, names)
                if not first or node.parent.prefix.endswith(indentation):
                    new.prefix = indentation
                new_nodes.append(new)
                first = False
            if new_nodes:
                nodes = []
                for new_node in new_nodes[:-1]:
                    nodes.extend([new_node, Newline()])
                nodes.append(new_nodes[-1])
                node.replace(nodes)
            else:
                self.cannot_convert(node, "All module elements are invalid")

    def transform_dot(self, node, results):
        """Transform for calls to module members in code."""
        module_dot = results.get("bare_with_attr")
        member = results.get("member")
        new_name = None
        if isinstance(member, list):
            member = member[0]
        for change in MAPPING[module_dot.value]:
            if member.value in change[1]:
                new_name = change[0]
                break
        if new_name:
            module_dot.replace(Name(new_name,
                                    prefix=module_dot.prefix))
        else:
            self.cannot_convert(node, "This is an invalid module element")

    def transform(self, node, results):
        if results.get("module"):
            self.transform_import(node, results)
        elif results.get("mod_member"):
            self.transform_member(node, results)
        elif results.get("bare_with_attr"):
            self.transform_dot(node, results)
        # Renaming and star imports are not supported for these modules.
        elif results.get("module_star"):
            self.cannot_convert(node, "Cannot handle star imports.")
        elif results.get("module_as"):
            self.cannot_convert(node, "This module is now multiple modules")

[ Back ]
Name
Size
Last Modified
Owner / Group
Permissions
Options
..
--
March 05 2024 23:45:16
root / root
0755
__pycache__
--
March 05 2024 23:45:16
root / root
0755
__init__.py
0.046 KB
June 06 2023 13:32:21
root / root
0644
fix_apply.py
2.291 KB
June 06 2023 13:32:21
root / root
0644
fix_asserts.py
0.961 KB
June 06 2023 13:32:21
root / root
0644
fix_basestring.py
0.313 KB
June 06 2023 13:32:21
root / root
0644
fix_buffer.py
0.576 KB
June 06 2023 13:32:21
root / root
0644
fix_dict.py
3.672 KB
June 06 2023 13:32:21
root / root
0644
fix_except.py
3.266 KB
June 06 2023 13:32:21
root / root
0644
fix_exec.py
0.956 KB
June 06 2023 13:32:21
root / root
0644
fix_execfile.py
2 KB
June 06 2023 13:32:21
root / root
0644
fix_exitfunc.py
2.437 KB
June 06 2023 13:32:21
root / root
0644
fix_filter.py
2.7 KB
June 06 2023 13:32:21
root / root
0644
fix_funcattrs.py
0.629 KB
June 06 2023 13:32:21
root / root
0644
fix_future.py
0.534 KB
June 06 2023 13:32:21
root / root
0644
fix_getcwdu.py
0.44 KB
June 06 2023 13:32:21
root / root
0644
fix_has_key.py
3.121 KB
June 06 2023 13:32:21
root / root
0644
fix_idioms.py
4.762 KB
June 06 2023 13:32:21
root / root
0644
fix_import.py
3.18 KB
June 06 2023 13:32:21
root / root
0644
fix_imports.py
5.551 KB
June 06 2023 13:32:21
root / root
0644
fix_imports2.py
0.282 KB
June 06 2023 13:32:21
root / root
0644
fix_input.py
0.691 KB
June 06 2023 13:32:21
root / root
0644
fix_intern.py
1.117 KB
June 06 2023 13:32:21
root / root
0644
fix_isinstance.py
1.57 KB
June 06 2023 13:32:21
root / root
0644
fix_itertools.py
1.512 KB
June 06 2023 13:32:21
root / root
0644
fix_itertools_imports.py
2.037 KB
June 06 2023 13:32:21
root / root
0644
fix_long.py
0.465 KB
June 06 2023 13:32:21
root / root
0644
fix_map.py
3.555 KB
June 06 2023 13:32:21
root / root
0644
fix_metaclass.py
8.004 KB
June 06 2023 13:32:21
root / root
0644
fix_methodattrs.py
0.592 KB
June 06 2023 13:32:21
root / root
0644
fix_ne.py
0.558 KB
June 06 2023 13:32:21
root / root
0644
fix_next.py
3.1 KB
June 06 2023 13:32:21
root / root
0644
fix_nonzero.py
0.577 KB
June 06 2023 13:32:21
root / root
0644
fix_numliterals.py
0.75 KB
June 06 2023 13:32:21
root / root
0644
fix_operator.py
3.346 KB
June 06 2023 13:32:21
root / root
0644
fix_paren.py
1.198 KB
June 06 2023 13:32:21
root / root
0644
fix_print.py
2.777 KB
June 06 2023 13:32:21
root / root
0644
fix_raise.py
2.857 KB
June 06 2023 13:32:21
root / root
0644
fix_raw_input.py
0.443 KB
June 06 2023 13:32:21
root / root
0644
fix_reduce.py
0.817 KB
June 06 2023 13:32:21
root / root
0644
fix_reload.py
1.056 KB
June 06 2023 13:32:21
root / root
0644
fix_renames.py
2.169 KB
June 06 2023 13:32:21
root / root
0644
fix_repr.py
0.599 KB
June 06 2023 13:32:21
root / root
0644
fix_set_literal.py
1.657 KB
June 06 2023 13:32:21
root / root
0644
fix_standarderror.py
0.438 KB
June 06 2023 13:32:21
root / root
0644
fix_sys_exc.py
1.01 KB
June 06 2023 13:32:21
root / root
0644
fix_throw.py
1.545 KB
June 06 2023 13:32:21
root / root
0644
fix_tuple_params.py
5.435 KB
June 06 2023 13:32:21
root / root
0644
fix_types.py
1.732 KB
June 06 2023 13:32:21
root / root
0644
fix_unicode.py
1.227 KB
June 06 2023 13:32:21
root / root
0644
fix_urllib.py
8.157 KB
June 06 2023 13:32:21
root / root
0644
fix_ws_comma.py
1.064 KB
June 06 2023 13:32:21
root / root
0644
fix_xrange.py
2.631 KB
June 06 2023 13:32:21
root / root
0644
fix_xreadlines.py
0.673 KB
June 06 2023 13:32:21
root / root
0644
fix_zip.py
1.259 KB
June 06 2023 13:32:21
root / root
0644

GRAYBYTE WORDPRESS FILE MANAGER @ 2025
CONTACT ME
Static GIF