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.
Files changed (23) hide show
  1. {enumerific-1.0.6/source/enumerific.egg-info → enumerific-1.0.7}/PKG-INFO +27 -1
  2. {enumerific-1.0.6 → enumerific-1.0.7}/README.md +26 -0
  3. {enumerific-1.0.6 → enumerific-1.0.7}/source/enumerific/extensible.py +18 -1
  4. enumerific-1.0.7/source/enumerific/version.txt +1 -0
  5. {enumerific-1.0.6 → enumerific-1.0.7/source/enumerific.egg-info}/PKG-INFO +27 -1
  6. {enumerific-1.0.6 → enumerific-1.0.7}/tests/test_extensible_enums.py +31 -2
  7. enumerific-1.0.6/source/enumerific/version.txt +0 -1
  8. {enumerific-1.0.6 → enumerific-1.0.7}/LICENSE.md +0 -0
  9. {enumerific-1.0.6 → enumerific-1.0.7}/pyproject.toml +0 -0
  10. {enumerific-1.0.6 → enumerific-1.0.7}/requirements.development.txt +0 -0
  11. {enumerific-1.0.6 → enumerific-1.0.7}/requirements.distribution.txt +0 -0
  12. {enumerific-1.0.6 → enumerific-1.0.7}/requirements.txt +0 -0
  13. {enumerific-1.0.6 → enumerific-1.0.7}/setup.cfg +0 -0
  14. {enumerific-1.0.6 → enumerific-1.0.7}/source/enumerific/__init__.py +0 -0
  15. {enumerific-1.0.6 → enumerific-1.0.7}/source/enumerific/exceptions.py +0 -0
  16. {enumerific-1.0.6 → enumerific-1.0.7}/source/enumerific/logging.py +0 -0
  17. {enumerific-1.0.6 → enumerific-1.0.7}/source/enumerific/standard.py +0 -0
  18. {enumerific-1.0.6 → enumerific-1.0.7}/source/enumerific.egg-info/SOURCES.txt +0 -0
  19. {enumerific-1.0.6 → enumerific-1.0.7}/source/enumerific.egg-info/dependency_links.txt +0 -0
  20. {enumerific-1.0.6 → enumerific-1.0.7}/source/enumerific.egg-info/requires.txt +0 -0
  21. {enumerific-1.0.6 → enumerific-1.0.7}/source/enumerific.egg-info/top_level.txt +0 -0
  22. {enumerific-1.0.6 → enumerific-1.0.7}/source/enumerific.egg-info/zip-safe +0 -0
  23. {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.6
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(value, Enumeration):
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.6
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 test_attribute_access():
1617
- """Test access to attributes (methods, properties, etc) on an Enumeration subclass"""
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