Re: [evolution-patches] Evolution fix for #307794
- From: Harish <kharish novell com>
- To: Vivek Jain <jvivek novell com>
- Cc: evolution-patches lists ximian com, Not Zed <notzed ximian com>
- Subject: Re: [evolution-patches] Evolution fix for #307794
- Date: Mon, 11 Jul 2005 19:43:22 +0530
Looks good to me. 
This has been a nasty bug and this patch is good enough.
Pl. do commit it.
PS. The idle handler is invoked exactly once. But it would run even if the 
objects it manipulates may have been freed already. You could add some checks
so it fails gracefully or better yet, remove the idle handler from executing
(which could require a more complicated change).
Harish
On Mon, 2005-07-11 at 19:16 +0530, Vivek Jain wrote:
hi,
Attached patch fixes the problem. The rebuild is called in the idle
handler and then we have to make sure  that the current page is
displayed after ec_rebuild is over.
Thanks,
Vivek Jain
On Fri, 2005-07-08 at 00:02 +0800, Not Zed wrote:
> Hmm, no c++ comments, its right in theHACKING file.  Go re-read it
> again.
> 
> Anyway, no, you definitly can't do this, they have to be destroyed or it
> will just break the whole e-config model.
> 
> Can you just add an idle handler so the server-changed event doesn't
> directly trigger the rebuild?  Maybe you can just do it in the
> target_changed code in e-config, so it doesn't have to be done in all
> the cases a rebuild is called for.  It might cause other issues though,
> and make sure the idle handler is removed if the object gets finalised
> before it can run, etc.
> 
> So why does this only happen with some versions of gtk+?  Still sounds
> like a gtk+/glib bug to me ...
> 
> (i.e. you can trigger a destroy of any other object from a signal from
> that object).
> 
> 
> On Thu, 2005-07-07 at 20:22 +0530, Arunprakash wrote:
> > Hi all,
> > 
> > I have a crude fix for bug #307794.
> > I have attached the patch.
> > 
> > When you select any item from the "Server Type"
> > combo box, it emits the "changed" signal.
> > 
> > This invokes "emae_provider_changed" callback which in
> > its execution path calls ec_rebuild.
> > 
> > Here the page containing the combox box
> > is destroyed and a new page with items
> > specific for that selected server type
> > is loaded.
> > 
> > But the code in gtkcombobox.c requires
> > that combo box for its pending opertions
> > and is destroyed in the callback.
> > 
> > The same happens for the combo box in the sending page also.
> > Because the same callback is used.
> > 
> > My fix removes that widget destruction leaving a memory leak.
> > 
> > The combo box has to be hold and destroyed later. But how?
> > 
> > Please review it,
> > and give suggestions and comments.
> > 
> > Thanks,
> > Arunprakash.
> > 
> > _______________________________________________
> > evolution-patches mailing list
> > evolution-patches lists ximian com
> > http://lists.ximian.com/mailman/listinfo/evolution-patches
> 
> _______________________________________________
> evolution-patches mailing list
> evolution-patches lists ximian com
> http://lists.ximian.com/mailman/listinfo/evolution-patches
_______________________________________________
evolution-patches mailing list
evolution-patches lists ximian com
http://lists.ximian.com/mailman/listinfo/evolution-patches
[
Date Prev][
Date Next]   [
Thread Prev][
Thread Next]   
[
Thread Index]
[
Date Index]
[
Author Index]