]> git.ipfire.org Git - thirdparty/sqlalchemy/sqlalchemy.git/commit
read from cls.__dict__ so init_subclass works
authorMike Bayer <mike_mp@zzzcomputing.com>
Mon, 4 Apr 2022 23:01:54 +0000 (19:01 -0400)
committerMike Bayer <mike_mp@zzzcomputing.com>
Tue, 12 Apr 2022 19:10:32 +0000 (15:10 -0400)
commit428ea01f00a9cc7f85e435018565eb6da7af1b77
tree8a39510cc038731e2df8f8b536ae1c533bd23351
parenta45e2284dad17fbbba3bea9d5e5304aab21c8c94
read from cls.__dict__ so init_subclass works

Modified the :class:`.DeclarativeMeta` metaclass to pass ``cls.__dict__``
into the declarative scanning process to look for attributes, rather than
the separate dictionary passed to the type's ``__init__()`` method. This
allows user-defined base classes that add attributes within an
``__init_subclass__()`` to work as expected, as ``__init_subclass__()`` can
only affect the ``cls.__dict__`` itself and not the other dictionary. This
is technically a regression from 1.3 where ``__dict__`` was being used.

Additionally makes the reference between ClassManager and
the declarative configuration object a weak reference, so that it
can be discarded after mappers are set up.

Fixes: #7900
Change-Id: I3c2fd4e227cc1891aa4bb3d7d5b43d5686f9f27c
doc/build/changelog/unreleased_14/7900.rst [new file with mode: 0644]
lib/sqlalchemy/orm/decl_api.py
lib/sqlalchemy/orm/decl_base.py
lib/sqlalchemy/orm/instrumentation.py
test/orm/declarative/test_mixin.py