PATH: //opt/cloudlinux/venv/lib/python3.11/site-packages/astroid/brain
FILE_BARU
CREATE
FOLDER_BARU
MKDIR
UPLOAD_FILE
GO
[ .. KEMBALI ]
📄 __init__.py
↓
X
📁 __pycache__/
X
📄 brain_argparse.py
↓
X
📄 brain_attrs.py
↓
X
📄 brain_boto3.py
↓
X
📄 brain_builtin_inference.py
↓
X
📄 brain_collections.py
↓
X
📄 brain_crypt.py
↓
X
📄 brain_ctypes.py
↓
X
📄 brain_curses.py
↓
X
📄 brain_dataclasses.py
↓
X
📄 brain_dateutil.py
↓
X
📄 brain_fstrings.py
↓
X
📄 brain_functools.py
↓
X
📄 brain_gi.py
↓
X
📄 brain_hashlib.py
↓
X
📄 brain_http.py
↓
X
📄 brain_hypothesis.py
↓
X
📄 brain_io.py
↓
X
📄 brain_mechanize.py
↓
X
📄 brain_multiprocessing.py
↓
X
📄 brain_namedtuple_enum.py
↓
X
📄 brain_nose.py
↓
X
📄 brain_numpy_core_einsumfunc.py
↓
X
📄 brain_numpy_core_fromnumeric.py
↓
X
📄 brain_numpy_core_function_base.py
↓
X
📄 brain_numpy_core_multiarray.py
↓
X
📄 brain_numpy_core_numeric.py
↓
X
📄 brain_numpy_core_numerictypes.py
↓
X
📄 brain_numpy_core_umath.py
↓
X
📄 brain_numpy_ma.py
↓
X
📄 brain_numpy_ndarray.py
↓
X
📄 brain_numpy_random_mtrand.py
↓
X
📄 brain_numpy_utils.py
↓
X
📄 brain_pathlib.py
↓
X
📄 brain_pkg_resources.py
↓
X
📄 brain_pytest.py
↓
X
📄 brain_qt.py
↓
X
📄 brain_random.py
↓
X
📄 brain_re.py
↓
X
📄 brain_regex.py
↓
X
📄 brain_responses.py
↓
X
📄 brain_scipy_signal.py
↓
X
📄 brain_signal.py
↓
X
📄 brain_six.py
↓
X
📄 brain_sqlalchemy.py
↓
X
📄 brain_ssl.py
↓
X
📄 brain_subprocess.py
↓
X
📄 brain_threading.py
↓
X
📄 brain_type.py
↓
X
📄 brain_typing.py
↓
X
📄 brain_unittest.py
↓
X
📄 brain_uuid.py
↓
X
📄 helpers.py
↓
X
SAVING...
BERHASIL DIUBAH!
EDITING: brain_qt.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 """Astroid hooks for the PyQT library.""" from astroid import nodes, parse from astroid.brain.helpers import register_module_extender from astroid.builder import AstroidBuilder from astroid.manager import AstroidManager def _looks_like_signal( node: nodes.FunctionDef, signal_name: str = "pyqtSignal" ) -> bool: """Detect a Signal node.""" klasses = node.instance_attrs.get("__class__", []) # On PySide2 or PySide6 (since Qt 5.15.2) the Signal class changed locations if node.qname().partition(".")[0] in {"PySide2", "PySide6"}: return any(cls.qname() == "Signal" for cls in klasses) # pragma: no cover if klasses: try: return klasses[0].name == signal_name except AttributeError: # pragma: no cover # return False if the cls does not have a name attribute pass return False def transform_pyqt_signal(node: nodes.FunctionDef) -> None: module = parse( """ _UNSET = object() class pyqtSignal(object): def connect(self, slot, type=None, no_receiver_check=False): pass def disconnect(self, slot=_UNSET): pass def emit(self, *args): pass """ ) signal_cls: nodes.ClassDef = module["pyqtSignal"] node.instance_attrs["emit"] = [signal_cls["emit"]] node.instance_attrs["disconnect"] = [signal_cls["disconnect"]] node.instance_attrs["connect"] = [signal_cls["connect"]] def transform_pyside_signal(node: nodes.FunctionDef) -> None: module = parse( """ class NotPySideSignal(object): def connect(self, receiver, type=None): pass def disconnect(self, receiver): pass def emit(self, *args): pass """ ) signal_cls: nodes.ClassDef = module["NotPySideSignal"] node.instance_attrs["connect"] = [signal_cls["connect"]] node.instance_attrs["disconnect"] = [signal_cls["disconnect"]] node.instance_attrs["emit"] = [signal_cls["emit"]] def pyqt4_qtcore_transform(): return AstroidBuilder(AstroidManager()).string_build( """ def SIGNAL(signal_name): pass class QObject(object): def emit(self, signal): pass """ ) register_module_extender(AstroidManager(), "PyQt4.QtCore", pyqt4_qtcore_transform) AstroidManager().register_transform( nodes.FunctionDef, transform_pyqt_signal, _looks_like_signal ) AstroidManager().register_transform( nodes.ClassDef, transform_pyside_signal, lambda node: node.qname() in {"PySide.QtCore.Signal", "PySide2.QtCore.Signal"}, )
SIMPAN PERUBAHAN