commit:     01647baea4dca5b7c53519672abae1160e596d3f
Author:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
AuthorDate: Mon May 30 20:13:20 2022 +0000
Commit:     Ionen Wolkens <ionen <AT> gentoo <DOT> org>
CommitDate: Mon May 30 20:25:45 2022 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=01647bae

media-libs/freeimage: fix revdeps when using >=tiff-4.4.0

Closes: https://bugs.gentoo.org/848531
Closes: https://bugs.gentoo.org/848534
Signed-off-by: Ionen Wolkens <ionen <AT> gentoo.org>

 .../files/freeimage-3.18.0-tiff-4.4.0.patch        |  12 ++
 media-libs/freeimage/freeimage-3.18.0-r8.ebuild    | 125 +++++++++++++++++++++
 2 files changed, 137 insertions(+)

diff --git a/media-libs/freeimage/files/freeimage-3.18.0-tiff-4.4.0.patch 
b/media-libs/freeimage/files/freeimage-3.18.0-tiff-4.4.0.patch
new file mode 100644
index 000000000000..a0c39064aa34
--- /dev/null
+++ b/media-libs/freeimage/files/freeimage-3.18.0-tiff-4.4.0.patch
@@ -0,0 +1,12 @@
+https://bugs.gentoo.org/848531
+https://bugs.gentoo.org/848534
+https://www.asmail.be/msg0055228425.html
+--- a/Source/Metadata/XTIFF.cpp
++++ b/Source/Metadata/XTIFF.cpp
+@@ -750,5 +750,5 @@
+                       }
+                       // type of storage may differ (e.g. rationnal array vs 
float array type)
+-                      if((unsigned)_TIFFDataSize(tif_tag_type) != 
FreeImage_TagDataWidth(tag_type)) {
++                      if((unsigned)TIFFFieldSetGetSize(fld) != 
FreeImage_TagDataWidth(tag_type)) {
+                               // skip tag or _TIFFmemcpy will fail
+                               continue;

diff --git a/media-libs/freeimage/freeimage-3.18.0-r8.ebuild 
b/media-libs/freeimage/freeimage-3.18.0-r8.ebuild
new file mode 100644
index 000000000000..aef7915a1072
--- /dev/null
+++ b/media-libs/freeimage/freeimage-3.18.0-r8.ebuild
@@ -0,0 +1,125 @@
+# Copyright 1999-2022 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=8
+
+inherit edos2unix toolchain-funcs
+
+MY_PN=FreeImage
+MY_PV=${PV//.}
+MY_P=${MY_PN}${MY_PV}
+
+DESCRIPTION="Image library supporting many formats"
+HOMEPAGE="https://freeimage.sourceforge.io/";
+SRC_URI="mirror://sourceforge/${PN}/${MY_P}.zip
+       mirror://sourceforge/${PN}/${MY_P}.pdf
+       
https://dev.gentoo.org/~juippis/distfiles/tmp/freeimage-3.18.0-unbundling.patch";
+
+LICENSE="|| ( GPL-2 FIPL-1.0 )"
+SLOT="0"
+KEYWORDS="~amd64 ~arm ~arm64 ~riscv ~x86 ~amd64-linux ~x86-linux"
+IUSE="jpeg jpeg2k mng openexr png raw static-libs tiff webp"
+
+# The tiff/imath+openexr isn't a typo. The TIFF plugin cheats and
+# uses code from it to handle 16bit<->float conversions.
+RDEPEND="
+       sys-libs/zlib
+       jpeg? ( media-libs/libjpeg-turbo:= )
+       jpeg2k? ( media-libs/openjpeg:2= )
+       mng? ( media-libs/libmng:= )
+       openexr? ( media-libs/openexr:= )
+       png? ( media-libs/libpng:0= )
+       raw? ( media-libs/libraw:= )
+       tiff? (
+               >=dev-libs/imath-3.1.4-r2:=
+               >=media-libs/openexr-3:0=
+               >=media-libs/tiff-4.4.0
+       )
+       webp? ( media-libs/libwebp:= )"
+DEPEND="${RDEPEND}"
+BDEPEND="
+       app-arch/unzip
+       virtual/pkgconfig"
+
+S=${WORKDIR}/${MY_PN}
+
+DOCS=( "${DISTDIR}"/${MY_P}.pdf README.linux Whatsnew.txt )
+
+PATCHES=(
+       "${DISTDIR}"/${PN}-3.18.0-unbundling.patch
+       "${FILESDIR}"/${PN}-3.18.0-remove-jpeg-transform.patch
+       "${FILESDIR}"/${PN}-3.18.0-rename-jpeg_read_icc_profile.patch
+       "${FILESDIR}"/${PN}-3.18.0-disable-plugin-G3.patch
+       "${FILESDIR}"/${PN}-3.18.0-raw.patch
+       "${FILESDIR}"/${PN}-3.18.0-libjpeg9.patch
+       "${FILESDIR}"/${PN}-3.18.0-CVE-2019-12211-CVE-2019-12213.patch
+       "${FILESDIR}"/${PN}-3.18.0-openexr-3-imath.patch
+       "${FILESDIR}"/${PN}-3.18.0-libraw-0.20.0.patch
+       "${FILESDIR}"/${PN}-3.18.0-tiff-4.4.0.patch
+)
+
+src_prepare() {
+       pushd Source >/dev/null || die
+       cp LibJPEG/{transupp.c,transupp.h,jinclude.h} . || die
+       cp LibTIFF4/{tiffiop,tif_dir}.h . || die
+       rm -rf LibPNG LibMNG LibOpenJPEG ZLib OpenEXR LibRawLite LibTIFF4 
LibJPEG LibWebP LibJXR || die
+       popd >/dev/null || die
+
+       edos2unix Makefile.{gnu,fip,srcs} fipMakefile.srcs */*.h */*/*.cpp
+       sed -i \
+               -e "s:/./:/:g" \
+               -e "s: ./: :g" \
+               -e 's: Source: \\\n\tSource:g' \
+               -e 's: Wrapper: \\\n\tWrapper:g' \
+               -e 's: Examples: \\\n\tExamples:g' \
+               -e 's: TestAPI: \\\n\tTestAPI:g' \
+               -e 's: -ISource: \\\n\t-ISource:g' \
+               -e 's: -IWrapper: \\\n\t-IWrapper:g' \
+               -e 's:INCLS:\nINCLS:g' \
+               Makefile.srcs fipMakefile.srcs || die
+       sed -i \
+               -e "/LibJPEG/d" \
+               -e "/LibJXR/d" \
+               -e "/LibPNG/d" \
+               -e "/LibTIFF/d" \
+               -e "/Source\/ZLib/d" \
+               -e "/LibOpenJPEG/d" \
+               -e "/OpenEXR/d" \
+               -e "/LibRawLite/d" \
+               -e "/LibMNG/d" \
+               -e "/LibWebP/d" \
+               -e "/LibJXR/d" \
+               Makefile.srcs fipMakefile.srcs || die
+
+       default
+}
+
+foreach_make() {
+       local m
+       for m in Makefile.{gnu,fip} ; do
+               emake -f ${m} \
+                       USE_EXR=$(usex openexr) \
+                       USE_JPEG=$(usex jpeg) \
+                       USE_JPEG2K=$(usex jpeg2k) \
+                       USE_MNG=$(usex mng) \
+                       USE_PNG=$(usex png) \
+                       USE_TIFF=$(usex tiff) \
+                       USE_RAW=$(usex raw) \
+                       USE_WEBP=$(usex webp) \
+                       $(usex static-libs '' STATICLIB=) \
+                       "$@"
+       done
+}
+
+src_compile() {
+       tc-export AR PKG_CONFIG
+       foreach_make \
+               CXX="$(tc-getCXX) -fPIC" \
+               CC="$(tc-getCC) -fPIC" \
+               ${MY_PN}
+}
+
+src_install() {
+       foreach_make install DESTDIR="${ED}" 
INSTALLDIR="${ED}"/usr/$(get_libdir)
+       einstalldocs
+}

Reply via email to