SILENT KILLERPanel

Current Path: > > opt > cloudlinux > venv > lib64 > python3.11 > site-packages > astroid > > brain


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/cloudlinux/venv/lib64/python3.11/site-packages/astroid//brain

NameTypeSizeLast ModifiedActions
__pycache__ Directory - -
__init__.py File 0 bytes April 17 2025 13:10:59.
brain_argparse.py File 1557 bytes April 17 2025 13:10:59.
brain_attrs.py File 3038 bytes April 17 2025 13:10:59.
brain_boto3.py File 1012 bytes April 17 2025 13:10:59.
brain_builtin_inference.py File 34254 bytes April 17 2025 13:10:59.
brain_collections.py File 4416 bytes April 17 2025 13:10:59.
brain_crypt.py File 863 bytes April 17 2025 13:10:59.
brain_ctypes.py File 2660 bytes April 17 2025 13:10:59.
brain_curses.py File 3477 bytes April 17 2025 13:10:59.
brain_dataclasses.py File 22089 bytes April 17 2025 13:10:59.
brain_dateutil.py File 767 bytes April 17 2025 13:10:59.
brain_fstrings.py File 2471 bytes April 17 2025 13:10:59.
brain_functools.py File 5986 bytes April 17 2025 13:10:59.
brain_gi.py File 7543 bytes April 17 2025 13:10:59.
brain_hashlib.py File 2821 bytes April 17 2025 13:10:59.
brain_http.py File 10640 bytes April 17 2025 13:10:59.
brain_hypothesis.py File 1732 bytes April 17 2025 13:10:59.
brain_io.py File 1526 bytes April 17 2025 13:10:59.
brain_mechanize.py File 2646 bytes April 17 2025 13:10:59.
brain_multiprocessing.py File 3211 bytes April 17 2025 13:10:59.
brain_namedtuple_enum.py File 22725 bytes April 17 2025 13:10:59.
brain_nose.py File 2320 bytes April 17 2025 13:10:59.
brain_numpy_core_einsumfunc.py File 825 bytes April 17 2025 13:10:59.
brain_numpy_core_fromnumeric.py File 732 bytes April 17 2025 13:10:59.
brain_numpy_core_function_base.py File 1298 bytes April 17 2025 13:10:59.
brain_numpy_core_multiarray.py File 4238 bytes April 17 2025 13:10:59.
brain_numpy_core_numeric.py File 1629 bytes April 17 2025 13:10:59.
brain_numpy_core_numerictypes.py File 8546 bytes April 17 2025 13:10:59.
brain_numpy_core_umath.py File 4893 bytes April 17 2025 13:10:59.
brain_numpy_ma.py File 896 bytes April 17 2025 13:10:59.
brain_numpy_ndarray.py File 8998 bytes April 17 2025 13:10:59.
brain_numpy_random_mtrand.py File 3436 bytes April 17 2025 13:10:59.
brain_numpy_utils.py File 2637 bytes April 17 2025 13:10:59.
brain_pathlib.py File 1542 bytes April 17 2025 13:10:59.
brain_pkg_resources.py File 2200 bytes April 17 2025 13:10:59.
brain_pytest.py File 2223 bytes April 17 2025 13:10:59.
brain_qt.py File 2808 bytes April 17 2025 13:10:59.
brain_random.py File 2890 bytes April 17 2025 13:10:59.
brain_re.py File 2870 bytes April 17 2025 13:10:59.
brain_regex.py File 3362 bytes April 17 2025 13:10:59.
brain_responses.py File 1868 bytes April 17 2025 13:10:59.
brain_scipy_signal.py File 2276 bytes April 17 2025 13:10:59.
brain_signal.py File 3880 bytes April 17 2025 13:10:59.
brain_six.py File 7594 bytes April 17 2025 13:10:59.
brain_sqlalchemy.py File 1009 bytes April 17 2025 13:10:59.
brain_ssl.py File 6554 bytes April 17 2025 13:10:59.
brain_subprocess.py File 2996 bytes April 17 2025 13:10:59.
brain_threading.py File 870 bytes April 17 2025 13:10:59.
brain_type.py File 2483 bytes April 17 2025 13:10:59.
brain_typing.py File 14315 bytes April 17 2025 13:10:59.
brain_unittest.py File 1147 bytes April 17 2025 13:10:59.
brain_uuid.py File 667 bytes April 17 2025 13:10:59.
helpers.py File 908 bytes April 17 2025 13:10:59.

Reading File: //opt/cloudlinux/venv/lib64/python3.11/site-packages/astroid//brain/brain_multiprocessing.py

# Licensed under the LGPL: https://www.gnu.org/licenses/old-licenses/lgpl-2.1.en.html
# For details: https://github.com/PyCQA/astroid/blob/main/LICENSE
# Copyright (c) https://github.com/PyCQA/astroid/blob/main/CONTRIBUTORS.txt

from astroid.bases import BoundMethod
from astroid.brain.helpers import register_module_extender
from astroid.builder import parse
from astroid.exceptions import InferenceError
from astroid.manager import AstroidManager
from astroid.nodes.scoped_nodes import FunctionDef


def _multiprocessing_transform():
    module = parse(
        """
    from multiprocessing.managers import SyncManager
    def Manager():
        return SyncManager()
    """
    )
    # Multiprocessing uses a getattr lookup inside contexts,
    # in order to get the attributes they need. Since it's extremely
    # dynamic, we use this approach to fake it.
    node = parse(
        """
    from multiprocessing.context import DefaultContext, BaseContext
    default = DefaultContext()
    base = BaseContext()
    """
    )
    try:
        context = next(node["default"].infer())
        base = next(node["base"].infer())
    except (InferenceError, StopIteration):
        return module

    for node in (context, base):
        for key, value in node.locals.items():
            if key.startswith("_"):
                continue

            value = value[0]
            if isinstance(value, FunctionDef):
                # We need to rebound this, since otherwise
                # it will have an extra argument (self).
                value = BoundMethod(value, node)
            module[key] = value
    return module


def _multiprocessing_managers_transform():
    return parse(
        """
    import array
    import threading
    import multiprocessing.pool as pool
    import queue

    class Namespace(object):
        pass

    class Value(object):
        def __init__(self, typecode, value, lock=True):
            self._typecode = typecode
            self._value = value
        def get(self):
            return self._value
        def set(self, value):
            self._value = value
        def __repr__(self):
            return '%s(%r, %r)'%(type(self).__name__, self._typecode, self._value)
        value = property(get, set)

    def Array(typecode, sequence, lock=True):
        return array.array(typecode, sequence)

    class SyncManager(object):
        Queue = JoinableQueue = queue.Queue
        Event = threading.Event
        RLock = threading.RLock
        Lock = threading.Lock
        BoundedSemaphore = threading.BoundedSemaphore
        Condition = threading.Condition
        Barrier = threading.Barrier
        Pool = pool.Pool
        list = list
        dict = dict
        Value = Value
        Array = Array
        Namespace = Namespace
        __enter__ = lambda self: self
        __exit__ = lambda *args: args

        def start(self, initializer=None, initargs=None):
            pass
        def shutdown(self):
            pass
    """
    )


register_module_extender(
    AstroidManager(), "multiprocessing.managers", _multiprocessing_managers_transform
)
register_module_extender(
    AstroidManager(), "multiprocessing", _multiprocessing_transform
)

SILENT KILLER Tool