RESOLVED FIXED 51241
[GTK] GRefPtr should not be used with Gtk widgets
https://bugs.webkit.org/show_bug.cgi?id=51241
Summary [GTK] GRefPtr should not be used with Gtk widgets
Carlos Garcia Campos
Reported 2010-12-17 02:38:46 PST
PlatformRefPtr breaks the widget life-cycle, the main problem is that PlatformRefPtr calls g_object_unref() when it's destroyed, which is undesirable for widgets. In gtk+ widgets are created with a floating reference and when added to a container, the container takes the ownership of the widget consuming the floating reference. So you don't usually need to call g_object_ref/unref on widgets (only for some operations like reparent a widget) and toplevel widgets are destroyed with gtk_widget_destroy(). There are some cases like EditorClientGtk where the widget used is not a toplevel and it's not going to be added to a container, in this case using PlatformRefPtr is correct, since you are taking the ownership of the widget.
Attachments
Patch (13.91 KB, patch)
2010-12-17 02:42 PST, Carlos Garcia Campos
no flags
Carlos Garcia Campos
Comment 1 2010-12-17 02:42:35 PST
Martin Robinson
Comment 2 2010-12-17 14:36:31 PST
Is this necessarily an error for non-toplevel widgets? If you add a widget to a container from a PlatformRefPtr the reference count should still be fine, assuming the PlatformRefPtr goes out of scope.
Carlos Garcia Campos
Comment 3 2010-12-19 23:57:10 PST
(In reply to comment #2) > Is this necessarily an error for non-toplevel widgets? It's not necessarily an error, you keep a reference, so that when the widget is desroyed you still have the reference and when PlatormRefPtr release the last reference the widget is finally destroyed. But that's not how we expect gtk+ widgets to work. PlatformRefPtr is supposed to be for taking the ownership of objects to release them when they are not needed anymore, gtk+ already does that for widgets, you create a widget, add it to a container and forget about it. > If you add a widget to a container from a PlatformRefPtr the reference count should still be fine, assuming the PlatformRefPtr goes out of scope. No it isn't, when the widget is created by gtk+ it has a floating reference, then PlatformRefPtr consumes the reference, so that when the widget is added to the container it has a real reference, rather than a floating one which is what the container expects. If you use adoptPlatformRef to not take the reference and let the parent widget do it as expected, PlatformRefPtr would release a reference that it doesn't have.
Martin Robinson
Comment 4 2010-12-20 22:59:27 PST
(In reply to comment #3) > (In reply to comment #2) > > Is this necessarily an error for non-toplevel widgets? > > It's not necessarily an error, you keep a reference, so that when the widget is desroyed you still have the reference and when PlatormRefPtr release the last reference the widget is finally destroyed. But that's not how we expect gtk+ widgets to work. PlatformRefPtr is supposed to be for taking the ownership of objects to release them when they are not needed anymore, gtk+ already does that for widgets, you create a widget, add it to a container and forget about it. In this case it should still be appropriate for situations where WebKit wants to control the lifetime of the GTK+ object or if it's shared between WebKit classes. For instance, ContextMenu isn't copyable, but if it was we would want the menu widget to be a PlatformRefPtr.
Carlos Garcia Campos
Comment 5 2010-12-20 23:13:00 PST
(In reply to comment #4) > > In this case it should still be appropriate for situations where WebKit wants to control the lifetime of the GTK+ object or if it's shared between WebKit classes. For instance, ContextMenu isn't copyable, but if it was we would want the menu widget to be a PlatformRefPtr. Sure, as I said in the bug description there are some situations where using PlatformRefPtr with widgets is correct.
Holger Freyther
Comment 6 2010-12-24 02:46:30 PST
(In reply to comment #5) > (In reply to comment #4) > > > > In this case it should still be appropriate for situations where WebKit wants to control the lifetime of the GTK+ object or if it's shared between WebKit classes. For instance, ContextMenu isn't copyable, but if it was we would want the menu widget to be a PlatformRefPtr. > > Sure, as I said in the bug description there are some situations where using PlatformRefPtr with widgets is correct. How did you find this? Review or did it misbehave?
Carlos Garcia Campos
Comment 7 2010-12-24 02:52:26 PST
(In reply to comment #6) > (In reply to comment #5) > > (In reply to comment #4) > > > > > > In this case it should still be appropriate for situations where WebKit wants to control the lifetime of the GTK+ object or if it's shared between WebKit classes. For instance, ContextMenu isn't copyable, but if it was we would want the menu widget to be a PlatformRefPtr. > > > > Sure, as I said in the bug description there are some situations where using PlatformRefPtr with widgets is correct. > > How did you find this? Review or did it misbehave? I noticed it when I was working on bug #49658, then I reviewed all other cases where PlatformRefPtr was used with widgets. There's no misbehaviour actually since it works, but it's not how gtk widgets are expected to work and it makes the code confusing.
Holger Freyther
Comment 8 2010-12-24 02:57:55 PST
(In reply to comment #7) > > > > How did you find this? Review or did it misbehave? > > I noticed it when I was working on bug #49658, then I reviewed all other cases where PlatformRefPtr was used with widgets. There's no misbehaviour actually since it works, but it's not how gtk widgets are expected to work and it makes the code confusing. I agree that it should be changed, I was just interested in how this was found. I try to find time to review your patch.
Martin Robinson
Comment 9 2011-01-10 08:55:36 PST
Comment on attachment 76860 [details] Patch Okay. :) This probably needs to be updated against HEAD though sicne PlatformRefPtr is now called GRefPtr.
Carlos Garcia Campos
Comment 10 2011-01-11 03:19:15 PST
Note You need to log in before you can comment on or make changes to this bug.