summaryrefslogtreecommitdiff
path: root/lib/sqlalchemy/ext/assignmapper.py
diff options
context:
space:
mode:
authorMike Bayer <mike_mp@zzzcomputing.com>2006-05-25 14:20:23 +0000
committerMike Bayer <mike_mp@zzzcomputing.com>2006-05-25 14:20:23 +0000
commitbb79e2e871d0a4585164c1a6ed626d96d0231975 (patch)
tree6d457ba6c36c408b45db24ec3c29e147fe7504ff /lib/sqlalchemy/ext/assignmapper.py
parent4fc3a0648699c2b441251ba4e1d37a9107bd1986 (diff)
downloadsqlalchemy-bb79e2e871d0a4585164c1a6ed626d96d0231975.tar.gz
merged 0.2 branch into trunk; 0.1 now in sqlalchemy/branches/rel_0_1
Diffstat (limited to 'lib/sqlalchemy/ext/assignmapper.py')
-rw-r--r--lib/sqlalchemy/ext/assignmapper.py34
1 files changed, 34 insertions, 0 deletions
diff --git a/lib/sqlalchemy/ext/assignmapper.py b/lib/sqlalchemy/ext/assignmapper.py
new file mode 100644
index 000000000..b8a676b75
--- /dev/null
+++ b/lib/sqlalchemy/ext/assignmapper.py
@@ -0,0 +1,34 @@
+from sqlalchemy import mapper, util
+import types
+
+def monkeypatch_query_method(ctx, class_, name):
+ def do(self, *args, **kwargs):
+ query = class_.mapper.query(session=ctx.current)
+ return getattr(query, name)(*args, **kwargs)
+ setattr(class_, name, classmethod(do))
+
+def monkeypatch_objectstore_method(ctx, class_, name):
+ def do(self, *args, **kwargs):
+ session = ctx.current
+ return getattr(session, name)(self, *args, **kwargs)
+ setattr(class_, name, do)
+
+def assign_mapper(ctx, class_, *args, **kwargs):
+ kwargs.setdefault("is_primary", True)
+ if not isinstance(getattr(class_, '__init__'), types.MethodType):
+ def __init__(self, **kwargs):
+ for key, value in kwargs.items():
+ setattr(self, key, value)
+ class_.__init__ = __init__
+ extension = kwargs.pop('extension', None)
+ if extension is not None:
+ extension = util.to_list(extension)
+ extension.append(ctx.mapper_extension)
+ else:
+ extension = ctx.mapper_extension
+ m = mapper(class_, extension=extension, *args, **kwargs)
+ class_.mapper = m
+ for name in ['get', 'select', 'select_by', 'selectone', 'get_by', 'join_to', 'join_via']:
+ monkeypatch_query_method(ctx, class_, name)
+ for name in ['flush', 'delete', 'expire', 'refresh', 'expunge', 'merge', 'update', 'save_or_update']:
+ monkeypatch_objectstore_method(ctx, class_, name)