Re: gtk+ API change; who should fix it? (A.k.a. Why isn't GNOME 2.19.4 released yet?)
- From: Owen Taylor <otaylor redhat com>
- To: Murray Cumming <murrayc murrayc com>
- Cc: GTK Dev List <gtk-devel-list gnome org>, jsacco gnome org, Johan Dahlin <jdahlin async com br>, "Gustavo J. A. M. Carneiro" <gjc inescporto pt>, Gnome Desktop Development List <desktop-devel-list gnome org>
- Subject: Re: gtk+ API change; who should fix it? (A.k.a. Why isn't GNOME 2.19.4 released yet?)
- Date: Fri, 22 Jun 2007 10:51:13 -0400
On Fri, 2007-06-22 at 15:36 +0200, Murray Cumming wrote:
> On Fri, 2007-06-22 at 13:58 +0100, Gustavo J. A. M. Carneiro wrote:
> > On Qui, 2007-06-21 at 23:39 -0300, Johan Dahlin wrote:
> > > Joseph Sacco wrote:
> > > > The currently available version of pygtk is the stable branch. I would
> > > > expect the development branchof pygtk to adapt.
> > > >
> > > I'm ready to adapt but only if the general consent is that API changes
> > > are okay.
> > >
> > > My personal opinion is that the API shouldn't be allowed to change, once
> > > an API is added it should stay stable until the major version is bumped
> > > (3.0 in the case of gtk+).
> >
> > I'm 100% with Johan on this one. Gtk+ 2.11.x broke API and ABI.
> > Before 2.11.x, the structure is:
> >
> > struct _GtkTooltips
> > {
> > GtkObject parent_instance;
> >
> > GtkWidget *tip_window;
> > GtkWidget *tip_label;
> > GtkTooltipsData *active_tips_data;
> > GList *tips_data_list;
> >
> > guint delay : 30;
> > guint enabled : 1;
> > guint have_grab : 1;
> > guint use_sticky_delay : 1;
> > gint timer_tag;
> > GTimeVal last_popdown;
> > };
> >
> > None of these fields is marked private, therefore they are public.
>
> Actually, that's not the convention in GTK+, though I doubt that it's
> written down anywhere official. struct fields are private unless marked
> as public. It's obviously difficult to know, and easy to make the
> mistake.
Actually, it's more complex than that:
Object structures are private unless marked public
Non-object structures are public unles marked private
gtk-doc respects this, so you can tell what is public by looking at the
docs...
> But even if an app did something wrong, we should still avoid breaking
> that app unnecessarily.
Yeah. I don't see the big deal here. The change broke compilation of
a commonly used package. It needs to be reverted, unless the reverting
it would change the compilation failure into a segfault. The fact that
the access was "illegal" doesn't matter.
- Owen
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]