diff options
| author | Mike Bayer <mike_mp@zzzcomputing.com> | 2022-03-25 17:08:48 -0400 |
|---|---|---|
| committer | Mike Bayer <mike_mp@zzzcomputing.com> | 2022-03-30 14:04:52 -0400 |
| commit | 4e754a8914a1c2c16c97bdf363d2e24bfa823730 (patch) | |
| tree | db723242b4e4c0d4c7f15c167857dd79fdfa6ccb /lib/sqlalchemy/orm/mapper.py | |
| parent | dba480ebaf89c0b5ea787661583de9da3928920f (diff) | |
| download | sqlalchemy-4e754a8914a1c2c16c97bdf363d2e24bfa823730.tar.gz | |
pep-484: the pep-484ening, SQL part three
hitting DML which is causing us to open up the
ColumnCollection structure a bit, as we do put anonymous
column expressions with None here. However, we still want
Table /TableClause to have named column collections that
don't return None, so parametrize the "key" in this
collection also.
* rename some "immutable" elements to "readonly". we change
the contents of immutablecolumncollection underneath, so it's
not "immutable"
Change-Id: I2593995a4e5c6eae874bed5bf76117198be8ae97
Diffstat (limited to 'lib/sqlalchemy/orm/mapper.py')
| -rw-r--r-- | lib/sqlalchemy/orm/mapper.py | 9 |
1 files changed, 5 insertions, 4 deletions
diff --git a/lib/sqlalchemy/orm/mapper.py b/lib/sqlalchemy/orm/mapper.py index 7d1fc7643..e463dcdb5 100644 --- a/lib/sqlalchemy/orm/mapper.py +++ b/lib/sqlalchemy/orm/mapper.py @@ -1749,6 +1749,7 @@ class Mapper( col.key = col._tq_key_label = key self.columns.add(col, key) + for col in prop.columns + prop._orig_columns: for col in col.proxy_set: self._columntoproperty[col] = prop @@ -2381,7 +2382,7 @@ class Mapper( yield c @HasMemoized.memoized_attribute - def attrs(self) -> util.ImmutableProperties["MapperProperty"]: + def attrs(self) -> util.ReadOnlyProperties["MapperProperty"]: """A namespace of all :class:`.MapperProperty` objects associated this mapper. @@ -2416,7 +2417,7 @@ class Mapper( """ self._check_configure() - return util.ImmutableProperties(self._props) + return util.ReadOnlyProperties(self._props) @HasMemoized.memoized_attribute def all_orm_descriptors(self): @@ -2484,7 +2485,7 @@ class Mapper( :attr:`_orm.Mapper.attrs` """ - return util.ImmutableProperties( + return util.ReadOnlyProperties( dict(self.class_manager._all_sqla_attributes()) ) @@ -2571,7 +2572,7 @@ class Mapper( def _filter_properties(self, type_): self._check_configure() - return util.ImmutableProperties( + return util.ReadOnlyProperties( util.OrderedDict( (k, v) for k, v in self._props.items() if isinstance(v, type_) ) |
