diff options
author | Mike Bayer <mike_mp@zzzcomputing.com> | 2007-10-31 17:15:30 +0000 |
---|---|---|
committer | Mike Bayer <mike_mp@zzzcomputing.com> | 2007-10-31 17:15:30 +0000 |
commit | 60c3a1e8a22c999f93b402b7761fd185018eb2a9 (patch) | |
tree | aaeb0ae6f5c80991397e76327fdb2f2042fddb13 /lib/sqlalchemy/orm/scoping.py | |
parent | 5a1863d092e07ae1d052af54eb0ac7a46400e399 (diff) | |
download | sqlalchemy-60c3a1e8a22c999f93b402b7761fd185018eb2a9.tar.gz |
dont call up new session unless save_on_init
Diffstat (limited to 'lib/sqlalchemy/orm/scoping.py')
-rw-r--r-- | lib/sqlalchemy/orm/scoping.py | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/lib/sqlalchemy/orm/scoping.py b/lib/sqlalchemy/orm/scoping.py index 82692aad2..3f2f2f049 100644 --- a/lib/sqlalchemy/orm/scoping.py +++ b/lib/sqlalchemy/orm/scoping.py @@ -118,7 +118,6 @@ class _ScopedExt(MapperExtension): class_.query = query() def init_instance(self, mapper, class_, oldinit, instance, args, kwargs): - session = kwargs.pop('_sa_session', self.context.registry()) if not isinstance(oldinit, types.MethodType): for key, value in kwargs.items(): if self.validate: @@ -126,6 +125,7 @@ class _ScopedExt(MapperExtension): raise exceptions.ArgumentError("Invalid __init__ argument: '%s'" % key) setattr(instance, key, value) 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)) return EXT_CONTINUE |