[1.5.x] Made custom m2m fields without through easier to use

The change in f105fbe52b made through=None
m2m fields fail in cases where they worked before. It isn't possible to
create such fields using public APIs. The fix is trivial, so it seems
worth adding it.

This is not a backport from master. Master has gotten enough other
changes to related fields internal API that this fix alone isn't enough
to do any good.
This commit is contained in:
Anssi Kääriäinen 2013-02-10 21:49:03 +02:00
parent 44afe44602
commit 77f6eb2a60
1 changed files with 3 additions and 1 deletions

View File

@ -591,12 +591,14 @@ def create_many_related_manager(superclass, rel):
"a many-to-many relationship can be used." % "a many-to-many relationship can be used." %
instance.__class__.__name__) instance.__class__.__name__)
def _get_fk_val(self, obj, field_name): def _get_fk_val(self, obj, field_name):
""" """
Returns the correct value for this relationship's foreign key. This Returns the correct value for this relationship's foreign key. This
might be something else than pk value when to_field is used. might be something else than pk value when to_field is used.
""" """
if not self.through:
# Make custom m2m fields with no through model defined usable.
return obj.pk
fk = self.through._meta.get_field(field_name) fk = self.through._meta.get_field(field_name)
if fk.rel.field_name and fk.rel.field_name != fk.rel.to._meta.pk.attname: if fk.rel.field_name and fk.rel.field_name != fk.rel.to._meta.pk.attname:
attname = fk.rel.get_related_field().get_attname() attname = fk.rel.get_related_field().get_attname()