Hackfut Security File Manager
Current Path:
/usr/lib64/python2.6/lib2to3/fixes
usr
/
lib64
/
python2.6
/
lib2to3
/
fixes
/
📁
..
📄
__init__.py
(47 B)
📄
__init__.pyc
(133 B)
📄
__init__.pyo
(133 B)
📄
fix_apply.py
(1.83 KB)
📄
fix_apply.pyc
(1.81 KB)
📄
fix_apply.pyo
(1.78 KB)
📄
fix_basestring.py
(296 B)
📄
fix_basestring.pyc
(772 B)
📄
fix_basestring.pyo
(772 B)
📄
fix_buffer.py
(566 B)
📄
fix_buffer.pyc
(938 B)
📄
fix_buffer.pyo
(938 B)
📄
fix_callable.py
(1.09 KB)
📄
fix_callable.pyc
(1.41 KB)
📄
fix_callable.pyo
(1.41 KB)
📄
fix_dict.py
(3.71 KB)
📄
fix_dict.pyc
(3.7 KB)
📄
fix_dict.pyo
(3.58 KB)
📄
fix_except.py
(3.25 KB)
📄
fix_except.pyc
(2.98 KB)
📄
fix_except.pyo
(2.98 KB)
📄
fix_exec.py
(977 B)
📄
fix_exec.pyc
(1.37 KB)
📄
fix_exec.pyo
(1.34 KB)
📄
fix_execfile.py
(1.93 KB)
📄
fix_execfile.pyc
(2 KB)
📄
fix_execfile.pyo
(1.96 KB)
📄
fix_exitfunc.py
(2.4 KB)
📄
fix_exitfunc.pyc
(2.64 KB)
📄
fix_exitfunc.pyo
(2.64 KB)
📄
fix_filter.py
(2.03 KB)
📄
fix_filter.pyc
(2.19 KB)
📄
fix_filter.pyo
(2.19 KB)
📄
fix_funcattrs.py
(619 B)
📄
fix_funcattrs.pyc
(1.07 KB)
📄
fix_funcattrs.pyo
(1.07 KB)
📄
fix_future.py
(521 B)
📄
fix_future.pyc
(898 B)
📄
fix_future.pyo
(898 B)
📄
fix_getcwdu.py
(427 B)
📄
fix_getcwdu.pyc
(905 B)
📄
fix_getcwdu.pyo
(905 B)
📄
fix_has_key.py
(3.13 KB)
📄
fix_has_key.pyc
(3.14 KB)
📄
fix_has_key.pyo
(3.1 KB)
📄
fix_idioms.py
(4.78 KB)
📄
fix_idioms.pyc
(4.46 KB)
📄
fix_idioms.pyo
(4.35 KB)
📄
fix_import.py
(3.16 KB)
📄
fix_import.pyc
(3.2 KB)
📄
fix_import.pyo
(3.2 KB)
📄
fix_imports.py
(5.51 KB)
📄
fix_imports.pyc
(5.23 KB)
📄
fix_imports.pyo
(5.23 KB)
📄
fix_imports2.py
(289 B)
📄
fix_imports2.pyc
(634 B)
📄
fix_imports2.pyo
(634 B)
📄
fix_input.py
(685 B)
📄
fix_input.pyc
(1.09 KB)
📄
fix_input.pyo
(1.09 KB)
📄
fix_intern.py
(1.33 KB)
📄
fix_intern.pyc
(1.54 KB)
📄
fix_intern.pyo
(1.54 KB)
📄
fix_isinstance.py
(1.55 KB)
📄
fix_isinstance.pyc
(1.79 KB)
📄
fix_isinstance.pyo
(1.79 KB)
📄
fix_itertools.py
(1.44 KB)
📄
fix_itertools.pyc
(1.66 KB)
📄
fix_itertools.pyo
(1.66 KB)
📄
fix_itertools_imports.py
(1.8 KB)
📄
fix_itertools_imports.pyc
(1.82 KB)
📄
fix_itertools_imports.pyo
(1.77 KB)
📄
fix_long.py
(453 B)
📄
fix_long.pyc
(822 B)
📄
fix_long.pyo
(822 B)
📄
fix_map.py
(2.97 KB)
📄
fix_map.pyc
(2.96 KB)
📄
fix_map.pyo
(2.96 KB)
📄
fix_metaclass.py
(8 KB)
📄
fix_metaclass.pyc
(6.5 KB)
📄
fix_metaclass.pyo
(6.45 KB)
📄
fix_methodattrs.py
(590 B)
📄
fix_methodattrs.pyc
(1.09 KB)
📄
fix_methodattrs.pyo
(1.09 KB)
📄
fix_ne.py
(573 B)
📄
fix_ne.pyc
(1001 B)
📄
fix_ne.pyo
(1001 B)
📄
fix_next.py
(3.08 KB)
📄
fix_next.pyc
(3.51 KB)
📄
fix_next.pyo
(3.48 KB)
📄
fix_nonzero.py
(573 B)
📄
fix_nonzero.pyc
(1.04 KB)
📄
fix_nonzero.pyo
(1.04 KB)
📄
fix_numliterals.py
(773 B)
📄
fix_numliterals.pyc
(1.24 KB)
📄
fix_numliterals.pyo
(1.24 KB)
📄
fix_operator.py
(1.46 KB)
📄
fix_operator.pyc
(1.72 KB)
📄
fix_operator.pyo
(1.72 KB)
📄
fix_paren.py
(1.17 KB)
📄
fix_paren.pyc
(1.49 KB)
📄
fix_paren.pyo
(1.49 KB)
📄
fix_print.py
(2.77 KB)
📄
fix_print.pyc
(2.69 KB)
📄
fix_print.pyo
(2.59 KB)
📄
fix_raise.py
(2.5 KB)
📄
fix_raise.pyc
(2.32 KB)
📄
fix_raise.pyo
(2.32 KB)
📄
fix_raw_input.py
(430 B)
📄
fix_raw_input.pyc
(915 B)
📄
fix_raw_input.pyo
(915 B)
📄
fix_reduce.py
(795 B)
📄
fix_reduce.pyc
(1.19 KB)
📄
fix_reduce.pyo
(1.19 KB)
📄
fix_renames.py
(2.14 KB)
📄
fix_renames.pyc
(2.39 KB)
📄
fix_renames.pyo
(2.39 KB)
📄
fix_repr.py
(589 B)
📄
fix_repr.pyc
(997 B)
📄
fix_repr.pyo
(997 B)
📄
fix_set_literal.py
(1.63 KB)
📄
fix_set_literal.pyc
(1.94 KB)
📄
fix_set_literal.pyo
(1.94 KB)
📄
fix_standarderror.py
(426 B)
📄
fix_standarderror.pyc
(832 B)
📄
fix_standarderror.pyo
(832 B)
📄
fix_sys_exc.py
(1014 B)
📄
fix_sys_exc.pyc
(1.65 KB)
📄
fix_sys_exc.pyo
(1.65 KB)
📄
fix_throw.py
(1.53 KB)
📄
fix_throw.pyc
(1.95 KB)
📄
fix_throw.pyo
(1.95 KB)
📄
fix_tuple_params.py
(5.33 KB)
📄
fix_tuple_params.pyc
(5.36 KB)
📄
fix_tuple_params.pyo
(5.36 KB)
📄
fix_types.py
(1.74 KB)
📄
fix_types.pyc
(2.13 KB)
📄
fix_types.pyo
(2.13 KB)
📄
fix_unicode.py
(696 B)
📄
fix_unicode.pyc
(1.14 KB)
📄
fix_unicode.pyo
(1.14 KB)
📄
fix_urllib.py
(7.33 KB)
📄
fix_urllib.pyc
(6.32 KB)
📄
fix_urllib.pyo
(6.32 KB)
📄
fix_ws_comma.py
(1.07 KB)
📄
fix_ws_comma.pyc
(1.37 KB)
📄
fix_ws_comma.pyo
(1.37 KB)
📄
fix_xrange.py
(2.61 KB)
📄
fix_xrange.pyc
(3 KB)
📄
fix_xrange.pyo
(3 KB)
📄
fix_xreadlines.py
(665 B)
📄
fix_xreadlines.pyc
(1.12 KB)
📄
fix_xreadlines.pyo
(1.12 KB)
📄
fix_zip.py
(879 B)
📄
fix_zip.pyc
(1.3 KB)
📄
fix_zip.pyo
(1.3 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): # 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 = unicode(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