[Python-checkins] Enum: add extended AutoNumber example (GH-22349)

Ethan Furman webhook-mailer at python.org
Tue Sep 22 03:05:34 EDT 2020


https://github.com/python/cpython/commit/62e40d8450b9c78346ec3617de7fe3f0ad381510
commit: 62e40d8450b9c78346ec3617de7fe3f0ad381510
branch: master
author: Ethan Furman <ethan at stoneleaf.us>
committer: GitHub <noreply at github.com>
date: 2020-09-22T00:05:27-07:00
summary:

Enum: add extended AutoNumber example (GH-22349)

files:
M Doc/library/enum.rst
M Misc/ACKS

diff --git a/Doc/library/enum.rst b/Doc/library/enum.rst
index 843d961afc4f7..3e9b1f9db3550 100644
--- a/Doc/library/enum.rst
+++ b/Doc/library/enum.rst
@@ -925,6 +925,32 @@ Using an auto-numbering :meth:`__new__` would look like::
     >>> Color.GREEN.value
     2
 
+To make a more general purpose ``AutoNumber``, add ``*args`` to the signature::
+
+    >>> class AutoNumber(NoValue):
+    ...     def __new__(cls, *args):      # this is the only change from above
+    ...         value = len(cls.__members__) + 1
+    ...         obj = object.__new__(cls)
+    ...         obj._value_ = value
+    ...         return obj
+    ...
+
+Then when you inherit from ``AutoNumber`` you can write your own ``__init__``
+to handle any extra arguments::
+
+    >>> class Swatch(AutoNumber):
+    ...     def __init__(self, pantone='unknown'):
+    ...         self.pantone = pantone
+    ...     AUBURN = '3497'
+    ...     SEA_GREEN = '1246'
+    ...     BLEACHED_CORAL = () # New color, no Pantone code yet!
+    ...
+    >>> Swatch.SEA_GREEN
+    <Swatch.SEA_GREEN: 2>
+    >>> Swatch.SEA_GREEN.pantone
+    '1246'
+    >>> Swatch.BLEACHED_CORAL.pantone
+    'unknown'
 
 .. note::
 
diff --git a/Misc/ACKS b/Misc/ACKS
index 01ee1cb42d39d..e4bd3da6b6c40 100644
--- a/Misc/ACKS
+++ b/Misc/ACKS
@@ -1723,6 +1723,7 @@ Févry Thibault
 Lowe Thiderman
 Nicolas M. Thiéry
 James Thomas
+Reuben Thomas
 Robin Thomas
 Brian Thorne
 Christopher Thorne



More information about the Python-checkins mailing list