Current Path: > > opt > cloudlinux > venv > lib64 > python3.11 > site-packages > pylint > extensions >
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 ]
Name | Type | Size | Last Modified | Actions |
---|---|---|---|---|
__pycache__ | Directory | - | - | |
__init__.py | File | 575 bytes | April 17 2025 13:10:59. | |
_check_docs_utils.py | File | 26360 bytes | April 17 2025 13:10:59. | |
bad_builtin.py | File | 2269 bytes | April 17 2025 13:10:59. | |
broad_try_clause.py | File | 2302 bytes | April 17 2025 13:10:59. | |
check_elif.py | File | 2139 bytes | April 17 2025 13:10:59. | |
code_style.py | File | 12807 bytes | April 17 2025 13:10:59. | |
comparetozero.py | File | 3168 bytes | April 17 2025 13:10:59. | |
comparison_placement.py | File | 2352 bytes | April 17 2025 13:10:59. | |
confusing_elif.py | File | 2038 bytes | April 17 2025 13:10:59. | |
consider_refactoring_into_while_condition.py | File | 3312 bytes | April 17 2025 13:10:59. | |
consider_ternary_expression.py | File | 1698 bytes | April 17 2025 13:10:59. | |
dict_init_mutate.py | File | 2111 bytes | April 17 2025 13:10:59. | |
docparams.py | File | 25905 bytes | April 17 2025 13:10:59. | |
docstyle.py | File | 2943 bytes | April 17 2025 13:10:59. | |
dunder.py | File | 2386 bytes | April 17 2025 13:10:59. | |
empty_comment.py | File | 1955 bytes | April 17 2025 13:10:59. | |
emptystring.py | File | 2972 bytes | April 17 2025 13:10:59. | |
eq_without_hash.py | File | 1455 bytes | April 17 2025 13:10:59. | |
for_any_all.py | File | 5825 bytes | April 17 2025 13:10:59. | |
magic_value.py | File | 4238 bytes | April 17 2025 13:10:59. | |
mccabe.py | File | 7056 bytes | April 17 2025 13:10:59. | |
no_self_use.py | File | 3711 bytes | April 17 2025 13:10:59. | |
overlapping_exceptions.py | File | 3340 bytes | April 17 2025 13:10:59. | |
private_import.py | File | 11235 bytes | April 17 2025 13:10:59. | |
redefined_loop_name.py | File | 3220 bytes | April 17 2025 13:10:59. | |
redefined_variable_type.py | File | 4095 bytes | April 17 2025 13:10:59. | |
set_membership.py | File | 1796 bytes | April 17 2025 13:10:59. | |
typing.py | File | 20390 bytes | April 17 2025 13:10:59. | |
while_used.py | File | 1093 bytes | April 17 2025 13:10:59. |
# Licensed under the GPL: https://www.gnu.org/licenses/old-licenses/gpl-2.0.html # For details: https://github.com/PyCQA/pylint/blob/main/LICENSE # Copyright (c) https://github.com/PyCQA/pylint/blob/main/CONTRIBUTORS.txt from __future__ import annotations from typing import TYPE_CHECKING from astroid import nodes from pylint.checkers import BaseChecker from pylint.checkers.utils import ( PYMETHODS, decorated_with_property, is_overload_stub, is_protocol_class, overrides_a_method, ) from pylint.interfaces import INFERENCE if TYPE_CHECKING: from pylint.lint.pylinter import PyLinter class NoSelfUseChecker(BaseChecker): name = "no_self_use" msgs = { "R6301": ( "Method could be a function", "no-self-use", "Used when a method doesn't use its bound instance, and so could " "be written as a function.", {"old_names": [("R0201", "old-no-self-use")]}, ), } def __init__(self, linter: PyLinter) -> None: super().__init__(linter) self._first_attrs: list[str | None] = [] self._meth_could_be_func: bool | None = None def visit_name(self, node: nodes.Name) -> None: """Check if the name handle an access to a class member if so, register it. """ if self._first_attrs and ( node.name == self._first_attrs[-1] or not self._first_attrs[-1] ): self._meth_could_be_func = False def visit_functiondef(self, node: nodes.FunctionDef) -> None: if not node.is_method(): return self._meth_could_be_func = True self._check_first_arg_for_type(node) visit_asyncfunctiondef = visit_functiondef def _check_first_arg_for_type(self, node: nodes.FunctionDef) -> None: """Check the name of first argument.""" # pylint: disable=duplicate-code if node.args.posonlyargs: first_arg = node.args.posonlyargs[0].name elif node.args.args: first_arg = node.argnames()[0] else: first_arg = None self._first_attrs.append(first_arg) # static method if node.type == "staticmethod": self._first_attrs[-1] = None def leave_functiondef(self, node: nodes.FunctionDef) -> None: """On method node, check if this method couldn't be a function. ignore class, static and abstract methods, initializer, methods overridden from a parent class. """ if node.is_method(): first = self._first_attrs.pop() if first is None: return class_node = node.parent.frame(future=True) if ( self._meth_could_be_func and node.type == "method" and node.name not in PYMETHODS and not ( node.is_abstract() or overrides_a_method(class_node, node.name) or decorated_with_property(node) or _has_bare_super_call(node) or is_protocol_class(class_node) or is_overload_stub(node) ) ): self.add_message("no-self-use", node=node, confidence=INFERENCE) leave_asyncfunctiondef = leave_functiondef def _has_bare_super_call(fundef_node: nodes.FunctionDef) -> bool: for call in fundef_node.nodes_of_class(nodes.Call): func = call.func if isinstance(func, nodes.Name) and func.name == "super" and not call.args: return True return False def register(linter: PyLinter) -> None: linter.register_checker(NoSelfUseChecker(linter))
SILENT KILLER Tool