SILENT KILLERPanel

Current Path: > > lib64 > python3.8 > 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: //lib64/python3.8/asyncio

NameTypeSizeLast ModifiedActions
__pycache__ Directory - -
__init__.py File 1227 bytes June 06 2023 13:32:21.
__main__.py File 3343 bytes June 06 2023 13:32:21.
base_events.py File 72621 bytes June 06 2023 13:32:21.
base_futures.py File 2574 bytes June 06 2023 13:32:21.
base_subprocess.py File 8843 bytes June 06 2023 13:32:21.
base_tasks.py File 2467 bytes June 06 2023 13:32:21.
constants.py File 888 bytes June 06 2023 13:32:21.
coroutines.py File 8797 bytes June 06 2023 13:32:21.
events.py File 26164 bytes June 06 2023 13:32:21.
exceptions.py File 1633 bytes June 06 2023 13:32:21.
format_helpers.py File 2404 bytes June 06 2023 13:32:21.
futures.py File 13154 bytes June 06 2023 13:32:21.
locks.py File 17276 bytes June 06 2023 13:32:21.
log.py File 124 bytes June 06 2023 13:32:21.
proactor_events.py File 32060 bytes June 06 2023 13:32:21.
protocols.py File 7136 bytes June 06 2023 13:32:21.
queues.py File 8223 bytes June 06 2023 13:32:21.
runners.py File 2054 bytes June 06 2023 13:32:21.
selector_events.py File 38996 bytes June 06 2023 13:32:21.
sslproto.py File 27210 bytes June 06 2023 13:32:21.
staggered.py File 5992 bytes June 06 2023 13:32:21.
streams.py File 26656 bytes June 06 2023 13:32:21.
subprocess.py File 8068 bytes June 06 2023 13:32:21.
tasks.py File 33923 bytes June 06 2023 13:32:21.
transports.py File 10486 bytes June 06 2023 13:32:21.
trsock.py File 5876 bytes June 06 2023 13:32:21.
unix_events.py File 49115 bytes June 06 2023 13:32:21.
windows_events.py File 32873 bytes June 06 2023 13:32:21.
windows_utils.py File 5060 bytes June 06 2023 13:32:21.

Reading File: //lib64/python3.8/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