public inbox for gentoo-dev@lists.gentoo.org
 help / color / mirror / Atom feed
* [gentoo-dev] blocking mixed versions of split QT libraries
@ 2009-05-18 10:04 Alex Alexander
  2009-05-18 10:22 ` Alistair Bush
  2009-05-18 14:21 ` Ciaran McCreesh
  0 siblings, 2 replies; 18+ messages in thread
From: Alex Alexander @ 2009-05-18 10:04 UTC (permalink / raw
  To: Gentoo-ML-dev

QT doesn't work well when mixed versions of its core libraries are
installed. Usually an emerge -avDu world solves the problem, but some
users tend to avoid this.

For example, lets say you have parts of QT 4.4.2 on your system. QT
4.5.1 is available and a user decides to manually update qt-core, or
to install KDE which has a QT dependency on a QT library not
installed. In these cases, portage will update only a part of the
installed QT libraries, leaving the system in a mixed state.

QT based apps don't like that. Others will refuse to build, others
will fail to run.

We've managed to experimentally block partial QT upgrades by adding an
RDEPEND to all QT libraries [1] in qting-edge overlay. Portage
understands this and throws out B blocks if you try to change versions
only in parts of QT, but upgrades/downgrades fine if you do them all
at once (or use -Du world).

This "fix" also catches stale QT libraries that nothing depends on
anymore because the user has removed whatever required them (and never
ran --depclean).

Unfortunately we've got reports from paludis users stating that they
can't update QT from qting-edge anymore.

What I'd like to discuss is the following:

1) Is there a saner way to achieve our goal of doing whatever is
possible to avoid mixed QT versions?
2) Is our implementation considered correct and acceptable by the PMS guys?
3) Whats the general Gentoo Policy on mixed versions? Do we care, or
is our policy "please -Du world"?

We've also managed to achieve the same thing by adding PDEPENDs to
each QT library for any other QT libraries that depend on it:

i.e. if qt-xmlpatterns depends on qt-gui, we add the following to qt-gui:
PDEPEND="
|| ( !x11-libs/qt-xmlpatterns ~x11-libs/qt-xmlpatterns-${PV} )
"

the above (expanded for all libraries) has the same effect as the [1]
RDEPEND but looks a bit more hackish.

thanks

[1] lines 30-59
http://github.com/gentoo-qt/qting-edge/blob/master/eclass/qt4-build-edge.eclass

--
Alex Alexander || wired
Gentoo QT && KDE Herd Tester
http://www.linuxized.com



^ permalink raw reply	[flat|nested] 18+ messages in thread

end of thread, other threads:[~2009-05-18 20:55 UTC | newest]

Thread overview: 18+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2009-05-18 10:04 [gentoo-dev] blocking mixed versions of split QT libraries Alex Alexander
2009-05-18 10:22 ` Alistair Bush
2009-05-18 16:34   ` Alex Alexander
2009-05-18 14:21 ` Ciaran McCreesh
2009-05-18 14:47   ` Petteri Räty
2009-05-18 14:52     ` Ciaran McCreesh
2009-05-18 17:15       ` Maciej Mrozowski
2009-05-18 17:26         ` Ciaran McCreesh
2009-05-18 18:05           ` Maciej Mrozowski
2009-05-18 18:19             ` Ciaran McCreesh
2009-05-18 19:08               ` Patrick Lauer
2009-05-18 19:20                 ` Ciaran McCreesh
2009-05-18 20:47                   ` Patrick Lauer
2009-05-18 20:55                     ` Ciaran McCreesh
2009-05-18 16:42   ` Alex Alexander
2009-05-18 16:51     ` Ciaran McCreesh
2009-05-18 17:01       ` Alex Alexander
2009-05-18 17:11         ` Ciaran McCreesh

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox