summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorCoprDistGit <infra@openeuler.org>2023-05-15 05:26:39 +0000
committerCoprDistGit <infra@openeuler.org>2023-05-15 05:26:39 +0000
commitb9f54d1be2ff886886b8c67d5dbaafb102c60159 (patch)
tree99917dbbe3e766f5bd682637ca3604dc09e3e46d
parenta59dd9f1b9197df897a42cba4804014631b84f01 (diff)
automatic import of python-pylint-enums
-rw-r--r--.gitignore1
-rw-r--r--python-pylint-enums.spec334
-rw-r--r--sources1
3 files changed, 336 insertions, 0 deletions
diff --git a/.gitignore b/.gitignore
index e69de29..a65bb3f 100644
--- a/.gitignore
+++ b/.gitignore
@@ -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
diff --git a/sources b/sources
new file mode 100644
index 0000000..274e73c
--- /dev/null
+++ b/sources
@@ -0,0 +1 @@
+38131fda5c0af1dd476390853c178957 pylint_enums-0.0.5.tar.gz