SILENT KILLERPanel

Current Path: > > opt > alt > python312 > lib64 > python3.12 > > asyncio >


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 ]

Files and Folders in: //opt/alt/python312/lib64/python3.12//asyncio/

NameTypeSizeLast ModifiedActions
__pycache__ Directory - -
__init__.py File 1220 bytes June 23 2025 13:48:51.
__main__.py File 3491 bytes June 23 2025 13:48:51.
base_events.py File 78567 bytes June 23 2025 13:48:51.
base_futures.py File 1974 bytes June 23 2025 13:48:51.
base_subprocess.py File 8869 bytes June 23 2025 13:48:51.
base_tasks.py File 2672 bytes June 23 2025 13:48:51.
constants.py File 1413 bytes June 23 2025 13:48:51.
coroutines.py File 3342 bytes June 23 2025 13:48:51.
events.py File 29339 bytes June 23 2025 13:48:51.
exceptions.py File 1752 bytes June 23 2025 13:48:51.
format_helpers.py File 2404 bytes June 23 2025 13:48:51.
futures.py File 14340 bytes June 23 2025 13:48:51.
locks.py File 18995 bytes June 23 2025 13:48:51.
log.py File 124 bytes June 23 2025 13:48:51.
mixins.py File 481 bytes June 23 2025 13:48:51.
proactor_events.py File 33500 bytes June 23 2025 13:48:51.
protocols.py File 6957 bytes June 23 2025 13:48:51.
queues.py File 7974 bytes June 23 2025 13:48:51.
runners.py File 7230 bytes June 23 2025 13:48:51.
selector_events.py File 48332 bytes June 23 2025 13:48:51.
sslproto.py File 31899 bytes June 23 2025 13:48:51.
staggered.py File 7077 bytes June 23 2025 13:48:51.
streams.py File 27619 bytes June 23 2025 13:48:51.
subprocess.py File 7737 bytes June 23 2025 13:48:51.
taskgroups.py File 9559 bytes June 23 2025 13:48:51.
tasks.py File 37362 bytes June 23 2025 13:48:51.
threads.py File 790 bytes June 23 2025 13:48:51.
timeouts.py File 5321 bytes June 23 2025 13:48:51.
transports.py File 10722 bytes June 23 2025 13:48:51.
trsock.py File 2475 bytes June 23 2025 13:48:51.
unix_events.py File 53124 bytes June 23 2025 13:48:51.
windows_events.py File 32587 bytes June 23 2025 13:48:51.
windows_utils.py File 5060 bytes June 23 2025 13:48:51.

Reading File: //opt/alt/python312/lib64/python3.12//asyncio//format_helpers.py

import functools
import inspect
import reprlib
import sys
import traceback

from . import constants


def _get_function_source(func):
    func = inspect.unwrap(func)
    if inspect.isfunction(func):
        code = func.__code__
        return (code.co_filename, code.co_firstlineno)
    if isinstance(func, functools.partial):
        return _get_function_source(func.func)
    if isinstance(func, functools.partialmethod):
        return _get_function_source(func.func)
    return None


def _format_callback_source(func, args):
    func_repr = _format_callback(func, args, None)
    source = _get_function_source(func)
    if source:
        func_repr += f' at {source[0]}:{source[1]}'
    return func_repr


def _format_args_and_kwargs(args, kwargs):
    """Format function arguments and keyword arguments.

    Special case for a single parameter: ('hello',) is formatted as ('hello').
    """
    # use reprlib to limit the length of the output
    items = []
    if args:
        items.extend(reprlib.repr(arg) for arg in args)
    if kwargs:
        items.extend(f'{k}={reprlib.repr(v)}' for k, v in kwargs.items())
    return '({})'.format(', '.join(items))


def _format_callback(func, args, kwargs, suffix=''):
    if isinstance(func, functools.partial):
        suffix = _format_args_and_kwargs(args, kwargs) + suffix
        return _format_callback(func.func, func.args, func.keywords, suffix)

    if hasattr(func, '__qualname__') and func.__qualname__:
        func_repr = func.__qualname__
    elif hasattr(func, '__name__') and func.__name__:
        func_repr = func.__name__
    else:
        func_repr = repr(func)

    func_repr += _format_args_and_kwargs(args, kwargs)
    if suffix:
        func_repr += suffix
    return func_repr


def extract_stack(f=None, limit=None):
    """Replacement for traceback.extract_stack() that only does the
    necessary work for asyncio debug mode.
    """
    if f is None:
        f = sys._getframe().f_back
    if limit is None:
        # Limit the amount of work to a reasonable amount, as extract_stack()
        # can be called for each coroutine and future in debug mode.
        limit = constants.DEBUG_STACK_DEPTH
    stack = traceback.StackSummary.extract(traceback.walk_stack(f),
                                           limit=limit,
                                           lookup_lines=False)
    stack.reverse()
    return stack

SILENT KILLER Tool