enumerific 1.0.6__tar.gz → 1.0.7__tar.gz
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- {enumerific-1.0.6/source/enumerific.egg-info → enumerific-1.0.7}/PKG-INFO +27 -1
- {enumerific-1.0.6 → enumerific-1.0.7}/README.md +26 -0
- {enumerific-1.0.6 → enumerific-1.0.7}/source/enumerific/extensible.py +18 -1
- enumerific-1.0.7/source/enumerific/version.txt +1 -0
- {enumerific-1.0.6 → enumerific-1.0.7/source/enumerific.egg-info}/PKG-INFO +27 -1
- {enumerific-1.0.6 → enumerific-1.0.7}/tests/test_extensible_enums.py +31 -2
- enumerific-1.0.6/source/enumerific/version.txt +0 -1
- {enumerific-1.0.6 → enumerific-1.0.7}/LICENSE.md +0 -0
- {enumerific-1.0.6 → enumerific-1.0.7}/pyproject.toml +0 -0
- {enumerific-1.0.6 → enumerific-1.0.7}/requirements.development.txt +0 -0
- {enumerific-1.0.6 → enumerific-1.0.7}/requirements.distribution.txt +0 -0
- {enumerific-1.0.6 → enumerific-1.0.7}/requirements.txt +0 -0
- {enumerific-1.0.6 → enumerific-1.0.7}/setup.cfg +0 -0
- {enumerific-1.0.6 → enumerific-1.0.7}/source/enumerific/__init__.py +0 -0
- {enumerific-1.0.6 → enumerific-1.0.7}/source/enumerific/exceptions.py +0 -0
- {enumerific-1.0.6 → enumerific-1.0.7}/source/enumerific/logging.py +0 -0
- {enumerific-1.0.6 → enumerific-1.0.7}/source/enumerific/standard.py +0 -0
- {enumerific-1.0.6 → enumerific-1.0.7}/source/enumerific.egg-info/SOURCES.txt +0 -0
- {enumerific-1.0.6 → enumerific-1.0.7}/source/enumerific.egg-info/dependency_links.txt +0 -0
- {enumerific-1.0.6 → enumerific-1.0.7}/source/enumerific.egg-info/requires.txt +0 -0
- {enumerific-1.0.6 → enumerific-1.0.7}/source/enumerific.egg-info/top_level.txt +0 -0
- {enumerific-1.0.6 → enumerific-1.0.7}/source/enumerific.egg-info/zip-safe +0 -0
- {enumerific-1.0.6 → enumerific-1.0.7}/tests/test_enumerific_library.py +0 -0
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
Metadata-Version: 2.4
|
|
2
2
|
Name: enumerific
|
|
3
|
-
Version: 1.0.
|
|
3
|
+
Version: 1.0.7
|
|
4
4
|
Summary: Simplifies working with Python enums.
|
|
5
5
|
Author: Daniel Sissman
|
|
6
6
|
License-Expression: MIT
|
|
@@ -675,6 +675,32 @@ assert Colors.PURPLE.rgb == (255, 0, 255)
|
|
|
675
675
|
assert Colors.PURPLE.primary is False
|
|
676
676
|
```
|
|
677
677
|
|
|
678
|
+
#### Example 19: Reconciling Enumeration Options via Annotations
|
|
679
|
+
|
|
680
|
+
```python
|
|
681
|
+
from enumerific import Enumeration, auto
|
|
682
|
+
|
|
683
|
+
class Colors(Enumeration):
|
|
684
|
+
"""Create a test Color enumeration based on the Enumeration class"""
|
|
685
|
+
|
|
686
|
+
RED = auto(RGB=(255, 0, 0))
|
|
687
|
+
GREEN = auto(RGB=(0, 255, 0))
|
|
688
|
+
BLUE = auto(RGB=(0, 0, 255))
|
|
689
|
+
|
|
690
|
+
# Ensure that the Colors enumeration subclass is of the expected types
|
|
691
|
+
assert issubclass(Colors, Enumeration)
|
|
692
|
+
|
|
693
|
+
# Attempt to reconcile a Color against one of its annotations
|
|
694
|
+
color = Colors.reconcile(value=(255, 0, 0), annotation="RGB")
|
|
695
|
+
|
|
696
|
+
assert isinstance(color, Colors)
|
|
697
|
+
assert isinstance(color, Enumeration)
|
|
698
|
+
|
|
699
|
+
assert color.name == "RED"
|
|
700
|
+
assert color.value == 1
|
|
701
|
+
assert color.RGB == (255, 0, 0)
|
|
702
|
+
```
|
|
703
|
+
|
|
678
704
|
# Enumerific Library Enumerations: Classes & Methods
|
|
679
705
|
|
|
680
706
|
The Enumerific library's `Enumeration` class is a greenfield implementation of enumerations
|
|
@@ -645,6 +645,32 @@ assert Colors.PURPLE.rgb == (255, 0, 255)
|
|
|
645
645
|
assert Colors.PURPLE.primary is False
|
|
646
646
|
```
|
|
647
647
|
|
|
648
|
+
#### Example 19: Reconciling Enumeration Options via Annotations
|
|
649
|
+
|
|
650
|
+
```python
|
|
651
|
+
from enumerific import Enumeration, auto
|
|
652
|
+
|
|
653
|
+
class Colors(Enumeration):
|
|
654
|
+
"""Create a test Color enumeration based on the Enumeration class"""
|
|
655
|
+
|
|
656
|
+
RED = auto(RGB=(255, 0, 0))
|
|
657
|
+
GREEN = auto(RGB=(0, 255, 0))
|
|
658
|
+
BLUE = auto(RGB=(0, 0, 255))
|
|
659
|
+
|
|
660
|
+
# Ensure that the Colors enumeration subclass is of the expected types
|
|
661
|
+
assert issubclass(Colors, Enumeration)
|
|
662
|
+
|
|
663
|
+
# Attempt to reconcile a Color against one of its annotations
|
|
664
|
+
color = Colors.reconcile(value=(255, 0, 0), annotation="RGB")
|
|
665
|
+
|
|
666
|
+
assert isinstance(color, Colors)
|
|
667
|
+
assert isinstance(color, Enumeration)
|
|
668
|
+
|
|
669
|
+
assert color.name == "RED"
|
|
670
|
+
assert color.value == 1
|
|
671
|
+
assert color.RGB == (255, 0, 0)
|
|
672
|
+
```
|
|
673
|
+
|
|
648
674
|
# Enumerific Library Enumerations: Classes & Methods
|
|
649
675
|
|
|
650
676
|
The Enumerific library's `Enumeration` class is a greenfield implementation of enumerations
|
|
@@ -1458,6 +1458,7 @@ class EnumerationMetaClass(type):
|
|
|
1458
1458
|
value: Enumeration | object = None,
|
|
1459
1459
|
name: str = None,
|
|
1460
1460
|
caselessly: bool = False,
|
|
1461
|
+
annotation: str = None,
|
|
1461
1462
|
) -> Enumeration | None:
|
|
1462
1463
|
"""The 'reconcile' method can be used to reconcile Enumeration type, enumeration
|
|
1463
1464
|
values, or enumeration names to their matching Enumeration type instances. If a
|
|
@@ -1480,7 +1481,23 @@ class EnumerationMetaClass(type):
|
|
|
1480
1481
|
reconciled: Enumeration = None
|
|
1481
1482
|
|
|
1482
1483
|
for attribute, enumeration in self._enumerations.items():
|
|
1483
|
-
if isinstance(
|
|
1484
|
+
if isinstance(annotation, str):
|
|
1485
|
+
if annotation in enumeration._annotations:
|
|
1486
|
+
if enumeration._annotations[annotation] is value:
|
|
1487
|
+
reconciled = enumeration
|
|
1488
|
+
break
|
|
1489
|
+
elif enumeration._annotations[annotation] == value:
|
|
1490
|
+
reconciled = enumeration
|
|
1491
|
+
break
|
|
1492
|
+
else:
|
|
1493
|
+
raise EnumerationOptionError(
|
|
1494
|
+
"The enumeration option, %s, has no '%s' annotation!"
|
|
1495
|
+
% (
|
|
1496
|
+
enumeration,
|
|
1497
|
+
annotation,
|
|
1498
|
+
)
|
|
1499
|
+
)
|
|
1500
|
+
elif isinstance(value, Enumeration):
|
|
1484
1501
|
if enumeration is value:
|
|
1485
1502
|
reconciled = enumeration
|
|
1486
1503
|
break
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
1.0.7
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
Metadata-Version: 2.4
|
|
2
2
|
Name: enumerific
|
|
3
|
-
Version: 1.0.
|
|
3
|
+
Version: 1.0.7
|
|
4
4
|
Summary: Simplifies working with Python enums.
|
|
5
5
|
Author: Daniel Sissman
|
|
6
6
|
License-Expression: MIT
|
|
@@ -675,6 +675,32 @@ assert Colors.PURPLE.rgb == (255, 0, 255)
|
|
|
675
675
|
assert Colors.PURPLE.primary is False
|
|
676
676
|
```
|
|
677
677
|
|
|
678
|
+
#### Example 19: Reconciling Enumeration Options via Annotations
|
|
679
|
+
|
|
680
|
+
```python
|
|
681
|
+
from enumerific import Enumeration, auto
|
|
682
|
+
|
|
683
|
+
class Colors(Enumeration):
|
|
684
|
+
"""Create a test Color enumeration based on the Enumeration class"""
|
|
685
|
+
|
|
686
|
+
RED = auto(RGB=(255, 0, 0))
|
|
687
|
+
GREEN = auto(RGB=(0, 255, 0))
|
|
688
|
+
BLUE = auto(RGB=(0, 0, 255))
|
|
689
|
+
|
|
690
|
+
# Ensure that the Colors enumeration subclass is of the expected types
|
|
691
|
+
assert issubclass(Colors, Enumeration)
|
|
692
|
+
|
|
693
|
+
# Attempt to reconcile a Color against one of its annotations
|
|
694
|
+
color = Colors.reconcile(value=(255, 0, 0), annotation="RGB")
|
|
695
|
+
|
|
696
|
+
assert isinstance(color, Colors)
|
|
697
|
+
assert isinstance(color, Enumeration)
|
|
698
|
+
|
|
699
|
+
assert color.name == "RED"
|
|
700
|
+
assert color.value == 1
|
|
701
|
+
assert color.RGB == (255, 0, 0)
|
|
702
|
+
```
|
|
703
|
+
|
|
678
704
|
# Enumerific Library Enumerations: Classes & Methods
|
|
679
705
|
|
|
680
706
|
The Enumerific library's `Enumeration` class is a greenfield implementation of enumerations
|
|
@@ -1613,8 +1613,8 @@ def test_membership_in_tuple():
|
|
|
1613
1613
|
assert Colors.VIOLET not in colors
|
|
1614
1614
|
|
|
1615
1615
|
|
|
1616
|
-
def
|
|
1617
|
-
"""Test access to
|
|
1616
|
+
def test_annotation_access():
|
|
1617
|
+
"""Test access to annotations (methods, properties, etc) on an Enumeration subclass"""
|
|
1618
1618
|
|
|
1619
1619
|
class Colors(Enumeration, backfill=True):
|
|
1620
1620
|
"""Create a test Color enumeration based on the Enumeration class"""
|
|
@@ -1812,3 +1812,32 @@ def test_attribute_access():
|
|
|
1812
1812
|
assert color.isMetallic() is False # isMetallic() is defined on the Colors subclass
|
|
1813
1813
|
assert color.HEX == "FF0000" # HEX is a property defined on the Colors subclass
|
|
1814
1814
|
assert color.count() == 8 # count() is a classmethod defined on the Colors subclass
|
|
1815
|
+
|
|
1816
|
+
|
|
1817
|
+
def test_annotation_reconciliation():
|
|
1818
|
+
"""Test reconciliation of enumeration options via their annotations."""
|
|
1819
|
+
|
|
1820
|
+
class Colors(Enumeration):
|
|
1821
|
+
"""Create a test Color enumeration based on the Enumeration class"""
|
|
1822
|
+
|
|
1823
|
+
RED = auto(RGB=(255, 0, 0))
|
|
1824
|
+
ORANGE = auto(RGB=(255, 165, 0))
|
|
1825
|
+
YELLOW = auto(RGB=(255, 255, 0))
|
|
1826
|
+
GREEN = auto(RGB=(0, 255, 0))
|
|
1827
|
+
BLUE = auto(RGB=(0, 0, 255))
|
|
1828
|
+
VIOLET = auto(RGB=(255, 0, 255))
|
|
1829
|
+
|
|
1830
|
+
# Ensure that the Colors enumeration subclass is of the expected types
|
|
1831
|
+
assert issubclass(Colors, Enumeration)
|
|
1832
|
+
assert issubclass(Colors, EnumerationInteger)
|
|
1833
|
+
|
|
1834
|
+
# Attempt to reconcile a Color against one of its annotations
|
|
1835
|
+
color = Colors.reconcile(value=(255, 0, 0), annotation="RGB")
|
|
1836
|
+
|
|
1837
|
+
assert isinstance(color, Colors)
|
|
1838
|
+
assert isinstance(color, Enumeration)
|
|
1839
|
+
assert isinstance(color, EnumerationInteger)
|
|
1840
|
+
|
|
1841
|
+
assert color.name == "RED"
|
|
1842
|
+
assert color.value == 1
|
|
1843
|
+
assert color.RGB == (255, 0, 0)
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
1.0.6
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|