]> git.ipfire.org Git - thirdparty/Python/cpython.git/commit
bpo-44649: Fix dataclasses(slots=True) with a field with a default, but init=False...
authorEric V. Smith <ericvsmith@users.noreply.github.com>
Mon, 22 Nov 2021 13:26:12 +0000 (08:26 -0500)
committerGitHub <noreply@github.com>
Mon, 22 Nov 2021 13:26:12 +0000 (08:26 -0500)
commitd3062f672c92855b7e9e962ad4bf1a67abd4589b
tree6820af4d14c25fb50287439c821d86d4fa39f7c5
parent5b946cadaa1175a5caae98bd2d309840bea52a58
bpo-44649: Fix dataclasses(slots=True) with a field with a default, but init=False (GH-29692)

Special handling is needed, because for non-slots dataclasses the instance attributes are not set: reading from a field just references the class's attribute of the same name, which contains the default value. But this doesn't work for classes using __slots__: they don't read the class's attribute. So in that case (and that case only), initialize the instance attribute. Handle this for both normal defaults, and for fields using default_factory.
Lib/dataclasses.py
Lib/test/test_dataclasses.py
Misc/NEWS.d/next/Library/2021-11-21-20-50-42.bpo-44649.E8M936.rst [new file with mode: 0644]