Time to close bug #145884.

After over a year of waiting (but still way ahead of Debian), wxGTK 2.8 is 
finally coming to Gentoo.  I'd like to thank everyone for their patience while 
we got the wrinkles ironed out.

Many of the problems we've had previously with wxWidgets in Gentoo were due in 
general to an incomplete separation between two major versions (being 2.4 and 
2.6).  These ebuilds had many file collisions and would conditionally install 
important files based on if the other version was installed or not, leading to 
situations where a working system was solely dependent on the order in which 
they were installed.  Uninstalling or re-emerging one would often break the 
other.  Packages would be built against whichever version was handy, despite 
what its requirements were.  Many bugs were filed, and Jakb was sad.

The first thing we did to get ourselves out of this situation was to get rid of 
2.4.  Then I took some pointers (and patches) from FreeBSD and got 2.6 and 2.8 
to coexist nicely.  After some fiddling with eclasses, a wrapper or two, and an 
eselect module, we seem to be on good ground.

So here's what you need to know.

For the Users:

Nothing. ;P  If all you know about wxGTK is it's some dependency you have to 
install on your way to building amule or vlc or audacity then everything should 
just work without you having to do a thing.  You might be happy to know we've 
cut the compile time in half though.

For the Other Users:

If you are building software outside of portage, say, doing development on a package that uses wxGTK or building something from CVS/SVN/etc., then we have a new eselect module (eselect-wxwidgets) which can be used to set the default version and type of wxGTK you need. Initially the profile is set to "none" and you'll have to switch to the one you want. This is currently a global setting, and has zero effect on packages built through portage.
We previously planned to allow installing debug and release versions side by 
side, but later decided against it.  I know there is some interest in this and 
I tried to design things to keep it open as an option so we might reconsider it 
sometime in the future.

For the Devs:

Basically, /usr/bin/wx-config is now a wrapper.  When called from userspace it 
falls through to the wx-config corresponding to the profile the user has set 
with the eselect module.  When called from wxwidgets.eclass, it uses info 
provided by the ebuild (WX_GTK_VER, need-wxwidgets) to choose which wx-config 
to call.  The obvious result of this is that ebuilds *NEED* to be accessing 
wx-config through the eclass.  There are a few packages which currently don't 
do this that I'll be filing bugs for.  Eventually (and sooner than later) 
calling the wrapper from ${PACKAGE_MANAGER} without going through the eclass 
will result in a fatal error.

The eclass has been in the tree for a bit and is documentated so I won't go over it 
again here.  `emerge eclass-manpages && man wxwidgets.eclass` should do it.  If 
we missed anything or you have any questions about the eclass please feel free to ask 
me and/or leio and/or [EMAIL PROTECTED]  One thing I did want to mention is that the 
eclass now automatically does the necessary built_with_use checks (X, unicode, etc) for 
whatever type of wxGTK you request so they can be dropped from the ebuilds.  There is 
also a new check_wx function for checking wxGTK for other USE flags (eg. opengl, odbc, 
gstreamer) in a consistent way.

The biggest change in our wxGTK-2.8 is we are no longer supporting the ansi 
profile; that is, we are unicode-only.  The upcoming wxWidgets 3.0 will do away 
with the ansi/unicode split and simply use UTF-8 for everything.  If your 
package supports building against the unicode libraries (most should), we 
encourage you to at least provide that option with a unicode USE flag or at 
most make it the default. ;)

Thanks to everyone who helped this along, tested, or otherwise poked at us to 
get it done.

Your wxWi{ndows,dgets} team.


PS. wxpython-2.8 will also be added shortly, after I finish cleaning up a few 
more packages that break when the two versions are both installed.


--
                       looks like christmas at fifty-five degrees
                                   this latitude weakens my knees
   EFFD 380E 047A 4B51 D2BD  C64F 8AA8 8346 F9A4 0662 (0xF9A40662)
--
[EMAIL PROTECTED] mailing list

Reply via email to