X7ROOT File Manager
Current Path:
/opt/alt/python36/lib64/python3.6/lib2to3/fixes
opt
/
alt
/
python36
/
lib64
/
python3.6
/
lib2to3
/
fixes
/
ðŸ“
..
📄
__init__.py
(47 B)
ðŸ“
__pycache__
📄
fix_apply.py
(2.37 KB)
📄
fix_asserts.py
(984 B)
📄
fix_basestring.py
(320 B)
📄
fix_buffer.py
(590 B)
📄
fix_dict.py
(3.67 KB)
📄
fix_except.py
(3.27 KB)
📄
fix_exec.py
(979 B)
📄
fix_execfile.py
(2 KB)
📄
fix_exitfunc.py
(2.44 KB)
📄
fix_filter.py
(2.59 KB)
📄
fix_funcattrs.py
(644 B)
📄
fix_future.py
(547 B)
📄
fix_getcwdu.py
(451 B)
📄
fix_has_key.py
(3.12 KB)
📄
fix_idioms.py
(4.76 KB)
📄
fix_import.py
(3.18 KB)
📄
fix_imports.py
(5.55 KB)
📄
fix_imports2.py
(289 B)
📄
fix_input.py
(708 B)
📄
fix_intern.py
(1.21 KB)
📄
fix_isinstance.py
(1.57 KB)
📄
fix_itertools.py
(1.51 KB)
📄
fix_itertools_imports.py
(2.04 KB)
📄
fix_long.py
(476 B)
📄
fix_map.py
(3.55 KB)
📄
fix_metaclass.py
(8 KB)
📄
fix_methodattrs.py
(606 B)
📄
fix_ne.py
(571 B)
📄
fix_next.py
(3.1 KB)
📄
fix_nonzero.py
(591 B)
📄
fix_numliterals.py
(768 B)
📄
fix_operator.py
(3.39 KB)
📄
fix_paren.py
(1.2 KB)
📄
fix_print.py
(2.78 KB)
📄
fix_raise.py
(2.86 KB)
📄
fix_raw_input.py
(454 B)
📄
fix_reduce.py
(837 B)
📄
fix_reload.py
(1.13 KB)
📄
fix_renames.py
(2.17 KB)
📄
fix_repr.py
(613 B)
📄
fix_set_literal.py
(1.66 KB)
📄
fix_standarderror.py
(449 B)
📄
fix_sys_exc.py
(1.01 KB)
📄
fix_throw.py
(1.54 KB)
📄
fix_tuple_params.py
(5.43 KB)
📄
fix_types.py
(1.73 KB)
📄
fix_unicode.py
(1.23 KB)
📄
fix_urllib.py
(8.16 KB)
📄
fix_ws_comma.py
(1.06 KB)
📄
fix_xrange.py
(2.63 KB)
📄
fix_xreadlines.py
(689 B)
📄
fix_zip.py
(1.26 KB)
Editing: fix_imports.py
"""Fix incompatible imports and module references.""" # Authors: Collin Winter, Nick Edds # Local imports from .. import fixer_base from ..fixer_util import Name, attr_chain MAPPING = {'StringIO': 'io', 'cStringIO': 'io', 'cPickle': 'pickle', '__builtin__' : 'builtins', 'copy_reg': 'copyreg', 'Queue': 'queue', 'SocketServer': 'socketserver', 'ConfigParser': 'configparser', 'repr': 'reprlib', 'FileDialog': 'tkinter.filedialog', 'tkFileDialog': 'tkinter.filedialog', 'SimpleDialog': 'tkinter.simpledialog', 'tkSimpleDialog': 'tkinter.simpledialog', 'tkColorChooser': 'tkinter.colorchooser', 'tkCommonDialog': 'tkinter.commondialog', 'Dialog': 'tkinter.dialog', 'Tkdnd': 'tkinter.dnd', 'tkFont': 'tkinter.font', 'tkMessageBox': 'tkinter.messagebox', 'ScrolledText': 'tkinter.scrolledtext', 'Tkconstants': 'tkinter.constants', 'Tix': 'tkinter.tix', 'ttk': 'tkinter.ttk', 'Tkinter': 'tkinter', 'markupbase': '_markupbase', '_winreg': 'winreg', 'thread': '_thread', 'dummy_thread': '_dummy_thread', # anydbm and whichdb are handled by fix_imports2 'dbhash': 'dbm.bsd', 'dumbdbm': 'dbm.dumb', 'dbm': 'dbm.ndbm', 'gdbm': 'dbm.gnu', 'xmlrpclib': 'xmlrpc.client', 'DocXMLRPCServer': 'xmlrpc.server', 'SimpleXMLRPCServer': 'xmlrpc.server', 'httplib': 'http.client', 'htmlentitydefs' : 'html.entities', 'HTMLParser' : 'html.parser', 'Cookie': 'http.cookies', 'cookielib': 'http.cookiejar', 'BaseHTTPServer': 'http.server', 'SimpleHTTPServer': 'http.server', 'CGIHTTPServer': 'http.server', #'test.test_support': 'test.support', 'commands': 'subprocess', 'UserString' : 'collections', 'UserList' : 'collections', 'urlparse' : 'urllib.parse', 'robotparser' : 'urllib.robotparser', } def alternates(members): return "(" + "|".join(map(repr, members)) + ")" def build_pattern(mapping=MAPPING): mod_list = ' | '.join(["module_name='%s'" % key for key in mapping]) bare_names = alternates(mapping.keys()) yield """name_import=import_name< 'import' ((%s) | multiple_imports=dotted_as_names< any* (%s) any* >) > """ % (mod_list, mod_list) yield """import_from< 'from' (%s) 'import' ['('] ( any | import_as_name< any 'as' any > | import_as_names< any* >) [')'] > """ % mod_list yield """import_name< 'import' (dotted_as_name< (%s) 'as' any > | multiple_imports=dotted_as_names< any* dotted_as_name< (%s) 'as' any > any* >) > """ % (mod_list, mod_list) # Find usages of module members in code e.g. thread.foo(bar) yield "power< bare_with_attr=(%s) trailer<'.' any > any* >" % bare_names class FixImports(fixer_base.BaseFix): BM_compatible = True keep_line_order = True # This is overridden in fix_imports2. mapping = MAPPING # We want to run this fixer late, so fix_import doesn't try to make stdlib # renames into relative imports. run_order = 6 def build_pattern(self): return "|".join(build_pattern(self.mapping)) def compile_pattern(self): # We override this, so MAPPING can be pragmatically altered and the # changes will be reflected in PATTERN. self.PATTERN = self.build_pattern() super(FixImports, self).compile_pattern() # Don't match the node if it's within another match. def match(self, node): match = super(FixImports, self).match results = match(node) if results: # Module usage could be in the trailer of an attribute lookup, so we # might have nested matches when "bare_with_attr" is present. if "bare_with_attr" not in results and \ any(match(obj) for obj in attr_chain(node, "parent")): return False return results return False def start_tree(self, tree, filename): super(FixImports, self).start_tree(tree, filename) self.replace = {} def transform(self, node, results): import_mod = results.get("module_name") if import_mod: mod_name = import_mod.value new_name = self.mapping[mod_name] import_mod.replace(Name(new_name, prefix=import_mod.prefix)) if "name_import" in results: # If it's not a "from x import x, y" or "import x as y" import, # marked its usage to be replaced. self.replace[mod_name] = new_name if "multiple_imports" in results: # This is a nasty hack to fix multiple imports on a line (e.g., # "import StringIO, urlparse"). The problem is that I can't # figure out an easy way to make a pattern recognize the keys of # MAPPING randomly sprinkled in an import statement. results = self.match(node) if results: self.transform(node, results) else: # Replace usage of the module. bare_name = results["bare_with_attr"][0] new_name = self.replace.get(bare_name.value) if new_name: bare_name.replace(Name(new_name, prefix=bare_name.prefix))
Upload File
Create Folder