Current Path: > > opt > alt > > python39 > lib64 > python3.9
Operation : Linux premium131.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 Software : Apache Server IP : 162.0.232.56 | Your IP: 216.73.216.111 Domains : 1034 Domain(s) Permission : [ 0755 ]
Name | Type | Size | Last Modified | Actions |
---|---|---|---|---|
__pycache__ | Directory | - | - | |
asyncio | Directory | - | - | |
collections | Directory | - | - | |
concurrent | Directory | - | - | |
config-3.9-x86_64-linux-gnu | Directory | - | - | |
ctypes | Directory | - | - | |
curses | Directory | - | - | |
dbm | Directory | - | - | |
distutils | Directory | - | - | |
Directory | - | - | ||
encodings | Directory | - | - | |
ensurepip | Directory | - | - | |
html | Directory | - | - | |
http | Directory | - | - | |
importlib | Directory | - | - | |
json | Directory | - | - | |
lib-dynload | Directory | - | - | |
lib2to3 | Directory | - | - | |
logging | Directory | - | - | |
multiprocessing | Directory | - | - | |
pydoc_data | Directory | - | - | |
site-packages | Directory | - | - | |
sqlite3 | Directory | - | - | |
unittest | Directory | - | - | |
urllib | Directory | - | - | |
venv | Directory | - | - | |
wsgiref | Directory | - | - | |
xml | Directory | - | - | |
xmlrpc | Directory | - | - | |
zoneinfo | Directory | - | - | |
LICENSE.txt | File | 13937 bytes | June 03 2025 18:47:52. | |
__future__.py | File | 5147 bytes | June 03 2025 18:47:52. | |
__phello__.foo.py | File | 64 bytes | June 03 2025 18:47:52. | |
_aix_support.py | File | 3389 bytes | June 03 2025 18:47:52. | |
_bootlocale.py | File | 1801 bytes | June 03 2025 18:47:52. | |
_bootsubprocess.py | File | 2675 bytes | June 03 2025 18:47:52. | |
_collections_abc.py | File | 29374 bytes | June 03 2025 18:47:52. | |
_compat_pickle.py | File | 8749 bytes | June 03 2025 18:47:52. | |
_compression.py | File | 5340 bytes | June 03 2025 18:47:52. | |
_markupbase.py | File | 14623 bytes | June 03 2025 18:47:52. | |
_osx_support.py | File | 21773 bytes | June 03 2025 18:47:52. | |
_py_abc.py | File | 6189 bytes | June 03 2025 18:47:52. | |
_pydecimal.py | File | 228666 bytes | June 03 2025 18:47:52. | |
_pyio.py | File | 93316 bytes | June 03 2025 18:47:52. | |
_sitebuiltins.py | File | 3115 bytes | June 03 2025 18:47:52. | |
_strptime.py | File | 25277 bytes | June 03 2025 18:47:52. | |
_sysconfigdata__linux_x86_64-linux-gnu.py | File | 40536 bytes | June 19 2025 12:09:48. | |
_sysconfigdata_d_linux_x86_64-linux-gnu.py | File | 40272 bytes | June 19 2025 12:00:02. | |
_threading_local.py | File | 7220 bytes | June 03 2025 18:47:52. | |
_weakrefset.py | File | 5923 bytes | June 03 2025 18:47:52. | |
abc.py | File | 4920 bytes | June 03 2025 18:47:52. | |
aifc.py | File | 32605 bytes | June 03 2025 18:47:52. | |
antigravity.py | File | 500 bytes | June 03 2025 18:47:52. | |
argparse.py | File | 98119 bytes | June 03 2025 18:47:52. | |
ast.py | File | 56256 bytes | June 03 2025 18:47:52. | |
asynchat.py | File | 11321 bytes | June 03 2025 18:47:52. | |
asyncore.py | File | 20102 bytes | June 03 2025 18:47:52. | |
base64.py | File | 19872 bytes | June 03 2025 18:47:52. | |
bdb.py | File | 31389 bytes | June 03 2025 18:47:52. | |
binhex.py | File | 14784 bytes | June 03 2025 18:47:52. | |
bisect.py | File | 2350 bytes | June 03 2025 18:47:52. | |
bz2.py | File | 12447 bytes | June 03 2025 18:47:52. | |
cProfile.py | File | 6358 bytes | June 03 2025 18:47:52. | |
calendar.py | File | 24832 bytes | June 03 2025 18:47:52. | |
cgi.py | File | 33945 bytes | June 03 2025 18:47:52. | |
cgitb.py | File | 12096 bytes | June 03 2025 18:47:52. | |
chunk.py | File | 5435 bytes | June 03 2025 18:47:52. | |
cmd.py | File | 14860 bytes | June 03 2025 18:47:52. | |
code.py | File | 10622 bytes | June 03 2025 18:47:52. | |
codecs.py | File | 36673 bytes | June 03 2025 18:47:52. | |
codeop.py | File | 6326 bytes | June 03 2025 18:47:52. | |
colorsys.py | File | 4064 bytes | June 03 2025 18:47:52. | |
compileall.py | File | 20105 bytes | June 03 2025 18:47:52. | |
configparser.py | File | 54584 bytes | June 03 2025 18:47:52. | |
contextlib.py | File | 24624 bytes | June 03 2025 18:47:52. | |
contextvars.py | File | 129 bytes | June 03 2025 18:47:52. | |
copy.py | File | 8650 bytes | June 03 2025 18:47:52. | |
copyreg.py | File | 7274 bytes | June 03 2025 18:47:52. | |
crypt.py | File | 3819 bytes | June 03 2025 18:47:52. | |
csv.py | File | 16144 bytes | June 03 2025 18:47:52. | |
dataclasses.py | File | 49586 bytes | June 03 2025 18:47:52. | |
datetime.py | File | 89177 bytes | June 03 2025 18:47:52. | |
decimal.py | File | 320 bytes | June 03 2025 18:47:52. | |
difflib.py | File | 83307 bytes | June 03 2025 18:47:52. | |
dis.py | File | 20570 bytes | June 03 2025 18:47:52. | |
doctest.py | File | 104568 bytes | June 03 2025 18:47:52. | |
enum.py | File | 39440 bytes | June 03 2025 18:47:52. | |
filecmp.py | File | 10024 bytes | June 03 2025 18:47:52. | |
fileinput.py | File | 14791 bytes | June 03 2025 18:47:52. | |
fnmatch.py | File | 6004 bytes | June 03 2025 18:47:52. | |
formatter.py | File | 15143 bytes | June 03 2025 18:47:52. | |
fractions.py | File | 24323 bytes | June 03 2025 18:47:52. | |
ftplib.py | File | 35496 bytes | June 03 2025 18:47:52. | |
functools.py | File | 38881 bytes | June 03 2025 18:47:52. | |
genericpath.py | File | 5246 bytes | June 03 2025 18:47:52. | |
getopt.py | File | 7489 bytes | June 03 2025 18:47:52. | |
getpass.py | File | 5990 bytes | June 03 2025 18:47:52. | |
gettext.py | File | 27266 bytes | June 03 2025 18:47:52. | |
glob.py | File | 5823 bytes | June 03 2025 18:47:52. | |
graphlib.py | File | 9573 bytes | June 03 2025 18:47:52. | |
gzip.py | File | 21772 bytes | June 03 2025 18:47:52. | |
hashlib.py | File | 10010 bytes | June 03 2025 18:47:52. | |
heapq.py | File | 22877 bytes | June 03 2025 18:47:52. | |
hmac.py | File | 7003 bytes | June 03 2025 18:47:52. | |
imaplib.py | File | 55256 bytes | June 03 2025 18:47:52. | |
imghdr.py | File | 3808 bytes | June 03 2025 18:47:52. | |
imp.py | File | 10536 bytes | June 03 2025 18:47:52. | |
inspect.py | File | 118235 bytes | June 03 2025 18:47:52. | |
io.py | File | 3541 bytes | June 03 2025 18:47:52. | |
ipaddress.py | File | 80924 bytes | June 03 2025 18:47:52. | |
keyword.py | File | 1047 bytes | June 03 2025 18:47:52. | |
linecache.py | File | 5461 bytes | June 03 2025 18:47:52. | |
locale.py | File | 78271 bytes | June 03 2025 18:47:52. | |
lzma.py | File | 13231 bytes | June 03 2025 18:47:52. | |
mailbox.py | File | 78794 bytes | June 03 2025 18:47:52. | |
mailcap.py | File | 9116 bytes | June 03 2025 18:47:52. | |
mimetypes.py | File | 21564 bytes | June 03 2025 18:47:52. | |
modulefinder.py | File | 24401 bytes | June 03 2025 18:47:52. | |
netrc.py | File | 5566 bytes | June 03 2025 18:47:52. | |
nntplib.py | File | 41023 bytes | June 03 2025 18:47:52. | |
ntpath.py | File | 28259 bytes | June 03 2025 18:47:52. | |
nturl2path.py | File | 2887 bytes | June 03 2025 18:47:52. | |
numbers.py | File | 10338 bytes | June 03 2025 18:47:52. | |
opcode.py | File | 5660 bytes | June 03 2025 18:47:52. | |
operator.py | File | 10751 bytes | June 03 2025 18:47:52. | |
optparse.py | File | 60369 bytes | June 03 2025 18:47:52. | |
os.py | File | 39065 bytes | June 03 2025 18:47:52. | |
pathlib.py | File | 51134 bytes | June 03 2025 18:47:52. | |
pdb.py | File | 63250 bytes | June 03 2025 18:47:52. | |
pickle.py | File | 64920 bytes | June 03 2025 18:47:52. | |
pickletools.py | File | 93486 bytes | June 03 2025 18:47:52. | |
pipes.py | File | 8916 bytes | June 03 2025 18:47:52. | |
pkgutil.py | File | 24276 bytes | June 03 2025 18:47:52. | |
platform.py | File | 40614 bytes | June 03 2025 18:47:52. | |
plistlib.py | File | 28248 bytes | June 03 2025 18:47:52. | |
poplib.py | File | 15198 bytes | June 03 2025 18:47:52. | |
posixpath.py | File | 16273 bytes | June 03 2025 18:47:52. | |
pprint.py | File | 22527 bytes | June 03 2025 18:47:52. | |
profile.py | File | 22894 bytes | June 03 2025 18:47:52. | |
pstats.py | File | 29326 bytes | June 03 2025 18:47:52. | |
pty.py | File | 4807 bytes | June 03 2025 18:47:52. | |
py_compile.py | File | 8203 bytes | June 19 2025 11:56:56. | |
pyclbr.py | File | 15255 bytes | June 03 2025 18:47:52. | |
pydoc.py | File | 109612 bytes | June 03 2025 18:47:52. | |
queue.py | File | 11496 bytes | June 03 2025 18:47:52. | |
quopri.py | File | 7279 bytes | June 03 2025 18:47:52. | |
random.py | File | 31484 bytes | June 03 2025 18:47:52. | |
re.py | File | 15861 bytes | June 03 2025 18:47:52. | |
reprlib.py | File | 5267 bytes | June 03 2025 18:47:52. | |
rlcompleter.py | File | 7648 bytes | June 03 2025 18:47:52. | |
runpy.py | File | 13084 bytes | June 03 2025 18:47:52. | |
sched.py | File | 6442 bytes | June 03 2025 18:47:52. | |
secrets.py | File | 2036 bytes | June 03 2025 18:47:52. | |
selectors.py | File | 19536 bytes | June 03 2025 18:47:52. | |
shelve.py | File | 8527 bytes | June 03 2025 18:47:52. | |
shlex.py | File | 13501 bytes | June 03 2025 18:47:52. | |
shutil.py | File | 53030 bytes | June 03 2025 18:47:52. | |
signal.py | File | 2438 bytes | June 03 2025 18:47:52. | |
site.py | File | 21844 bytes | June 03 2025 18:47:52. | |
smtpd.py | File | 34834 bytes | June 03 2025 18:47:52. | |
smtplib.py | File | 45418 bytes | June 03 2025 18:47:52. | |
sndhdr.py | File | 7099 bytes | June 03 2025 18:47:52. | |
socket.py | File | 36915 bytes | June 03 2025 18:47:52. | |
socketserver.py | File | 27296 bytes | June 03 2025 18:47:52. | |
sre_compile.py | File | 27973 bytes | June 03 2025 18:47:52. | |
sre_constants.py | File | 7177 bytes | June 03 2025 18:47:52. | |
sre_parse.py | File | 40779 bytes | June 03 2025 18:47:52. | |
ssl.py | File | 52530 bytes | June 03 2025 18:47:52. | |
stat.py | File | 5485 bytes | June 03 2025 18:47:52. | |
statistics.py | File | 38067 bytes | June 03 2025 18:47:52. | |
string.py | File | 10566 bytes | June 03 2025 18:47:52. | |
stringprep.py | File | 12917 bytes | June 03 2025 18:47:52. | |
struct.py | File | 257 bytes | June 03 2025 18:47:52. | |
subprocess.py | File | 83564 bytes | June 03 2025 18:47:52. | |
sunau.py | File | 18158 bytes | June 03 2025 18:47:52. | |
symbol.py | File | 2281 bytes | June 19 2025 12:01:19. | |
symtable.py | File | 7905 bytes | June 03 2025 18:47:52. | |
sysconfig.py | File | 24914 bytes | June 03 2025 18:47:52. | |
tabnanny.py | File | 11419 bytes | June 03 2025 18:47:52. | |
tarfile.py | File | 110849 bytes | June 03 2025 18:47:52. | |
telnetlib.py | File | 23254 bytes | June 03 2025 18:47:52. | |
tempfile.py | File | 27963 bytes | June 03 2025 18:47:52. | |
textwrap.py | File | 19407 bytes | June 03 2025 18:47:52. | |
this.py | File | 1003 bytes | June 03 2025 18:47:52. | |
threading.py | File | 54176 bytes | June 03 2025 18:47:52. | |
timeit.py | File | 13493 bytes | June 03 2025 18:47:52. | |
token.py | File | 2368 bytes | June 03 2025 18:47:52. | |
tokenize.py | File | 25883 bytes | June 03 2025 18:47:52. | |
trace.py | File | 29220 bytes | June 03 2025 18:47:52. | |
traceback.py | File | 24660 bytes | June 03 2025 18:47:52. | |
tracemalloc.py | File | 18047 bytes | June 03 2025 18:47:52. | |
tty.py | File | 879 bytes | June 03 2025 18:47:52. | |
types.py | File | 9785 bytes | June 03 2025 18:47:52. | |
typing.py | File | 77044 bytes | June 03 2025 18:47:52. | |
uu.py | File | 7277 bytes | June 19 2025 12:10:58. | |
uuid.py | File | 27324 bytes | June 03 2025 18:47:52. | |
warnings.py | File | 19688 bytes | June 03 2025 18:47:52. | |
wave.py | File | 18004 bytes | June 03 2025 18:47:52. | |
weakref.py | File | 21560 bytes | June 03 2025 18:47:52. | |
webbrowser.py | File | 24096 bytes | June 03 2025 18:47:52. | |
xdrlib.py | File | 5913 bytes | June 03 2025 18:47:52. | |
zipapp.py | File | 7535 bytes | June 03 2025 18:47:52. | |
zipfile.py | File | 88240 bytes | June 03 2025 18:47:52. | |
zipimport.py | File | 30765 bytes | June 03 2025 18:47:52. |
"""Parse a Python module and describe its classes and functions. Parse enough of a Python file to recognize imports and class and function definitions, and to find out the superclasses of a class. The interface consists of a single function: readmodule_ex(module, path=None) where module is the name of a Python module, and path is an optional list of directories where the module is to be searched. If present, path is prepended to the system search path sys.path. The return value is a dictionary. The keys of the dictionary are the names of the classes and functions defined in the module (including classes that are defined via the from XXX import YYY construct). The values are instances of classes Class and Function. One special key/value pair is present for packages: the key '__path__' has a list as its value which contains the package search path. Classes and Functions have a common superclass: _Object. Every instance has the following attributes: module -- name of the module; name -- name of the object; file -- file in which the object is defined; lineno -- line in the file where the object's definition starts; parent -- parent of this object, if any; children -- nested objects contained in this object. The 'children' attribute is a dictionary mapping names to objects. Instances of Function describe functions with the attributes from _Object. Instances of Class describe classes with the attributes from _Object, plus the following: super -- list of super classes (Class instances if possible); methods -- mapping of method names to beginning line numbers. If the name of a super class is not recognized, the corresponding entry in the list of super classes is not a class instance but a string giving the name of the super class. Since import statements are recognized and imported modules are scanned as well, this shouldn't happen often. """ import io import sys import importlib.util import tokenize from token import NAME, DEDENT, OP __all__ = ["readmodule", "readmodule_ex", "Class", "Function"] _modules = {} # Initialize cache of modules we've seen. class _Object: "Information about Python class or function." def __init__(self, module, name, file, lineno, parent): self.module = module self.name = name self.file = file self.lineno = lineno self.parent = parent self.children = {} def _addchild(self, name, obj): self.children[name] = obj class Function(_Object): "Information about a Python function, including methods." def __init__(self, module, name, file, lineno, parent=None): _Object.__init__(self, module, name, file, lineno, parent) class Class(_Object): "Information about a Python class." def __init__(self, module, name, super, file, lineno, parent=None): _Object.__init__(self, module, name, file, lineno, parent) self.super = [] if super is None else super self.methods = {} def _addmethod(self, name, lineno): self.methods[name] = lineno def _nest_function(ob, func_name, lineno): "Return a Function after nesting within ob." newfunc = Function(ob.module, func_name, ob.file, lineno, ob) ob._addchild(func_name, newfunc) if isinstance(ob, Class): ob._addmethod(func_name, lineno) return newfunc def _nest_class(ob, class_name, lineno, super=None): "Return a Class after nesting within ob." newclass = Class(ob.module, class_name, super, ob.file, lineno, ob) ob._addchild(class_name, newclass) return newclass def readmodule(module, path=None): """Return Class objects for the top-level classes in module. This is the original interface, before Functions were added. """ res = {} for key, value in _readmodule(module, path or []).items(): if isinstance(value, Class): res[key] = value return res def readmodule_ex(module, path=None): """Return a dictionary with all functions and classes in module. Search for module in PATH + sys.path. If possible, include imported superclasses. Do this by reading source, without importing (and executing) it. """ return _readmodule(module, path or []) def _readmodule(module, path, inpackage=None): """Do the hard work for readmodule[_ex]. If inpackage is given, it must be the dotted name of the package in which we are searching for a submodule, and then PATH must be the package search path; otherwise, we are searching for a top-level module, and path is combined with sys.path. """ # Compute the full module name (prepending inpackage if set). if inpackage is not None: fullmodule = "%s.%s" % (inpackage, module) else: fullmodule = module # Check in the cache. if fullmodule in _modules: return _modules[fullmodule] # Initialize the dict for this module's contents. tree = {} # Check if it is a built-in module; we don't do much for these. if module in sys.builtin_module_names and inpackage is None: _modules[module] = tree return tree # Check for a dotted module name. i = module.rfind('.') if i >= 0: package = module[:i] submodule = module[i+1:] parent = _readmodule(package, path, inpackage) if inpackage is not None: package = "%s.%s" % (inpackage, package) if not '__path__' in parent: raise ImportError('No package named {}'.format(package)) return _readmodule(submodule, parent['__path__'], package) # Search the path for the module. f = None if inpackage is not None: search_path = path else: search_path = path + sys.path spec = importlib.util._find_spec_from_path(fullmodule, search_path) if spec is None: raise ModuleNotFoundError(f"no module named {fullmodule!r}", name=fullmodule) _modules[fullmodule] = tree # Is module a package? if spec.submodule_search_locations is not None: tree['__path__'] = spec.submodule_search_locations try: source = spec.loader.get_source(fullmodule) except (AttributeError, ImportError): # If module is not Python source, we cannot do anything. return tree else: if source is None: return tree fname = spec.loader.get_filename(fullmodule) return _create_tree(fullmodule, path, fname, source, tree, inpackage) def _create_tree(fullmodule, path, fname, source, tree, inpackage): """Return the tree for a particular module. fullmodule (full module name), inpackage+module, becomes o.module. path is passed to recursive calls of _readmodule. fname becomes o.file. source is tokenized. Imports cause recursive calls to _readmodule. tree is {} or {'__path__': <submodule search locations>}. inpackage, None or string, is passed to recursive calls of _readmodule. The effect of recursive calls is mutation of global _modules. """ f = io.StringIO(source) stack = [] # Initialize stack of (class, indent) pairs. g = tokenize.generate_tokens(f.readline) try: for tokentype, token, start, _end, _line in g: if tokentype == DEDENT: lineno, thisindent = start # Close previous nested classes and defs. while stack and stack[-1][1] >= thisindent: del stack[-1] elif token == 'def': lineno, thisindent = start # Close previous nested classes and defs. while stack and stack[-1][1] >= thisindent: del stack[-1] tokentype, func_name, start = next(g)[0:3] if tokentype != NAME: continue # Skip def with syntax error. cur_func = None if stack: cur_obj = stack[-1][0] cur_func = _nest_function(cur_obj, func_name, lineno) else: # It is just a function. cur_func = Function(fullmodule, func_name, fname, lineno) tree[func_name] = cur_func stack.append((cur_func, thisindent)) elif token == 'class': lineno, thisindent = start # Close previous nested classes and defs. while stack and stack[-1][1] >= thisindent: del stack[-1] tokentype, class_name, start = next(g)[0:3] if tokentype != NAME: continue # Skip class with syntax error. # Parse what follows the class name. tokentype, token, start = next(g)[0:3] inherit = None if token == '(': names = [] # Initialize list of superclasses. level = 1 super = [] # Tokens making up current superclass. while True: tokentype, token, start = next(g)[0:3] if token in (')', ',') and level == 1: n = "".join(super) if n in tree: # We know this super class. n = tree[n] else: c = n.split('.') if len(c) > 1: # Super class form is module.class: # look in module for class. m = c[-2] c = c[-1] if m in _modules: d = _modules[m] if c in d: n = d[c] names.append(n) super = [] if token == '(': level += 1 elif token == ')': level -= 1 if level == 0: break elif token == ',' and level == 1: pass # Only use NAME and OP (== dot) tokens for type name. elif tokentype in (NAME, OP) and level == 1: super.append(token) # Expressions in the base list are not supported. inherit = names if stack: cur_obj = stack[-1][0] cur_class = _nest_class( cur_obj, class_name, lineno, inherit) else: cur_class = Class(fullmodule, class_name, inherit, fname, lineno) tree[class_name] = cur_class stack.append((cur_class, thisindent)) elif token == 'import' and start[1] == 0: modules = _getnamelist(g) for mod, _mod2 in modules: try: # Recursively read the imported module. if inpackage is None: _readmodule(mod, path) else: try: _readmodule(mod, path, inpackage) except ImportError: _readmodule(mod, []) except: # If we can't find or parse the imported module, # too bad -- don't die here. pass elif token == 'from' and start[1] == 0: mod, token = _getname(g) if not mod or token != "import": continue names = _getnamelist(g) try: # Recursively read the imported module. d = _readmodule(mod, path, inpackage) except: # If we can't find or parse the imported module, # too bad -- don't die here. continue # Add any classes that were defined in the imported module # to our name space if they were mentioned in the list. for n, n2 in names: if n in d: tree[n2 or n] = d[n] elif n == '*': # Don't add names that start with _. for n in d: if n[0] != '_': tree[n] = d[n] except StopIteration: pass f.close() return tree def _getnamelist(g): """Return list of (dotted-name, as-name or None) tuples for token source g. An as-name is the name that follows 'as' in an as clause. """ names = [] while True: name, token = _getname(g) if not name: break if token == 'as': name2, token = _getname(g) else: name2 = None names.append((name, name2)) while token != "," and "\n" not in token: token = next(g)[1] if token != ",": break return names def _getname(g): "Return (dotted-name or None, next-token) tuple for token source g." parts = [] tokentype, token = next(g)[0:2] if tokentype != NAME and token != '*': return (None, token) parts.append(token) while True: tokentype, token = next(g)[0:2] if token != '.': break tokentype, token = next(g)[0:2] if tokentype != NAME: break parts.append(token) return (".".join(parts), token) def _main(): "Print module output (default this file) for quick visual check." import os try: mod = sys.argv[1] except: mod = __file__ if os.path.exists(mod): path = [os.path.dirname(mod)] mod = os.path.basename(mod) if mod.lower().endswith(".py"): mod = mod[:-3] else: path = [] tree = readmodule_ex(mod, path) lineno_key = lambda a: getattr(a, 'lineno', 0) objs = sorted(tree.values(), key=lineno_key, reverse=True) indent_level = 2 while objs: obj = objs.pop() if isinstance(obj, list): # Value is a __path__ key. continue if not hasattr(obj, 'indent'): obj.indent = 0 if isinstance(obj, _Object): new_objs = sorted(obj.children.values(), key=lineno_key, reverse=True) for ob in new_objs: ob.indent = obj.indent + indent_level objs.extend(new_objs) if isinstance(obj, Class): print("{}class {} {} {}" .format(' ' * obj.indent, obj.name, obj.super, obj.lineno)) elif isinstance(obj, Function): print("{}def {} {}".format(' ' * obj.indent, obj.name, obj.lineno)) if __name__ == "__main__": _main()
SILENT KILLER Tool