summaryrefslogtreecommitdiff
path: root/lib/sqlalchemy
diff options
context:
space:
mode:
authorMike Bayer <mike_mp@zzzcomputing.com>2008-10-12 04:25:53 +0000
committerMike Bayer <mike_mp@zzzcomputing.com>2008-10-12 04:25:53 +0000
commit3bf1ddfb912f43657d66f5c2807198e93a33818a (patch)
tree2c38edc44bc919ab5e312571a4ca6ab2007945d8 /lib/sqlalchemy
parent41e1f5526cf24131f6365de2c48f39748504daf2 (diff)
downloadsqlalchemy-3bf1ddfb912f43657d66f5c2807198e93a33818a.tar.gz
a much easier way to ArgSingleton
Diffstat (limited to 'lib/sqlalchemy')
-rw-r--r--lib/sqlalchemy/orm/dependency.py25
-rw-r--r--lib/sqlalchemy/util.py18
2 files changed, 11 insertions, 32 deletions
diff --git a/lib/sqlalchemy/orm/dependency.py b/lib/sqlalchemy/orm/dependency.py
index 5293ad658..b33213a80 100644
--- a/lib/sqlalchemy/orm/dependency.py
+++ b/lib/sqlalchemy/orm/dependency.py
@@ -42,6 +42,7 @@ class DependencyProcessor(object):
self.passive_updates = prop.passive_updates
self.enable_typechecks = prop.enable_typechecks
self.key = prop.key
+ self.dependency_marker = MapperStub(self.parent, self.mapper, self.key)
if not self.prop.synchronize_pairs:
raise sa_exc.ArgumentError("Can't build a DependencyProcessor for relation %s. No target attributes to populate between parent and child are present" % self.prop)
@@ -152,10 +153,9 @@ class OneToManyDP(DependencyProcessor):
def register_dependencies(self, uowcommit):
if self.post_update:
if not self.is_backref:
- stub = MapperStub(self.parent, self.mapper, self.key)
- uowcommit.register_dependency(self.mapper, stub)
- uowcommit.register_dependency(self.parent, stub)
- uowcommit.register_processor(stub, self, self.parent)
+ uowcommit.register_dependency(self.mapper, self.dependency_marker)
+ uowcommit.register_dependency(self.parent, self.dependency_marker)
+ uowcommit.register_processor(self.dependency_marker, self, self.parent)
else:
uowcommit.register_dependency(self.parent, self.mapper)
uowcommit.register_processor(self.parent, self, self.parent)
@@ -306,10 +306,9 @@ class ManyToOneDP(DependencyProcessor):
def register_dependencies(self, uowcommit):
if self.post_update:
if not self.is_backref:
- stub = MapperStub(self.parent, self.mapper, self.key)
- uowcommit.register_dependency(self.mapper, stub)
- uowcommit.register_dependency(self.parent, stub)
- uowcommit.register_processor(stub, self, self.parent)
+ uowcommit.register_dependency(self.mapper, self.dependency_marker)
+ uowcommit.register_dependency(self.parent, self.dependency_marker)
+ uowcommit.register_processor(self.dependency_marker, self, self.parent)
else:
uowcommit.register_dependency(self.mapper, self.parent)
uowcommit.register_processor(self.mapper, self, self.parent)
@@ -386,10 +385,9 @@ class ManyToManyDP(DependencyProcessor):
# related mappers. its dependency processor then populates the
# association table.
- stub = MapperStub(self.parent, self.mapper, self.key)
- uowcommit.register_dependency(self.parent, stub)
- uowcommit.register_dependency(self.mapper, stub)
- uowcommit.register_processor(stub, self, self.parent)
+ uowcommit.register_dependency(self.parent, self.dependency_marker)
+ uowcommit.register_dependency(self.mapper, self.dependency_marker)
+ uowcommit.register_processor(self.dependency_marker, self, self.parent)
def process_dependencies(self, task, deplist, uowcommit, delete = False):
#print self.mapper.mapped_table.name + " " + self.key + " " + repr(len(deplist)) + " process_dep isdelete " + repr(delete) + " direction " + repr(self.direction)
@@ -496,8 +494,7 @@ class MapperStub(object):
so that a depedendency can be corresponded to it.
"""
- __metaclass__ = util.ArgSingleton
-
+
def __init__(self, parent, mapper, key):
self.mapper = mapper
self.base_mapper = self
diff --git a/lib/sqlalchemy/util.py b/lib/sqlalchemy/util.py
index 43df0ec68..88245945e 100644
--- a/lib/sqlalchemy/util.py
+++ b/lib/sqlalchemy/util.py
@@ -218,24 +218,6 @@ def flatten_iterator(x):
else:
yield elem
-class ArgSingleton(type):
- instances = weakref.WeakValueDictionary()
-
- def dispose(cls):
- for key in list(ArgSingleton.instances):
- if key[0] is cls:
- del ArgSingleton.instances[key]
- dispose = staticmethod(dispose)
-
- def __call__(self, *args):
- hashkey = (self, args)
- try:
- return ArgSingleton.instances[hashkey]
- except KeyError:
- instance = type.__call__(self, *args)
- ArgSingleton.instances[hashkey] = instance
- return instance
-
def get_cls_kwargs(cls):
"""Return the full set of inherited kwargs for the given `cls`.