diff options
author | Miss Islington (bot) <31488909+miss-islington@users.noreply.github.com> | 2023-08-31 22:04:55 (GMT) |
---|---|---|
committer | GitHub <noreply@github.com> | 2023-08-31 22:04:55 (GMT) |
commit | 8c3793a539ce950e552da390b7b24485dd655237 (patch) | |
tree | f270c1cc50d17f694166ac1b6af27c2c3006091d /Doc/library/ast.rst | |
parent | a92c60c99bab716d1d08bccb92dcc0fe6ee93abe (diff) | |
download | cpython-8c3793a539ce950e552da390b7b24485dd655237.zip cpython-8c3793a539ce950e552da390b7b24485dd655237.tar.gz cpython-8c3793a539ce950e552da390b7b24485dd655237.tar.bz2 |
[3.12] gh-108682: [Enum] raise TypeError if super().__new__ called in custom __new__ (GH-108704) (#108733)
gh-108682: [Enum] raise TypeError if super().__new__ called in custom __new__ (GH-108704)
When overriding the `__new__` method of an enum, the underlying data type should be created directly; i.e. .
member = object.__new__(cls)
member = int.__new__(cls, value)
member = str.__new__(cls, value)
Calling `super().__new__()` finds the lookup version of `Enum.__new__`, and will now raise an exception when detected.
(cherry picked from commit d48760b2f1e28dd3c1a35721939f400a8ab619b8)
Co-authored-by: Ethan Furman <ethan@stoneleaf.us>
Diffstat (limited to 'Doc/library/ast.rst')
0 files changed, 0 insertions, 0 deletions