diff options
author | CoprDistGit <infra@openeuler.org> | 2023-05-15 05:26:39 +0000 |
---|---|---|
committer | CoprDistGit <infra@openeuler.org> | 2023-05-15 05:26:39 +0000 |
commit | b9f54d1be2ff886886b8c67d5dbaafb102c60159 (patch) | |
tree | 99917dbbe3e766f5bd682637ca3604dc09e3e46d | |
parent | a59dd9f1b9197df897a42cba4804014631b84f01 (diff) |
automatic import of python-pylint-enums
-rw-r--r-- | .gitignore | 1 | ||||
-rw-r--r-- | python-pylint-enums.spec | 334 | ||||
-rw-r--r-- | sources | 1 |
3 files changed, 336 insertions, 0 deletions
@@ -0,0 +1 @@ +/pylint_enums-0.0.5.tar.gz diff --git a/python-pylint-enums.spec b/python-pylint-enums.spec new file mode 100644 index 0000000..bfc4972 --- /dev/null +++ b/python-pylint-enums.spec @@ -0,0 +1,334 @@ +%global _empty_manifest_terminate_build 0 +Name: python-pylint-enums +Version: 0.0.5 +Release: 1 +Summary: A Pylint plugin that checks for a specific implementation of Enum subclasses. +License: MIT License +URL: https://github.com/cs-cordero/pylint_enums +Source0: https://mirrors.nju.edu.cn/pypi/web/packages/d0/98/0cefde3c334f7000b1b9faec113db958e8368da82043d7818a2d4d86df14/pylint_enums-0.0.5.tar.gz +BuildArch: noarch + +Requires: python3-pylint + +%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]` + - Option 2 (command line option) + - `$ pylint [filepath] --load-plugins=pylint_enums` + +## 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 + +[Christopher Sabater Cordero](https://github.com/cs-cordero) + + + + +%package -n python3-pylint-enums +Summary: A Pylint plugin that checks for a specific implementation of Enum subclasses. +Provides: python-pylint-enums +BuildRequires: python3-devel +BuildRequires: python3-setuptools +BuildRequires: python3-pip +%description -n python3-pylint-enums +# 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]` + - Option 2 (command line option) + - `$ pylint [filepath] --load-plugins=pylint_enums` + +## 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 + +[Christopher Sabater Cordero](https://github.com/cs-cordero) + + + + +%package help +Summary: Development documents and examples for pylint-enums +Provides: python3-pylint-enums-doc +%description help +# 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]` + - Option 2 (command line option) + - `$ pylint [filepath] --load-plugins=pylint_enums` + +## 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 + +[Christopher Sabater Cordero](https://github.com/cs-cordero) + + + + +%prep +%autosetup -n pylint-enums-0.0.5 + +%build +%py3_build + +%install +%py3_install +install -d -m755 %{buildroot}/%{_pkgdocdir} +if [ -d doc ]; then cp -arf doc %{buildroot}/%{_pkgdocdir}; fi +if [ -d docs ]; then cp -arf docs %{buildroot}/%{_pkgdocdir}; fi +if [ -d example ]; then cp -arf example %{buildroot}/%{_pkgdocdir}; fi +if [ -d examples ]; then cp -arf examples %{buildroot}/%{_pkgdocdir}; fi +pushd %{buildroot} +if [ -d usr/lib ]; then + find usr/lib -type f -printf "/%h/%f\n" >> filelist.lst +fi +if [ -d usr/lib64 ]; then + find usr/lib64 -type f -printf "/%h/%f\n" >> filelist.lst +fi +if [ -d usr/bin ]; then + find usr/bin -type f -printf "/%h/%f\n" >> filelist.lst +fi +if [ -d usr/sbin ]; then + find usr/sbin -type f -printf "/%h/%f\n" >> filelist.lst +fi +touch doclist.lst +if [ -d usr/share/man ]; then + find usr/share/man -type f -printf "/%h/%f.gz\n" >> doclist.lst +fi +popd +mv %{buildroot}/filelist.lst . +mv %{buildroot}/doclist.lst . + +%files -n python3-pylint-enums -f filelist.lst +%dir %{python3_sitelib}/* + +%files help -f doclist.lst +%{_docdir}/* + +%changelog +* Mon May 15 2023 Python_Bot <Python_Bot@openeuler.org> - 0.0.5-1 +- Package Spec generated @@ -0,0 +1 @@ +38131fda5c0af1dd476390853c178957 pylint_enums-0.0.5.tar.gz |