| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354 |
- # Licensed under the GPL: https://www.gnu.org/licenses/old-licenses/gpl-2.0.html
- # For details: https://github.com/pylint-dev/pylint/blob/main/LICENSE
- # Copyright (c) https://github.com/pylint-dev/pylint/blob/main/CONTRIBUTORS.txt
- """Check for use of dictionary mutation after initialization."""
- from __future__ import annotations
- from typing import TYPE_CHECKING
- from astroid import nodes
- from pylint.checkers import BaseChecker
- from pylint.checkers.utils import only_required_for_messages
- from pylint.interfaces import HIGH
- if TYPE_CHECKING:
- from pylint.lint.pylinter import PyLinter
- class DictInitMutateChecker(BaseChecker):
- name = "dict-init-mutate"
- msgs = {
- "C3401": (
- "Declare all known key/values when initializing the dictionary.",
- "dict-init-mutate",
- "Dictionaries can be initialized with a single statement "
- "using dictionary literal syntax.",
- )
- }
- @only_required_for_messages("dict-init-mutate")
- def visit_assign(self, node: nodes.Assign) -> None:
- """
- Detect dictionary mutation immediately after initialization.
- At this time, detecting nested mutation is not supported.
- """
- match node:
- case nodes.Assign(
- targets=[nodes.AssignName(name=dict_name)], value=nodes.Dict()
- ):
- pass
- case _:
- return
- match node.next_sibling():
- case nodes.Assign(
- targets=[nodes.Subscript(value=nodes.Name(name=name))]
- ) if (name == dict_name):
- self.add_message("dict-init-mutate", node=node, confidence=HIGH)
- def register(linter: PyLinter) -> None:
- linter.register_checker(DictInitMutateChecker(linter))
|