__ __ __ __ _____ _ _ _____ _ _ _ | \/ | \ \ / / | __ \ (_) | | / ____| | | | | | \ / |_ __\ V / | |__) | __ ___ ____ _| |_ ___ | (___ | |__ ___| | | | |\/| | '__|> < | ___/ '__| \ \ / / _` | __/ _ \ \___ \| '_ \ / _ \ | | | | | | |_ / . \ | | | | | |\ V / (_| | || __/ ____) | | | | __/ | | |_| |_|_(_)_/ \_\ |_| |_| |_| \_/ \__,_|\__\___| |_____/|_| |_|\___V 2.1 if you need WebShell for Seo everyday contact me on Telegram Telegram Address : @jackleetFor_More_Tools:
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
| Name | Type | Size | Permission | Actions |
|---|---|---|---|---|
| __pycache__ | Folder | 0755 |
|
|
| __init__.py | File | 1.19 KB | 0644 |
|
| __main__.py | File | 3.26 KB | 0644 |
|
| base_events.py | File | 76.14 KB | 0644 |
|
| base_futures.py | File | 1.93 KB | 0644 |
|
| base_subprocess.py | File | 8.66 KB | 0644 |
|
| base_tasks.py | File | 2.61 KB | 0644 |
|
| constants.py | File | 1.38 KB | 0644 |
|
| coroutines.py | File | 3.26 KB | 0644 |
|
| events.py | File | 28.65 KB | 0644 |
|
| exceptions.py | File | 1.71 KB | 0644 |
|
| format_helpers.py | File | 2.35 KB | 0644 |
|
| futures.py | File | 13.88 KB | 0644 |
|
| locks.py | File | 18.55 KB | 0644 |
|
| log.py | File | 124 B | 0644 |
|
| mixins.py | File | 481 B | 0644 |
|
| proactor_events.py | File | 32.6 KB | 0644 |
|
| protocols.py | File | 6.79 KB | 0644 |
|
| queues.py | File | 7.79 KB | 0644 |
|
| runners.py | File | 6.99 KB | 0644 |
|
| selector_events.py | File | 47.15 KB | 0644 |
|
| sslproto.py | File | 31 KB | 0644 |
|
| staggered.py | File | 5.85 KB | 0644 |
|
| streams.py | File | 26.97 KB | 0644 |
|
| subprocess.py | File | 7.56 KB | 0644 |
|
| taskgroups.py | File | 8.54 KB | 0644 |
|
| tasks.py | File | 36.49 KB | 0644 |
|
| threads.py | File | 790 B | 0644 |
|
| timeouts.py | File | 5.2 KB | 0644 |
|
| transports.py | File | 10.47 KB | 0644 |
|
| trsock.py | File | 2.42 KB | 0644 |
|
| unix_events.py | File | 51.88 KB | 0644 |
|
| windows_events.py | File | 31.82 KB | 0644 |
|
| windows_utils.py | File | 4.94 KB | 0644 |
|