File: add_overloaded_method.py

package info (click to toggle)
mypy 1.19.1-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 22,412 kB
  • sloc: python: 114,754; ansic: 13,343; cpp: 11,380; makefile: 257; sh: 28
file content (41 lines) | stat: -rw-r--r-- 1,447 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
from __future__ import annotations

from typing import Callable

from mypy.nodes import ARG_POS, Argument, Var
from mypy.plugin import ClassDefContext, Plugin
from mypy.plugins.common import MethodSpec, add_overloaded_method_to_class


class OverloadedMethodPlugin(Plugin):
    def get_base_class_hook(self, fullname: str) -> Callable[[ClassDefContext], None] | None:
        if "AddOverloadedMethod" in fullname:
            return add_overloaded_method_hook
        return None


def add_overloaded_method_hook(ctx: ClassDefContext) -> None:
    add_overloaded_method_to_class(ctx.api, ctx.cls, "method", _generate_method_specs(ctx))
    add_overloaded_method_to_class(
        ctx.api, ctx.cls, "clsmethod", _generate_method_specs(ctx), is_classmethod=True
    )
    add_overloaded_method_to_class(
        ctx.api, ctx.cls, "stmethod", _generate_method_specs(ctx), is_staticmethod=True
    )


def _generate_method_specs(ctx: ClassDefContext) -> list[MethodSpec]:
    return [
        MethodSpec(
            args=[Argument(Var("arg"), ctx.api.named_type("builtins.int"), None, ARG_POS)],
            return_type=ctx.api.named_type("builtins.str"),
        ),
        MethodSpec(
            args=[Argument(Var("arg"), ctx.api.named_type("builtins.str"), None, ARG_POS)],
            return_type=ctx.api.named_type("builtins.int"),
        ),
    ]


def plugin(version: str) -> type[OverloadedMethodPlugin]:
    return OverloadedMethodPlugin