Thanks Malcome,

I was thinking of a kind of dispatch.connect "related-pre-save" and
"related-post-save" for the manytomany related data.
A bit like the existing "pre-save" and "post-save".

The idea to look at the manipulator is not bad too.
I'll investigate it, thanks.






Malcolm Tredinnick wrote:
> On Sat, 2006-07-08 at 17:49 +0000, william wrote:
> > I've been trough the save() as documented here:
> > http://code.djangoproject.com/wiki/RemovingTheMagic#Overridingsaveanddeletemodelmethods
> >
> > But, this  does not work for fields having a ManyToMany relation.
> > If you take the example with "publication" and "article" as described
> > here: http://www.djangoproject.com/documentation/models/many_to_many/
> >
> > If you put the following into the "Article" class:
> >     def save(self):
> >         print "Before",self.publications.all()
> >         super(Article, self).save()
> >         print "after",self.publications.all()
> >
> > You'll see that you'll always see the same result before and after the
> > save.
> > (standard fields are yet working correctly)
> > It seems that the manytomany related data are saved after the complete
> > execution of save().
> > I'm using revision 3275
> > In my case this is annoying.
>
> Related items (the things being saved into the many-to-many relation)
> are not saved as part of a model's save method, as you have discovered.
> Instead, the Add- and ChangeManipulators save the many-to-many items
> later. In fact, for adding a new item, this is basically required,
> because you need to know the new instance's primary key value before you
> can save a reference to it in the m2m join table -- and that value does
> not necessarily exist before it is saved to the database.
>
> At the moment, any workaround is going to involve custom manipulators, I
> suspect (although I may be missing something obvious). We might be able
> to come up with something a bit nicer with the upcoming manipulator
> refactoring that is on the table.
>
> This does come up from time to time when somebody wants to take action
> based on a new relationship being created. So you're not on the fringe
> here by wanting this.
>
> Sorry, not much encouragement there except to say it's a known problem
> (well, at least, I consider it a "problem"). Maybe somebody smarter than
> me can suggest an easy solution at the moment *shrug*.
> 
> Regards,
> Malcolm


--~--~---------~--~----~------------~-------~--~----~
You received this message because you are subscribed to the Google Groups 
"Django users" group.
To post to this group, send email to django-users@googlegroups.com
To unsubscribe from this group, send email to [EMAIL PROTECTED]
For more options, visit this group at 
http://groups.google.com/group/django-users
-~----------~----~----~----~------~----~------~--~---

Reply via email to