$12 GRAYBYTE WORDPRESS FILE MANAGER $33

SERVER : premium201.web-hosting.com #1 SMP Wed Mar 26 12:08:09 UTC 2025
SERVER IP : 104.21.15.130 | ADMIN IP 216.73.217.149
OPTIONS : CRL = ON | WGT = ON | SDO = OFF | PKEX = OFF
DEACTIVATED : NONE

/opt/cloudlinux/venv/lib/python3.11/site-packages/pylint/extensions/

HOME
Current File : /opt/cloudlinux/venv/lib/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))


Current_dir [ NOT WRITEABLE ] Document_root [ WRITEABLE ]


[ Back ]
NAME
SIZE
LAST TOUCH
USER
CAN-I?
FUNCTIONS
..
--
11 Feb 2026 9.30 AM
root / root
0755
__pycache__
--
11 Feb 2026 9.30 AM
root / root
0755
__init__.py
0.562 KB
20 Jan 2026 1.01 PM
root / root
0644
_check_docs_utils.py
25.742 KB
20 Jan 2026 1.01 PM
root / root
0644
bad_builtin.py
2.216 KB
20 Jan 2026 1.01 PM
root / root
0644
broad_try_clause.py
2.248 KB
20 Jan 2026 1.01 PM
root / root
0644
check_elif.py
2.089 KB
20 Jan 2026 1.01 PM
root / root
0644
code_style.py
12.507 KB
20 Jan 2026 1.01 PM
root / root
0644
comparetozero.py
3.094 KB
20 Jan 2026 1.01 PM
root / root
0644
comparison_placement.py
2.297 KB
20 Jan 2026 1.01 PM
root / root
0644
confusing_elif.py
1.99 KB
20 Jan 2026 1.01 PM
root / root
0644
consider_refactoring_into_while_condition.py
3.234 KB
20 Jan 2026 1.01 PM
root / root
0644
consider_ternary_expression.py
1.658 KB
20 Jan 2026 1.01 PM
root / root
0644
dict_init_mutate.py
2.062 KB
20 Jan 2026 1.01 PM
root / root
0644
docparams.py
25.298 KB
20 Jan 2026 1.01 PM
root / root
0644
docstyle.py
2.874 KB
20 Jan 2026 1.01 PM
root / root
0644
dunder.py
2.33 KB
20 Jan 2026 1.01 PM
root / root
0644
empty_comment.py
1.909 KB
20 Jan 2026 1.01 PM
root / root
0644
emptystring.py
2.902 KB
20 Jan 2026 1.01 PM
root / root
0644
eq_without_hash.py
1.421 KB
20 Jan 2026 1.01 PM
root / root
0644
for_any_all.py
5.688 KB
20 Jan 2026 1.01 PM
root / root
0644
magic_value.py
4.139 KB
20 Jan 2026 1.01 PM
root / root
0644
mccabe.py
6.891 KB
20 Jan 2026 1.01 PM
root / root
0644
no_self_use.py
3.624 KB
20 Jan 2026 1.01 PM
root / root
0644
overlapping_exceptions.py
3.262 KB
20 Jan 2026 1.01 PM
root / root
0644
private_import.py
10.972 KB
20 Jan 2026 1.01 PM
root / root
0644
redefined_loop_name.py
3.145 KB
20 Jan 2026 1.01 PM
root / root
0644
redefined_variable_type.py
3.999 KB
20 Jan 2026 1.01 PM
root / root
0644
set_membership.py
1.754 KB
20 Jan 2026 1.01 PM
root / root
0644
typing.py
19.912 KB
20 Jan 2026 1.01 PM
root / root
0644
while_used.py
1.067 KB
20 Jan 2026 1.01 PM
root / root
0644

GRAYBYTE WORDPRESS FILE MANAGER @ 2025 CONTACT ME
Static GIF