diff options
author | Ioannis Aslanidis <deathwing00@gentoo.org> | 2006-08-22 13:09:32 +0000 |
---|---|---|
committer | Ioannis Aslanidis <deathwing00@gentoo.org> | 2006-08-22 13:09:32 +0000 |
commit | 029658834ef950fdad8b890f4e39540fe3982e19 (patch) | |
tree | 741e6fe19c7d71fdb16bbe36cf3c3ad13affc6bf /media-gfx | |
parent | Stable on SPARC. (diff) | |
download | gentoo-2-029658834ef950fdad8b890f4e39540fe3982e19.tar.gz gentoo-2-029658834ef950fdad8b890f4e39540fe3982e19.tar.bz2 gentoo-2-029658834ef950fdad8b890f4e39540fe3982e19.zip |
Memory leak fix added. Resolves bug #144433. Thanks to Peter Gantner for reporting it.
(Portage version: 2.1-r2)
Diffstat (limited to 'media-gfx')
-rw-r--r-- | media-gfx/digikam/ChangeLog | 10 | ||||
-rw-r--r-- | media-gfx/digikam/digikam-0.9.0_beta1-r1.ebuild | 95 | ||||
-rw-r--r-- | media-gfx/digikam/files/digest-digikam-0.9.0_beta1-r1 | 33 | ||||
-rw-r--r-- | media-gfx/digikam/files/digikam-0.9.0_beta1-memory-leak-fix.patch | 71 |
4 files changed, 208 insertions, 1 deletions
diff --git a/media-gfx/digikam/ChangeLog b/media-gfx/digikam/ChangeLog index c0d363ff7266..c3e23a076d0d 100644 --- a/media-gfx/digikam/ChangeLog +++ b/media-gfx/digikam/ChangeLog @@ -1,6 +1,14 @@ # ChangeLog for media-gfx/digikam # Copyright 2002-2006 Gentoo Foundation; Distributed under the GPL v2 -# $Header: /var/cvsroot/gentoo-x86/media-gfx/digikam/ChangeLog,v 1.55 2006/08/13 16:26:04 deathwing00 Exp $ +# $Header: /var/cvsroot/gentoo-x86/media-gfx/digikam/ChangeLog,v 1.56 2006/08/22 13:09:32 deathwing00 Exp $ + +*digikam-0.9.0_beta1-r1 (22 Aug 2006) + + 22 Aug 2006; Ioannis Aslanidis <deathwing00@gentoo.org> + +files/digikam-0.9.0_beta1-memory-leak-fix.patch, + +digikam-0.9.0_beta1-r1.ebuild: + Memory leak fix added. Resolves bug #144433. Thanks to Peter Gantner for + reporting it. *digikam-0.9.0_beta1 (13 Aug 2006) diff --git a/media-gfx/digikam/digikam-0.9.0_beta1-r1.ebuild b/media-gfx/digikam/digikam-0.9.0_beta1-r1.ebuild new file mode 100644 index 000000000000..4764cff97cdb --- /dev/null +++ b/media-gfx/digikam/digikam-0.9.0_beta1-r1.ebuild @@ -0,0 +1,95 @@ +# Copyright 1999-2006 Gentoo Foundation +# Distributed under the terms of the GNU General Public License v2 +# $Header: /var/cvsroot/gentoo-x86/media-gfx/digikam/digikam-0.9.0_beta1-r1.ebuild,v 1.1 2006/08/22 13:09:32 deathwing00 Exp $ + +inherit kde + +P_DOC="${PN}-doc-0.8.0" +MY_P="${P/_/-}" +S="${WORKDIR}/${MY_P}" +S_DOC="${WORKDIR}/${P_DOC}" + +DESCRIPTION="A digital photo management application for KDE." +HOMEPAGE="http://www.digikam.org/" + +SLOT="0" +LICENSE="GPL-2" +KEYWORDS="~amd64 ~ppc ~sparc ~x86" +IUSE="nfs doc kdehiddenvisibility exif" + +DEPEND=">=media-libs/libgphoto2-2 + >=dev-db/sqlite-3 + >=media-libs/libkipi-0.1.1 + media-libs/tiff + sys-libs/gdbm + media-gfx/dcraw + media-gfx/exiv2 + media-libs/lcms" +RDEPEND="${DEPEND} + || ( ( kde-base/kgamma kde-base/kamera ) kde-base/kdegraphics )" + +need-kde 3.4 + +LANGS="bg bn br ca cs cy da de el en_GB es et eu fi fr ga gl he hu is it ja km +lt mk ms mt nb nl nn pa pl pt pt_BR ro ru rw sl sr sr@Latn sv ta tr uk vi zh_CN" +LANGS_DOC="da es et it nl pt_BR pt sv" + +DOC_URI="mirror://sourceforge/digikam/${P_DOC}.tar.bz2" +SRC_URI="${DOC_URI}" + +for lang in ${LANGS}; do + IUSE="${IUSE} linguas_${lang}" + [[ " ${LANGS_DOC} " != *" ${lang} "* ]] && SRC_URI="!linguas_${lang}? ( ${SRC_URI} )" +done + +for lang in ${LANGS_DOC}; do + IUSE="${IUSE} linguas_${lang}" + SRC_URI="linguas_${lang}? ( + mirror://gentoo/${P_DOC}-${lang}.tar.bz2 + mirror://gentoo/${P_DOC}-gentoo.tar.bz2 + ) + !linguas_${lang}? ( ${SRC_URI} )" +done + +SRC_URI="mirror://sourceforge/digikam/${MY_P}.tar.bz2 + doc? ( linguas_en? ( mirror://gentoo/${P_DOC}-gentoo.tar.bz2 ) + !linguas_en? ( ${SRC_URI} ) )" + +pkg_setup(){ + slot_rebuild "media-libs/libkipi media-libs/libkexif" && die + kde_pkg_setup +} + +src_unpack(){ + kde_src_unpack + rm -f "${S}/configure" "${S_DOC}/configure" + + local MAKE_PO=$(echo "${LINGUAS} ${LANGS}" | fmt -w 1 | sort | uniq -d | tr '\n' ' ') + einfo "Enabling translations for: en ${MAKE_PO}" + sed -i -e "s:^SUBDIRS =.*:SUBDIRS = . ${MAKE_PO}:" "${S}/po/Makefile.am" || die "sed for locale failed" + + if use doc; then + local MAKE_DOC=$(echo "${LINGUAS} ${LANGS_DOC}" | fmt -w 1 | sort | uniq -d | tr '\n' ' ') + einfo "Enabling documentation for: en ${LANG_DOCS}" + fi + epatch ${FILESDIR}/${P}-memory-leak-fix.patch +} + +src_compile(){ + local myconf + + myconf="$(use_enable nfs nfs-hack)" + kde_src_compile + myconf="" + [[ -d "${S_DOC}" ]] && KDE_S="${S_DOC}" kde_src_compile +} + +src_install(){ + kde_src_install + [[ -d "${S_DOC}" ]] && KDE_S="${S_DOC}" kde_src_install + + # Install the .desktop in FDO's suggested directory + dodir /usr/share/applications/kde + mv "${D}/usr/share/applnk/Graphics/digikam.desktop" \ + "${D}/usr/share/applications/kde" +} diff --git a/media-gfx/digikam/files/digest-digikam-0.9.0_beta1-r1 b/media-gfx/digikam/files/digest-digikam-0.9.0_beta1-r1 new file mode 100644 index 000000000000..58c58c3de95f --- /dev/null +++ b/media-gfx/digikam/files/digest-digikam-0.9.0_beta1-r1 @@ -0,0 +1,33 @@ +MD5 fc3a26a91fd6f715ffb75efe8be06e4e digikam-0.9.0-beta1.tar.bz2 6524485 +RMD160 4328f23262ab70e7260e4bf20eb02dc08d9c5517 digikam-0.9.0-beta1.tar.bz2 6524485 +SHA256 f50b7784d15106fe605b0244ecffac099b50a9106eb552709f85491aeb722e42 digikam-0.9.0-beta1.tar.bz2 6524485 +MD5 a18e5e9a4fd17994da5089ddcd9bc0c1 digikam-doc-0.8.0-da.tar.bz2 50493 +RMD160 50fe4b8deb3c5edb759c3844cf3f52c7f2bcaade digikam-doc-0.8.0-da.tar.bz2 50493 +SHA256 9a0c5a0c8d5e86b5836aba3adb22fbfe50b968b7bd19320c967443fbe1860182 digikam-doc-0.8.0-da.tar.bz2 50493 +MD5 06bcc36d7a4dc42c42978f7d1059c2f3 digikam-doc-0.8.0-es.tar.bz2 10816588 +RMD160 d031a6d0601b2a5a98a7d11762bc32a210b80b82 digikam-doc-0.8.0-es.tar.bz2 10816588 +SHA256 de17de6816895db79b56aaeb2106286ad351e51b1acf124eeaf29e3baeb055a0 digikam-doc-0.8.0-es.tar.bz2 10816588 +MD5 6d2c381f78ea883c4bbc925756012b98 digikam-doc-0.8.0-et.tar.bz2 41384 +RMD160 d7d57533d8cdf7d4919c4107e7baa6c2f77b03c9 digikam-doc-0.8.0-et.tar.bz2 41384 +SHA256 ba02a828fbbeb1243e97195b5a333d12b1b4f88456082b6e615709bd07f20b83 digikam-doc-0.8.0-et.tar.bz2 41384 +MD5 7fa628fe68a39efa27fc73aa7430ea90 digikam-doc-0.8.0-gentoo.tar.bz2 19396732 +RMD160 22ac0d7fa874dc853ab3957a145c54d9737a3d2e digikam-doc-0.8.0-gentoo.tar.bz2 19396732 +SHA256 c0f7448e02378f2ef559b9b0e887327422d849c9ba607a254448dcc00eb3699c digikam-doc-0.8.0-gentoo.tar.bz2 19396732 +MD5 a4d535948f5d738e3030beae99bcc674 digikam-doc-0.8.0-it.tar.bz2 702416 +RMD160 bc89f465e073eb64944ef2a9914bb2291878b365 digikam-doc-0.8.0-it.tar.bz2 702416 +SHA256 07fa5ef11f9544b4f3a2b0be8759ea1d7041d56f9188a15101bb53aae8dca3f3 digikam-doc-0.8.0-it.tar.bz2 702416 +MD5 2c1061c24bbf8482d814b1e1ab8c1c89 digikam-doc-0.8.0-nl.tar.bz2 9764577 +RMD160 30968073fedb980b821f332044194b63873c8785 digikam-doc-0.8.0-nl.tar.bz2 9764577 +SHA256 f8d7d934bc25270686b81183dd1dfd3c43d6f479e9961c3d8218f2ae114b7c15 digikam-doc-0.8.0-nl.tar.bz2 9764577 +MD5 9b71a31b61c5679e699365d21b31d1f5 digikam-doc-0.8.0-pt.tar.bz2 52611 +RMD160 5f5e400f79dcfb5f527afe8cc31de261bd05f421 digikam-doc-0.8.0-pt.tar.bz2 52611 +SHA256 727a21963504cd2b1e3b67bfa7fb872b5f9d45d32f770861b51eceaeff763431 digikam-doc-0.8.0-pt.tar.bz2 52611 +MD5 29d2ae35f8aac6109fd98fb630fcbb4f digikam-doc-0.8.0-pt_BR.tar.bz2 1988378 +RMD160 ddcd056964e48b294e6bfb8a5c1e8f1c7390d0c4 digikam-doc-0.8.0-pt_BR.tar.bz2 1988378 +SHA256 82a036d609ad4bfc2f74d9ec291dd463641d4456b2493f03b15cb16337273391 digikam-doc-0.8.0-pt_BR.tar.bz2 1988378 +MD5 7c76dca73e22ca1457387d740f819b83 digikam-doc-0.8.0-sv.tar.bz2 261061 +RMD160 e682527412ebd4732e5010c6bbbd4619159dd0f3 digikam-doc-0.8.0-sv.tar.bz2 261061 +SHA256 bbbc383c04fb16df562126d4d0523364753d26fbf95291922792e03477c378d0 digikam-doc-0.8.0-sv.tar.bz2 261061 +MD5 b958495f3830949bc9c2cd6fd1cd53e6 digikam-doc-0.8.0.tar.bz2 43156836 +RMD160 94d6abb1e58ba8ed91b11a86608d5dce8c9ba3a2 digikam-doc-0.8.0.tar.bz2 43156836 +SHA256 9aa84a94187e0f40939373b264de7ce73e73be44b976f8b890538a68aa1f3f22 digikam-doc-0.8.0.tar.bz2 43156836 diff --git a/media-gfx/digikam/files/digikam-0.9.0_beta1-memory-leak-fix.patch b/media-gfx/digikam/files/digikam-0.9.0_beta1-memory-leak-fix.patch new file mode 100644 index 000000000000..450721daf61c --- /dev/null +++ b/media-gfx/digikam/files/digikam-0.9.0_beta1-memory-leak-fix.patch @@ -0,0 +1,71 @@ +--- trunk/extragear/graphics/digikam/digikam/imagepreviewjob.cpp #567459:567460 +@@ -173,6 +173,12 @@ + stream >> width >> height >> depth; + preview = QImage(d->shmaddr, width, height, depth, + 0, 0, QImage::IgnoreEndian); ++ ++ // The buffer supplied to the QImage constructor above must remain valid ++ // throughout the lifetime of the object. ++ // This is not true, the shared memory will be freed or reused. ++ // If we pass the object around, we must do a deep copy. ++ preview = preview.copy(); + } + else + { +--- trunk/extragear/graphics/digikam/digikam/imagepreviewwidget.cpp #567459:567460 +@@ -91,11 +91,11 @@ + + ImagePreviewWidget::~ImagePreviewWidget() + { +- if (!d->previewJob.isNull()) ++ if (d->previewJob) + d->previewJob->kill(); +- ++ + d->blinkPreviewTimer->stop(); +- ++ + delete d; + } + +@@ -107,6 +107,9 @@ + d->previewBlink = false; + d->blinkPreviewTimer->start(200); + ++ if (d->previewJob) ++ d->previewJob->kill(); ++ + d->previewJob = new ImagePreviewJob(KURL(path), 1024, AlbumSettings::instance()->getExifRotate()); + + connect(d->previewJob, SIGNAL(signalImagePreview(const KURL&, const QImage&)), +@@ -129,9 +132,16 @@ + void ImagePreviewWidget::slotGotImagePreview(const KURL&, const QImage& preview) + { + d->blinkPreviewTimer->stop(); +- d->previewJob = 0; + d->preview = preview; + d->pixmap = QPixmap(contentsRect().size()); ++ ++ // It is very important to kill the thumbnail job properly ++ // so that is frees its shared memory. Otherwise the memory ++ // will _never_ be freed, see b.k.o. #131277 ++ if (d->previewJob) ++ d->previewJob->kill(); ++ d->previewJob = 0; ++ + updatePixmap(); + repaint(false); + emit previewComplete(); +@@ -140,7 +150,11 @@ + void ImagePreviewWidget::slotFailedImagePreview(const KURL&) + { + d->blinkPreviewTimer->stop(); +- d->previewJob = 0; ++ ++ if (d->previewJob) ++ d->previewJob->kill(); ++ d->previewJob = 0; ++ + d->preview = QImage(); + d->pixmap = QPixmap(contentsRect().size()); + updatePixmap(); |