diff options
author | Markos Chandras <hwoarang@gentoo.org> | 2009-12-07 15:19:56 +0000 |
---|---|---|
committer | Markos Chandras <hwoarang@gentoo.org> | 2009-12-07 15:19:56 +0000 |
commit | 7612990680cd41cc68bca81a771caa78e9880a10 (patch) | |
tree | 2a73691f8e4e283f11d4a514132ca02f8ec89102 /x11-libs | |
parent | removed invalid block (diff) | |
download | historical-7612990680cd41cc68bca81a771caa78e9880a10.tar.gz historical-7612990680cd41cc68bca81a771caa78e9880a10.tar.bz2 historical-7612990680cd41cc68bca81a771caa78e9880a10.zip |
Add patch to fix plasma crash on kde4. Bug #296003
Package-Manager: portage-2.2_rc55/cvs/Linux x86_64
Diffstat (limited to 'x11-libs')
-rw-r--r-- | x11-libs/qt-gui/ChangeLog | 8 | ||||
-rw-r--r-- | x11-libs/qt-gui/Manifest | 14 | ||||
-rw-r--r-- | x11-libs/qt-gui/files/qt-gui-4.6.0-fix-qgraphicsscence.patch | 40 | ||||
-rw-r--r-- | x11-libs/qt-gui/qt-gui-4.6.0-r1.ebuild | 172 |
4 files changed, 222 insertions, 12 deletions
diff --git a/x11-libs/qt-gui/ChangeLog b/x11-libs/qt-gui/ChangeLog index 7e7e98a45555..9fcc33e0e5be 100644 --- a/x11-libs/qt-gui/ChangeLog +++ b/x11-libs/qt-gui/ChangeLog @@ -1,6 +1,12 @@ # ChangeLog for x11-libs/qt-gui # Copyright 1999-2009 Gentoo Foundation; Distributed under the GPL v2 -# $Header: /var/cvsroot/gentoo-x86/x11-libs/qt-gui/ChangeLog,v 1.86 2009/12/01 18:16:30 tampakrap Exp $ +# $Header: /var/cvsroot/gentoo-x86/x11-libs/qt-gui/ChangeLog,v 1.87 2009/12/07 15:19:56 hwoarang Exp $ + +*qt-gui-4.6.0-r1 (07 Dec 2009) + + 07 Dec 2009; Markos Chandras <hwoarang@gentoo.org> + +qt-gui-4.6.0-r1.ebuild, +files/qt-gui-4.6.0-fix-qgraphicsscence.patch: + Add patch to fix plasma crash on kde4. Bug #296003 01 Dec 2009; Theo Chatzimichos <tampakrap@gentoo.org> -qt-gui-4.6.0_rc1.ebuild: diff --git a/x11-libs/qt-gui/Manifest b/x11-libs/qt-gui/Manifest index 85d5d7c2268d..64a59c14fc4d 100644 --- a/x11-libs/qt-gui/Manifest +++ b/x11-libs/qt-gui/Manifest @@ -1,18 +1,10 @@ ------BEGIN PGP SIGNED MESSAGE----- -Hash: SHA1 - AUX hardcoded_fonts.patch 520 RMD160 cdc8f5b4db20b4eede5eabad61ea7893e7b2fc8f SHA1 e23e2731074170585165d89822b83215ba0e3bea SHA256 0d428c620f995d1e96e649b3e49e9ce591b2882a38e600b485c6c8b509504c51 AUX qt-4.5.3-glib-event-loop.patch 770 RMD160 0b854962f1b46958e8b969f949fe5e0d6e66b5ff SHA1 26543a05f894678fd1357d7b0fca217dac6b1a0c SHA256 83f010690d3a7220f5bd559b2aa82d9135d31a2c04bf9d6b12ed78a2dd3da6bb +AUX qt-gui-4.6.0-fix-qgraphicsscence.patch 1580 RMD160 9fb7c764016d7489e8d5de50ba2d8da70a429016 SHA1 4ad41221ef76d90ed5f4d5fb99a46ccffb86e418 SHA256 a1b82848b075adeba4fa2350bb51dde0875f62a3c8075626aa8e1a8c6d5f78d8 DIST qt-everywhere-opensource-src-4.6.0.tar.gz 155679111 RMD160 7842b9f4a5364016677fc2162dfd31f1440bb05d SHA1 c2cbbde83f1ebac3b8dd13a112fcad757d395041 SHA256 55259c813324f6383cbd441aa2f23e01c320b6d63fbe3b5d52a7715055d28589 DIST qt-x11-opensource-src-4.5.3.tar.gz 125384668 RMD160 93d765ecf89ed15668a4eedc7d77c2a2e41424a2 SHA1 78620ffd03c83c4d86f5039ccf7b09e5c709ed25 SHA256 0c87fc42825d3556970db4412257c6874e716ac3bc45e6f273924d5d6a089aa6 EBUILD qt-gui-4.5.3-r2.ebuild 5954 RMD160 7c920064963fc0ca6cc6cb6f6953c70b224ac9a1 SHA1 396265aea4631ebabaf6e917832c7513d1baf277 SHA256 1c927ed5eb92dbb54d77bfea26aaf755e3bd1a275578ec618724169ccc3bd64d +EBUILD qt-gui-4.6.0-r1.ebuild 5593 RMD160 8f170021c9d9a40cb52a101321e3bd951fcee7c2 SHA1 1b00bcbab654b592fe15ca72aa19d0021b0c09f4 SHA256 9c526852fc8dc535774e03d4dcffe602d065f515127e78f888caa379fe525d6c EBUILD qt-gui-4.6.0.ebuild 5532 RMD160 fcaac803ab2bfde31e92e4624671dc9d5cf19ae8 SHA1 3d6547d2cc955f4f88f2403a110623218d582650 SHA256 6adbf6210b785005128de31b943a5eb69f8cccc6091234330fbace3a29448c19 -MISC ChangeLog 13884 RMD160 9d4a5974f185bb5efd0335334a024767256bef35 SHA1 0f68c0156be178968e5d2a4423447a92cbbc9b9a SHA256 b1eae339ebd1484c7175e8430fec2b400699c97273cf2039ec29eed8414d3b2f +MISC ChangeLog 14096 RMD160 2472c6748030d645c5057d26cc748f40a9336e89 SHA1 f0bfca28f86a3baf2d65bc2ce0f3aae6d93462c9 SHA256 30a31a3461a22a449b63758d5fd4a6cf25da5628884f52b0ca027655dff42d23 MISC metadata.xml 529 RMD160 2513a7da89a47d04450f9b7f655972da20b38041 SHA1 8a8d0bcb3cb1e20e146eea356fa584ad59286745 SHA256 ab959731572519498303eff852a9ec570321d42ff4227c1846d5b0ba6191c74c ------BEGIN PGP SIGNATURE----- -Version: GnuPG v2.0.13 (GNU/Linux) - -iEYEARECAAYFAksVXYMACgkQjDdoMVfcAHhoKwCeNeu/rgOjArrSYMe7NiffbpJW -19IAoJeFVIUx2FfxgOPNLpPRRMu6LpMC -=npW/ ------END PGP SIGNATURE----- diff --git a/x11-libs/qt-gui/files/qt-gui-4.6.0-fix-qgraphicsscence.patch b/x11-libs/qt-gui/files/qt-gui-4.6.0-fix-qgraphicsscence.patch new file mode 100644 index 000000000000..d56412ba5d93 --- /dev/null +++ b/x11-libs/qt-gui/files/qt-gui-4.6.0-fix-qgraphicsscence.patch @@ -0,0 +1,40 @@ +From 705880f0045ac39140f980d69aec68869213e379 Mon Sep 17 00:00:00 2001 +From: Alexis Menard <alexis.menard@nokia.com> +Date: Thu, 26 Nov 2009 13:47:34 +0100 +Subject: [PATCH] Fix a crash in KDE/Plasma with QGraphicsView. TopLevel list of items + was corrupted. + +This nasty bug was triggered when the index sort the top level list of +items. We forgot to set the flag topLevelSequentialOrdering to false +so when an item was removed from the top level list it was using the +sibling index which can be not valid anymore since the list is not +sorted by sequential order. So it let some dangling pointers in the +list which make processDirtyItemRecursive crash the next paint event. + +Reviewed-by:bnilsen +Reviewed-by:andreas +--- + src/gui/graphicsview/qgraphicsscene_p.h | 3 +- + 2 files changed, 34 insertions(+), 1 deletions(-) + +diff --git a/src/gui/graphicsview/qgraphicsscene_p.h b/src/gui/graphicsview/qgraphicsscene_p.h +index a1d0496..69e4d5b 100644 +--- a/src/gui/graphicsview/qgraphicsscene_p.h ++++ b/src/gui/graphicsview/qgraphicsscene_p.h +@@ -78,7 +78,7 @@ class QGraphicsSceneIndex; + class QGraphicsView; + class QGraphicsWidget; + +-class QGraphicsScenePrivate : public QObjectPrivate ++class Q_AUTOTEST_EXPORT QGraphicsScenePrivate : public QObjectPrivate + { + Q_DECLARE_PUBLIC(QGraphicsScene) + public: +@@ -265,6 +265,7 @@ public: + { + if (needSortTopLevelItems) { + qSort(topLevelItems.begin(), topLevelItems.end(), qt_notclosestLeaf); ++ topLevelSequentialOrdering = false; + needSortTopLevelItems = false; + } + } diff --git a/x11-libs/qt-gui/qt-gui-4.6.0-r1.ebuild b/x11-libs/qt-gui/qt-gui-4.6.0-r1.ebuild new file mode 100644 index 000000000000..bbc9e852e427 --- /dev/null +++ b/x11-libs/qt-gui/qt-gui-4.6.0-r1.ebuild @@ -0,0 +1,172 @@ +# Copyright 1999-2009 Gentoo Foundation +# Distributed under the terms of the GNU General Public License v2 +# $Header: /var/cvsroot/gentoo-x86/x11-libs/qt-gui/qt-gui-4.6.0-r1.ebuild,v 1.1 2009/12/07 15:19:56 hwoarang Exp $ + +EAPI="2" +inherit eutils qt4-build + +DESCRIPTION="The GUI module for the Qt toolkit" +SLOT="4" +KEYWORDS="~alpha ~amd64 ~arm ~hppa ~ia64 ~mips ~ppc ~ppc64 ~sparc ~x86 ~x86-fbsd" +IUSE="+accessibility cups dbus +glib gtk mng nas nis raster tiff qt3support xinerama" + +RDEPEND="media-libs/fontconfig + >=media-libs/freetype-2 + media-libs/jpeg + media-libs/libpng + sys-libs/zlib + x11-libs/libX11 + x11-libs/libXext + x11-libs/libXrandr + x11-libs/libXcursor + x11-libs/libXfont + x11-libs/libSM + x11-libs/libXi + ~x11-libs/qt-core-${PV}[debug=,glib=,qt3support=] + ~x11-libs/qt-script-${PV}[debug=] + cups? ( net-print/cups ) + dbus? ( ~x11-libs/qt-dbus-${PV}[debug=] ) + gtk? ( x11-libs/gtk+:2 ) + mng? ( >=media-libs/libmng-1.0.9 ) + nas? ( >=media-libs/nas-1.5 ) + tiff? ( media-libs/tiff ) + xinerama? ( x11-libs/libXinerama ) + " +DEPEND="${RDEPEND} + xinerama? ( x11-proto/xineramaproto ) + x11-proto/xextproto + x11-proto/inputproto" +PDEPEND="qt3support? ( ~x11-libs/qt-qt3support-${PV}[debug=] )" + +QT4_TARGET_DIRECTORIES=" +src/gui +src/scripttools +tools/designer +tools/linguist/linguist +src/plugins/imageformats/gif +src/plugins/imageformats/ico +src/plugins/imageformats/jpeg +src/plugins/inputmethods" + +QT4_EXTRACT_DIRECTORIES=" +include +src +tools/linguist/phrasebooks +tools/linguist/shared +tools/shared" + +PATCHES=( + "${FILESDIR}"/${P}-fix-qgraphicsscence.patch +) + +pkg_setup() { + if ! use qt3support; then + ewarn "WARNING: if you need 'qtconfig', you _must_ enable qt3support." + ebeep 5 + fi + + if use raster; then + ewarn "WARNING: You have enabled raster backend rendering engine." + ewarn "This is a new feature and may lead to composite problems" + ewarn "screen corruption and broken qt4 or kde4 applications. " + ewarn "If you encounter such problems please" + ewarn "remove 'raster' use flag and re-compile qt-gui before" + ewarn "filling a bug on gentoo bugzilla." + ebeep 5 + fi + qt4-build_pkg_setup +} + +src_unpack() { + use dbus && QT4_TARGET_DIRECTORIES="${QT4_TARGET_DIRECTORIES} tools/qdbus/qdbusviewer" + use mng && QT4_TARGET_DIRECTORIES="${QT4_TARGET_DIRECTORIES} src/plugins/imageformats/mng" + use tiff && QT4_TARGET_DIRECTORIES="${QT4_TARGET_DIRECTORIES} src/plugins/imageformats/tiff" + use accessibility && QT4_TARGET_DIRECTORIES="${QT4_TARGET_DIRECTORIES} src/plugins/accessible/widgets" + QT4_EXTRACT_DIRECTORIES="${QT4_TARGET_DIRECTORIES} ${QT4_EXTRACT_DIRECTORIES}" + + qt4-build_src_unpack +} + +src_prepare() { + qt4-build_src_prepare + + # Don't build plugins this go around, because they depend on qt3support lib + sed -i -e "s:CONFIG(shared:# &:g" "${S}"/tools/designer/src/src.pro +} + +src_configure() { + export PATH="${S}/bin:${PATH}" + export LD_LIBRARY_PATH="${S}/lib:${LD_LIBRARY_PATH}" + + myconf="$(qt_use accessibility) + $(qt_use cups) + $(qt_use glib) + $(qt_use mng libmng system) + $(qt_use nis) + $(qt_use tiff libtiff system) + $(qt_use dbus qdbus) + $(qt_use qt3support) + $(qt_use gtk gtkstyle) + $(qt_use xinerama)" + + use nas && myconf="${myconf} -system-nas-sound" + use raster && myconf="${myconf} -graphicssystem raster" + + myconf="${myconf} -qt-gif -system-libpng -system-libjpeg + -no-sql-mysql -no-sql-psql -no-sql-ibase -no-sql-sqlite -no-sql-sqlite2 -no-sql-odbc + -xrender -xrandr -xkb -xshape -sm -no-svg" + + # Explicitly don't compile these packages. + # Emerge "qt-webkit", "qt-phonon", etc for their functionality. + myconf="${myconf} -no-webkit -no-phonon -no-dbus -no-opengl" + + qt4-build_src_configure +} + +src_install() { + QCONFIG_ADD="x11sm xshape xcursor xfixes xrandr xrender xkb fontconfig + $(usev accessibility) $(usev xinerama) $(usev cups) $(usev nas) + gif png system-png system-jpeg + $(use mng && echo system-mng) + $(use tiff && echo system-tiff)" + QCONFIG_REMOVE="no-gif no-png" + QCONFIG_DEFINE="$(use accessibility && echo QT_ACCESSIBILITY) + $(use cups && echo QT_CUPS) QT_FONTCONFIG QT_IMAGEFORMAT_JPEG + $(use mng && echo QT_IMAGEFORMAT_MNG) + $(use nas && echo QT_NAS) + $(use nis && echo QT_NIS) QT_IMAGEFORMAT_PNG QT_SESSIONMANAGER QT_SHAPE + $(use tiff && echo QT_IMAGEFORMAT_TIFF) QT_XCURSOR + $(use xinerama && echo QT_XINERAMA) QT_XFIXES QT_XKB QT_XRANDR QT_XRENDER" + + qt4-build_src_install + + # remove some unnecessary headers + rm -f "${D}${QTHEADERDIR}"/{Qt,QtGui}/{qmacstyle_mac.h,qwindowdefs_win.h} \ + "${D}${QTHEADERDIR}"/QtGui/QMacStyle + + # qt-creator + # some qt-creator headers are located + # under /usr/include/qt4/QtDesigner/private. + # those headers are just includes of the headers + # which are located under tools/designer/src/lib/* + # So instead of installing both, we create the private folder + # and drop tools/designer/src/lib/* headers in it. + dodir /usr/include/qt4/QtDesigner/private/ + insinto /usr/include/qt4/QtDesigner/private/ + doins "${S}"/tools/designer/src/lib/shared/* + doins "${S}"/tools/designer/src/lib/sdk/* + + # install correct designer and linguist icons, bug 241208 + doicon tools/linguist/linguist/images/icons/linguist-128-32.png \ + tools/designer/src/designer/images/designer.png \ + || die "doicon failed" + # Note: absolute image path required here! + make_desktop_entry /usr/bin/linguist Linguist \ + /usr/share/pixmaps/linguist-128-32.png \ + 'Qt;Development;GUIDesigner' \ + || die "linguist make_desktop_entry failed" + make_desktop_entry /usr/bin/designer Designer \ + /usr/share/pixmaps/designer.png \ + 'Qt;Development;GUIDesigner' \ + || die "designer make_desktop_entry failed" +} |