enumerific 1.0.7__py3-none-any.whl → 1.0.9__py3-none-any.whl

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/extensible.py CHANGED
@@ -90,6 +90,7 @@ class auto(int, anno):
90
90
 
91
91
  start: int = 0
92
92
  steps: int = 1
93
+ times: int = 0
93
94
  power: int = 0
94
95
  value: int = 0
95
96
 
@@ -1378,7 +1379,7 @@ class EnumerationMetaClass(type):
1378
1379
 
1379
1380
  return self._instance.__name__
1380
1381
 
1381
- def register(self, name: str, value: object) -> Enumeration:
1382
+ def register(self, name: str, value: object = auto()) -> Enumeration:
1382
1383
  """The 'register' method supports registering additional enumeration options for
1383
1384
  an existing enumeration class. The method accepts the name of the enumeration
1384
1385
  option and its corresponding value; these are then mapped into a new enumeration
@@ -1459,44 +1460,59 @@ class EnumerationMetaClass(type):
1459
1460
  name: str = None,
1460
1461
  caselessly: bool = False,
1461
1462
  annotation: str = None,
1463
+ **annotations: dict[str, object],
1462
1464
  ) -> Enumeration | None:
1463
1465
  """The 'reconcile' method can be used to reconcile Enumeration type, enumeration
1464
1466
  values, or enumeration names to their matching Enumeration type instances. If a
1465
1467
  match is found the Enumeration type instance will be returned otherwise None will
1466
1468
  be returned, unless the class is configured to raise an error for mismatches."""
1467
1469
 
1468
- if name is None and value is None:
1470
+ if isinstance(annotation, str):
1471
+ annotations[annotation] = value
1472
+
1473
+ if name is None and value is None and len(annotations) == 0:
1469
1474
  raise ValueError(
1470
- "Either the 'value' or 'name' argument must be specified when calling the 'reconcile' function!"
1475
+ "Either a 'value', 'name' or annotation keyword argument must be specified when calling the 'reconcile' function!"
1471
1476
  )
1472
1477
 
1473
1478
  if not value is None and not isinstance(value, (Enumeration, object)):
1474
1479
  raise TypeError(
1475
- "The 'value' argument must reference an Enumeration type or have an enumeration value!"
1480
+ "The 'value' argument, if specified, must reference an Enumeration type or have an enumeration value!"
1476
1481
  )
1477
1482
 
1478
1483
  if not name is None and not isinstance(name, str):
1479
- raise TypeError("The 'name' argument must have a string value!")
1484
+ raise TypeError(
1485
+ "The 'name' argument, if specified, must have a string value!"
1486
+ )
1480
1487
 
1481
1488
  reconciled: Enumeration = None
1482
1489
 
1483
1490
  for attribute, enumeration in self._enumerations.items():
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,
1491
+ if len(annotations) > 0:
1492
+ comparisons: list[bool] = []
1493
+
1494
+ for annotation, value in annotations.items():
1495
+ if annotation in enumeration._annotations:
1496
+ if enumeration._annotations[annotation] is value:
1497
+ comparisons.append(True)
1498
+ elif enumeration._annotations[annotation] == value:
1499
+ comparisons.append(True)
1500
+ else:
1501
+ comparisons.append(False)
1502
+ else:
1503
+ comparisons.append(False)
1504
+
1505
+ logger.debug(
1506
+ "The enumeration option, %s, has no '%s' annotation!"
1507
+ % (
1508
+ enumeration,
1509
+ annotation,
1510
+ )
1498
1511
  )
1499
- )
1512
+
1513
+ if len(comparisons) == len(annotations) and False not in comparisons:
1514
+ reconciled = enumeration
1515
+ break
1500
1516
  elif isinstance(value, Enumeration):
1501
1517
  if enumeration is value:
1502
1518
  reconciled = enumeration
enumerific/version.txt CHANGED
@@ -1 +1 @@
1
- 1.0.7
1
+ 1.0.9
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: enumerific
3
- Version: 1.0.7
3
+ Version: 1.0.9
4
4
  Summary: Simplifies working with Python enums.
5
5
  Author: Daniel Sissman
6
6
  License-Expression: MIT
@@ -690,8 +690,8 @@ class Colors(Enumeration):
690
690
  # Ensure that the Colors enumeration subclass is of the expected types
691
691
  assert issubclass(Colors, Enumeration)
692
692
 
693
- # Attempt to reconcile a Color against one of its annotations
694
- color = Colors.reconcile(value=(255, 0, 0), annotation="RGB")
693
+ # Attempt to reconcile a Color against one of its annotations (via annotation keyword)
694
+ color = Colors.reconcile(RGB=(255, 0, 0))
695
695
 
696
696
  assert isinstance(color, Colors)
697
697
  assert isinstance(color, Enumeration)
@@ -699,6 +699,16 @@ assert isinstance(color, Enumeration)
699
699
  assert color.name == "RED"
700
700
  assert color.value == 1
701
701
  assert color.RGB == (255, 0, 0)
702
+
703
+ # Attempt to reconcile a Color against one of its annotations (via annotation argument)
704
+ color = Colors.reconcile(value=(0, 255, 0), annotation="RGB")
705
+
706
+ assert isinstance(color, Colors)
707
+ assert isinstance(color, Enumeration)
708
+
709
+ assert color.name == "GREEN"
710
+ assert color.value == 2
711
+ assert color.RGB == (0, 255, 0)
702
712
  ```
703
713
 
704
714
  # Enumerific Library Enumerations: Classes & Methods
@@ -890,4 +900,4 @@ See the documentation for [PyTest](https://docs.pytest.org/en/latest/) regarding
890
900
 
891
901
  ### Copyright & License Information
892
902
 
893
- Copyright © 2024–2025 Daniel Sissman; licensed under the MIT License.
903
+ Copyright © 2024–2026 Daniel Sissman; licensed under the MIT License.
@@ -0,0 +1,12 @@
1
+ enumerific/__init__.py,sha256=K9iFirgxSkrHgXfhocOvgRkskGe0VfWRgxEvppnVWBM,587
2
+ enumerific/exceptions.py,sha256=lvfcH1cz43hDjzSUpgm1-OZjKzxo--fyZ8UsBS-GiZA,359
3
+ enumerific/extensible.py,sha256=JPr4LRGg4rABV_WO9Yzb6FJhrxwiafju7ITIQXW6QiY,87136
4
+ enumerific/logging.py,sha256=zz1Phnot1BFWMoxwvZ0FlZDsiYZZYhz-_S4IzgPYc40,97
5
+ enumerific/standard.py,sha256=xQhhwlcYZ6-8DmgscbV38g2Ol5Z8_vvBwonz-Ww0I40,3254
6
+ enumerific/version.txt,sha256=1vkXxITmpI_Pi5DvCc3gKGw9huXerUi0L68NrpT7LfU,5
7
+ enumerific-1.0.9.dist-info/licenses/LICENSE.md,sha256=j1XidOCGUhPx7CyXA31uC0XGKDRnvUcZpMp161qHI6g,1077
8
+ enumerific-1.0.9.dist-info/METADATA,sha256=LnOD66jWq4fMD79UFTvZA-ILzxh89gdNKs8485h-3b8,34237
9
+ enumerific-1.0.9.dist-info/WHEEL,sha256=_zCd3N1l69ArxyTb8rzEoP9TpbYXkqRFSNOD5OuxnTs,91
10
+ enumerific-1.0.9.dist-info/top_level.txt,sha256=hyemsMgPYZgSx71XHmFRF-gvc_2Y4rDAESR8e0hbYHU,11
11
+ enumerific-1.0.9.dist-info/zip-safe,sha256=AbpHGcgLb-kRsJGnwFEktk7uzpZOCcBY74-YBdrKVGs,1
12
+ enumerific-1.0.9.dist-info/RECORD,,
@@ -1,12 +0,0 @@
1
- enumerific/__init__.py,sha256=K9iFirgxSkrHgXfhocOvgRkskGe0VfWRgxEvppnVWBM,587
2
- enumerific/exceptions.py,sha256=lvfcH1cz43hDjzSUpgm1-OZjKzxo--fyZ8UsBS-GiZA,359
3
- enumerific/extensible.py,sha256=HX-oZ91XtTLk5dmlqFOSFCO71_TEj1zGaO4KSKGwwoY,86507
4
- enumerific/logging.py,sha256=zz1Phnot1BFWMoxwvZ0FlZDsiYZZYhz-_S4IzgPYc40,97
5
- enumerific/standard.py,sha256=xQhhwlcYZ6-8DmgscbV38g2Ol5Z8_vvBwonz-Ww0I40,3254
6
- enumerific/version.txt,sha256=6fmB8RVMkjgdY7ZTz7_Hm-ksP2zJXgkVpeXBnzkkylg,5
7
- enumerific-1.0.7.dist-info/licenses/LICENSE.md,sha256=j1XidOCGUhPx7CyXA31uC0XGKDRnvUcZpMp161qHI6g,1077
8
- enumerific-1.0.7.dist-info/METADATA,sha256=AnTj6l-xLoVxh1rQ1dFw1t8_v3Aq2slvwgiL458SBGs,33923
9
- enumerific-1.0.7.dist-info/WHEEL,sha256=_zCd3N1l69ArxyTb8rzEoP9TpbYXkqRFSNOD5OuxnTs,91
10
- enumerific-1.0.7.dist-info/top_level.txt,sha256=hyemsMgPYZgSx71XHmFRF-gvc_2Y4rDAESR8e0hbYHU,11
11
- enumerific-1.0.7.dist-info/zip-safe,sha256=AbpHGcgLb-kRsJGnwFEktk7uzpZOCcBY74-YBdrKVGs,1
12
- enumerific-1.0.7.dist-info/RECORD,,