diff options
author | Mike Bayer <mike_mp@zzzcomputing.com> | 2007-12-29 19:20:38 +0000 |
---|---|---|
committer | Mike Bayer <mike_mp@zzzcomputing.com> | 2007-12-29 19:20:38 +0000 |
commit | a582fe3b2645f4c12221b0dc8940cefffe674a93 (patch) | |
tree | 018ccd85ce1675c3bbefd83d7af3955c1d93a7b6 /lib/sqlalchemy/orm/scoping.py | |
parent | 90d38c7407e532462059d2e98cb8d3bab31f7a36 (diff) | |
download | sqlalchemy-a582fe3b2645f4c12221b0dc8940cefffe674a93.tar.gz |
- mapped classes which extend "object" and do not provide an
__init__() method will now raise TypeError if non-empty *args
or **kwargs are present at instance construction time (and are
not consumed by any extensions such as the scoped_session mapper),
consistent with the behavior of normal Python classes [ticket:908]
Diffstat (limited to 'lib/sqlalchemy/orm/scoping.py')
-rw-r--r-- | lib/sqlalchemy/orm/scoping.py | 8 |
1 files changed, 6 insertions, 2 deletions
diff --git a/lib/sqlalchemy/orm/scoping.py b/lib/sqlalchemy/orm/scoping.py index 3f2f2f049..19cd44884 100644 --- a/lib/sqlalchemy/orm/scoping.py +++ b/lib/sqlalchemy/orm/scoping.py @@ -118,15 +118,19 @@ class _ScopedExt(MapperExtension): class_.query = query() def init_instance(self, mapper, class_, oldinit, instance, args, kwargs): + if self.save_on_init: + entity_name = kwargs.pop('_sa_entity_name', None) + session = kwargs.pop('_sa_session', None) if not isinstance(oldinit, types.MethodType): for key, value in kwargs.items(): if self.validate: if not mapper.get_property(key, resolve_synonyms=False, raiseerr=False): raise exceptions.ArgumentError("Invalid __init__ argument: '%s'" % key) setattr(instance, key, value) + kwargs.clear() if self.save_on_init: - session = kwargs.pop('_sa_session', self.context.registry()) - session._save_impl(instance, entity_name=kwargs.pop('_sa_entity_name', None)) + session = session or self.context.registry() + session._save_impl(instance, entity_name=entity_name) return EXT_CONTINUE def init_failed(self, mapper, class_, oldinit, instance, args, kwargs): |