SILENT KILLERPanel

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 ]

Files and Folders in: //opt/cloudlinux/venv/lib64/python3.11/site-packages/pylint/extensions

NameTypeSizeLast ModifiedActions
__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.

Reading File: //opt/cloudlinux/venv/lib64/python3.11/site-packages/pylint/extensions/docstyle.py

# 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

import linecache
from typing import TYPE_CHECKING

from astroid import nodes

from pylint import checkers
from pylint.checkers.utils import only_required_for_messages
from pylint.interfaces import HIGH

if TYPE_CHECKING:
    from pylint.lint import PyLinter


class DocStringStyleChecker(checkers.BaseChecker):
    """Checks format of docstrings based on PEP 0257."""

    name = "docstyle"

    msgs = {
        "C0198": (
            'Bad docstring quotes in %s, expected """, given %s',
            "bad-docstring-quotes",
            "Used when a docstring does not have triple double quotes.",
        ),
        "C0199": (
            "First line empty in %s docstring",
            "docstring-first-line-empty",
            "Used when a blank line is found at the beginning of a docstring.",
        ),
    }

    @only_required_for_messages("docstring-first-line-empty", "bad-docstring-quotes")
    def visit_module(self, node: nodes.Module) -> None:
        self._check_docstring("module", node)

    def visit_classdef(self, node: nodes.ClassDef) -> None:
        self._check_docstring("class", node)

    def visit_functiondef(self, node: nodes.FunctionDef) -> None:
        ftype = "method" if node.is_method() else "function"
        self._check_docstring(ftype, node)

    visit_asyncfunctiondef = visit_functiondef

    def _check_docstring(
        self, node_type: str, node: nodes.Module | nodes.ClassDef | nodes.FunctionDef
    ) -> None:
        docstring = node.doc_node.value if node.doc_node else None
        if docstring and docstring[0] == "\n":
            self.add_message(
                "docstring-first-line-empty",
                node=node,
                args=(node_type,),
                confidence=HIGH,
            )

        # Use "linecache", instead of node.as_string(), because the latter
        # looses the original form of the docstrings.

        if docstring:
            lineno = node.fromlineno + 1
            line = linecache.getline(node.root().file, lineno).lstrip()
            if line and line.find('"""') == 0:
                return
            if line and "'''" in line:
                quotes = "'''"
            elif line and line[0] == '"':
                quotes = '"'
            elif line and line[0] == "'":
                quotes = "'"
            else:
                quotes = ""
            if quotes:
                self.add_message(
                    "bad-docstring-quotes",
                    node=node,
                    args=(node_type, quotes),
                    confidence=HIGH,
                )


def register(linter: PyLinter) -> None:
    linter.register_checker(DocStringStyleChecker(linter))

SILENT KILLER Tool