Skip to content

Files

Latest commit

 

History

History
54 lines (39 loc) · 1.28 KB

singledispatchmethod-function.md

File metadata and controls

54 lines (39 loc) · 1.28 KB

Pattern: Missing use of singledispatch

Issue: -

Description

singledispatchmethod should decorate class/instance methods and not functions. Use singledispatch for those cases.

Example of incorrect code:

from functools import singledispatchmethod


class Board:
    @singledispatchmethod  # [singledispatchmethod-function]
    @staticmethod
    def convert_position(position):
        pass

    @convert_position.register  # [singledispatchmethod-function]
    @staticmethod
    def _(position: str) -> tuple:
        position_a, position_b = position.split(",")
        return (int(position_a), int(position_b))

    @convert_position.register  # [singledispatchmethod-function]
    @staticmethod
    def _(position: tuple) -> str:
        return f"{position[0]},{position[1]}"

Example of correct code:

from functools import singledispatchmethod


class Board:
    @singledispatchmethod
    def convert_position(cls, position):
        pass

    @singledispatchmethod
    @classmethod
    def _(cls, position: str) -> tuple:
        position_a, position_b = position.split(",")
        return (int(position_a), int(position_b))

    @singledispatchmethod
    @classmethod
    def _(cls, position: tuple) -> str:
        return f"{position[0]},{position[1]}"