404

[ Avaa Bypassed ]




Upload:

Command:

elspacio@3.144.87.18: ~ $
# 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

"""Check for use of nested min/max functions."""

from __future__ import annotations

import copy
from typing import TYPE_CHECKING

from astroid import nodes, objects

from pylint.checkers import BaseChecker
from pylint.checkers.utils import only_required_for_messages, safe_infer
from pylint.interfaces import INFERENCE

if TYPE_CHECKING:
    from pylint.lint import PyLinter

DICT_TYPES = (
    objects.DictValues,
    objects.DictKeys,
    objects.DictItems,
    nodes.node_classes.Dict,
)


class NestedMinMaxChecker(BaseChecker):
    """Multiple nested min/max calls on the same line will raise multiple messages.

    This behaviour is intended as it would slow down the checker to check
    for nested call with minimal benefits.
    """

    FUNC_NAMES = ("builtins.min", "builtins.max")

    name = "nested_min_max"
    msgs = {
        "W3301": (
            "Do not use nested call of '%s'; it's possible to do '%s' instead",
            "nested-min-max",
            "Nested calls ``min(1, min(2, 3))`` can be rewritten as ``min(1, 2, 3)``.",
        )
    }

    @classmethod
    def is_min_max_call(cls, node: nodes.NodeNG) -> bool:
        if not isinstance(node, nodes.Call):
            return False

        inferred = safe_infer(node.func)
        return (
            isinstance(inferred, nodes.FunctionDef)
            and inferred.qname() in cls.FUNC_NAMES
        )

    @classmethod
    def get_redundant_calls(cls, node: nodes.Call) -> list[nodes.Call]:
        return [
            arg
            for arg in node.args
            if cls.is_min_max_call(arg) and arg.func.name == node.func.name
        ]

    @only_required_for_messages("nested-min-max")
    def visit_call(self, node: nodes.Call) -> None:
        if not self.is_min_max_call(node):
            return

        redundant_calls = self.get_redundant_calls(node)
        if not redundant_calls:
            return

        fixed_node = copy.copy(node)
        while len(redundant_calls) > 0:
            for i, arg in enumerate(fixed_node.args):
                # Exclude any calls with generator expressions as there is no
                # clear better suggestion for them.
                if isinstance(arg, nodes.Call) and any(
                    isinstance(a, nodes.GeneratorExp) for a in arg.args
                ):
                    return

                if arg in redundant_calls:
                    fixed_node.args = (
                        fixed_node.args[:i] + arg.args + fixed_node.args[i + 1 :]
                    )
                    break

            redundant_calls = self.get_redundant_calls(fixed_node)

        for idx, arg in enumerate(fixed_node.args):
            if not isinstance(arg, nodes.Const):
                inferred = safe_infer(arg)
                if isinstance(
                    inferred, (nodes.List, nodes.Tuple, nodes.Set, *DICT_TYPES)
                ):
                    splat_node = nodes.Starred(lineno=inferred.lineno)
                    splat_node.value = arg
                    fixed_node.args = (
                        fixed_node.args[:idx]
                        + [splat_node]
                        + fixed_node.args[idx + 1 : idx]
                    )

        self.add_message(
            "nested-min-max",
            node=node,
            args=(node.func.name, fixed_node.as_string()),
            confidence=INFERENCE,
        )


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

Filemanager

Name Type Size Permission Actions
__pycache__ Folder 0755
base Folder 0755
classes Folder 0755
refactoring Folder 0755
__init__.py File 4.26 KB 0644
async.py File 3.83 KB 0644
bad_chained_comparison.py File 2.18 KB 0644
base_checker.py File 10.67 KB 0644
deprecated.py File 9.43 KB 0644
design_analysis.py File 21.62 KB 0644
dunder_methods.py File 3.43 KB 0644
ellipsis_checker.py File 1.97 KB 0644
exceptions.py File 26.05 KB 0644
format.py File 26.91 KB 0644
imports.py File 41.31 KB 0644
lambda_expressions.py File 3.38 KB 0644
logging.py File 15.84 KB 0644
mapreduce_checker.py File 1.08 KB 0644
method_args.py File 4.68 KB 0644
misc.py File 4.87 KB 0644
modified_iterating_checker.py File 7.67 KB 0644
nested_min_max.py File 3.63 KB 0644
newstyle.py File 4.46 KB 0644
non_ascii_names.py File 6.98 KB 0644
raw_metrics.py File 3.81 KB 0644
similar.py File 33.29 KB 0644
spelling.py File 16.17 KB 0644
stdlib.py File 31.28 KB 0644
strings.py File 40.28 KB 0644
threading_checker.py File 1.9 KB 0644
typecheck.py File 86.83 KB 0644
unicode.py File 18.05 KB 0644
unsupported_version.py File 2.93 KB 0644
utils.py File 77.26 KB 0644
variables.py File 126.57 KB 0644