|
@@ -249,11 +249,19 @@ class SingleRelatedObjectDescriptor(object):
|
|
|
if instance is None:
|
|
|
return self
|
|
|
try:
|
|
|
- return getattr(instance, self.cache_name)
|
|
|
+ rel_obj = getattr(instance, self.cache_name)
|
|
|
except AttributeError:
|
|
|
params = {'%s__pk' % self.related.field.name: instance._get_pk_val()}
|
|
|
- rel_obj = self.get_query_set(instance=instance).get(**params)
|
|
|
+ try:
|
|
|
+ rel_obj = self.get_query_set(instance=instance).get(**params)
|
|
|
+ except self.related.model.DoesNotExist:
|
|
|
+ rel_obj = None
|
|
|
+ else:
|
|
|
+ setattr(rel_obj, self.related.field.get_cache_name(), instance)
|
|
|
setattr(instance, self.cache_name, rel_obj)
|
|
|
+ if rel_obj is None:
|
|
|
+ raise self.related.model.DoesNotExist
|
|
|
+ else:
|
|
|
return rel_obj
|
|
|
|
|
|
def __set__(self, instance, value):
|
|
@@ -331,24 +339,27 @@ class ReverseSingleRelatedObjectDescriptor(object):
|
|
|
def __get__(self, instance, instance_type=None):
|
|
|
if instance is None:
|
|
|
return self
|
|
|
-
|
|
|
try:
|
|
|
- return getattr(instance, self.cache_name)
|
|
|
+ rel_obj = getattr(instance, self.cache_name)
|
|
|
except AttributeError:
|
|
|
val = getattr(instance, self.field.attname)
|
|
|
if val is None:
|
|
|
-
|
|
|
- if self.field.null:
|
|
|
- return None
|
|
|
- raise self.field.rel.to.DoesNotExist
|
|
|
- other_field = self.field.rel.get_related_field()
|
|
|
- if other_field.rel:
|
|
|
- params = {'%s__pk' % self.field.rel.field_name: val}
|
|
|
+ rel_obj = None
|
|
|
else:
|
|
|
- params = {'%s__exact' % self.field.rel.field_name: val}
|
|
|
- qs = self.get_query_set(instance=instance)
|
|
|
- rel_obj = qs.get(**params)
|
|
|
+ other_field = self.field.rel.get_related_field()
|
|
|
+ if other_field.rel:
|
|
|
+ params = {'%s__pk' % self.field.rel.field_name: val}
|
|
|
+ else:
|
|
|
+ params = {'%s__exact' % self.field.rel.field_name: val}
|
|
|
+ qs = self.get_query_set(instance=instance)
|
|
|
+
|
|
|
+ rel_obj = qs.get(**params)
|
|
|
+ if not self.field.rel.multiple:
|
|
|
+ setattr(rel_obj, self.field.related.get_cache_name(), instance)
|
|
|
setattr(instance, self.cache_name, rel_obj)
|
|
|
+ if rel_obj is None and not self.field.null:
|
|
|
+ raise self.field.rel.to.DoesNotExist
|
|
|
+ else:
|
|
|
return rel_obj
|
|
|
|
|
|
def __set__(self, instance, value):
|
|
@@ -385,17 +396,13 @@ class ReverseSingleRelatedObjectDescriptor(object):
|
|
|
|
|
|
|
|
|
|
|
|
- related = getattr(instance, self.field.get_cache_name(), None)
|
|
|
+ related = getattr(instance, self.cache_name, None)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
- if related:
|
|
|
- cache_name = self.field.related.get_cache_name()
|
|
|
- try:
|
|
|
- delattr(related, cache_name)
|
|
|
- except AttributeError:
|
|
|
- pass
|
|
|
+ if related is not None:
|
|
|
+ setattr(related, self.field.related.get_cache_name(), None)
|
|
|
|
|
|
|
|
|
try:
|
|
@@ -405,9 +412,11 @@ class ReverseSingleRelatedObjectDescriptor(object):
|
|
|
setattr(instance, self.field.attname, val)
|
|
|
|
|
|
|
|
|
-
|
|
|
+
|
|
|
|
|
|
- setattr(instance, self.field.get_cache_name(), value)
|
|
|
+ setattr(instance, self.cache_name, value)
|
|
|
+ if value is not None and not self.field.rel.multiple:
|
|
|
+ setattr(value, self.field.related.get_cache_name(), instance)
|
|
|
|
|
|
class ForeignRelatedObjectsDescriptor(object):
|
|
|
|