A Pylint plugin that checks for a specific implementation of Enum subclasses.
Project description
Pylint-Enums
Installation:
$ pip install pylint_enums # a conventional option
$ pipenv install pylint_enums # a more modern option
Usage:
- Follow instructions to add
pylint_enums
as part of your loaded plugins.- Option 1 (.pylintrc)
- Add
load-plugins=pylint_enums
to your.pylintrc
. - Use pylint normally, i.e.,
$ pylint [filepath]
- Add
- Option 2 (command line option)
$ pylint [filepath] --load-plugins=pylint_enums
- Option 1 (.pylintrc)
What this is:
This is a tiny pylint plugin that adds a checker for Enum subclasses. It warns you when you haven't provided a typed annotation for the value
attribute and when a __str__
method has not been defined for the Enum when the type annotation isn't part of a finite list of simple types.
__str__
declaration is not enforced for the following types:
str
int
decimal
float
Why this is helpful:
Typically, the value of an enum doesn't matter.
from enum import Enum
class Foo(Enum):
FIRST = 'these'
SECOND = 'usually'
THIRD = 'don\'t'
FOURTH = 'matter'
However, in certain applications and/or use-cases, you actually do care about the value of each enum member. Specifically, you may use them as a verbose_name
or a pretty_name
for displaying to the user, or you may want to assign it a stateful value and use its contents later.
from enum import Enum
from typing import NamedTuple
class FooMember(NamedTuple):
label: str
rank: int
class Foo(Enum):
FIRST = FooMember(label='first', rank=1)
SECOND = FooMember(label='second', rank=2)
THIRD = FooMember(label='third', rank=3)
FOURTH = FooMember(label='fourth', rank=4)
def __str__(self) -> str:
return self.value.label
As of this writing, mypy==0.600
is unable to infer the types of the member values. They resolve to 'Any'
:
reveal_type(Foo) # 'def (value: Any) -> foo.Foo'
reveal_type(Foo.FIRST) # 'foo.Foo'
reveal_type(Foo.FIRST.value) # 'Any'
This can be problematic for mypy
users that rely on type hints to maintain their code base. When you write a function that returns Foo.FIRST.value
, our tooling is unable to help us figure out whether this value is a str
, a NamedTuple
, or some other value. Ideally, we would add additional type hints to the Enum:
class Foo(Enum):
value: FooMember
FIRST = FooMember(label='first', rank=1)
...
But alas, this requires developer vigilance to remember to do. If you're maintaining many enums across multiple files, it could be annoying to make sure that they and all future defined Enums are adequately typed.
This pylint plugin will raise errors when value
is not typed and when the value is typed to something complex and the Enum is missing a __str__
method.
Author
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file pylint_enums-0.0.5.tar.gz
.
File metadata
- Download URL: pylint_enums-0.0.5.tar.gz
- Upload date:
- Size: 4.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 20a98d810629dd02663088d10821db45490ee83f26e3ebdfc5f4e90a06b44738 |
|
MD5 | 38131fda5c0af1dd476390853c178957 |
|
BLAKE2b-256 | d0980cefde3c334f7000b1b9faec113db958e8368da82043d7818a2d4d86df14 |
File details
Details for the file pylint_enums-0.0.5-py3-none-any.whl
.
File metadata
- Download URL: pylint_enums-0.0.5-py3-none-any.whl
- Upload date:
- Size: 5.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 8515f438f1ea1778b37bd6293e2528b4d1f49dfcab97201d6317e3134b65c493 |
|
MD5 | 2224aa216f9124a27ba1a384348c81e2 |
|
BLAKE2b-256 | 439a575529b6c1554f9e019a61d618470ee95223993e248cc34ec9e34a8cce31 |