commit:     5b70d238e0d292577542e5880b7aef8db32f8d5c
Author:     Sam James <sam <AT> gentoo <DOT> org>
AuthorDate: Sat Mar 16 05:16:34 2024 +0000
Commit:     Sam James <sam <AT> gentoo <DOT> org>
CommitDate: Sat Mar 16 05:16:34 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=5b70d238

media-gfx/gimp: modern C fixes

Closes: https://bugs.gentoo.org/919282
Signed-off-by: Sam James <sam <AT> gentoo.org>

 .../gimp/files/gimp-2.10.36_c99_metadata.patch     |  27 +++
 media-gfx/gimp/files/gimp-2.10.36_c99_tiff.patch   |  27 +++
 media-gfx/gimp/gimp-2.10.36-r2.ebuild              | 217 +++++++++++++++++++++
 3 files changed, 271 insertions(+)

diff --git a/media-gfx/gimp/files/gimp-2.10.36_c99_metadata.patch 
b/media-gfx/gimp/files/gimp-2.10.36_c99_metadata.patch
new file mode 100644
index 000000000000..9ea2c80122f2
--- /dev/null
+++ b/media-gfx/gimp/files/gimp-2.10.36_c99_metadata.patch
@@ -0,0 +1,27 @@
+https://bugs.gentoo.org/919282
+https://gitlab.gnome.org/GNOME/gimp/-/commit/51311f913d9f417d121f59b83d560c7b4b853d1c
+
+From 51311f913d9f417d121f59b83d560c7b4b853d1c Mon Sep 17 00:00:00 2001
+From: Simon Budig <[email protected]>
+Date: Sat, 20 May 2023 22:25:40 +0200
+Subject: [PATCH] metadata: shut up a weird warning
+
+---
+ plug-ins/metadata/metadata-editor.c | 2 +-
+ 1 file changed, 1 insertion(+), 1 deletion(-)
+
+diff --git a/plug-ins/metadata/metadata-editor.c 
b/plug-ins/metadata/metadata-editor.c
+index a3992e40ddc..5bf6ef709f1 100644
+--- a/plug-ins/metadata/metadata-editor.c
++++ b/plug-ins/metadata/metadata-editor.c
+@@ -2846,7 +2846,7 @@ metadata_dialog_editor_set_metadata (GExiv2Metadata  
*metadata,
+                             }
+                           else
+                             {
+-                              if (! g_strv_contains (values, 
equiv_values[evi]))
++                              if (! g_strv_contains ((const gchar * const *) 
values, equiv_values[evi]))
+                                 {
+                                   gchar *tmpvalue;
+ 
+-- 
+GitLab

diff --git a/media-gfx/gimp/files/gimp-2.10.36_c99_tiff.patch 
b/media-gfx/gimp/files/gimp-2.10.36_c99_tiff.patch
new file mode 100644
index 000000000000..d08ed5182eac
--- /dev/null
+++ b/media-gfx/gimp/files/gimp-2.10.36_c99_tiff.patch
@@ -0,0 +1,27 @@
+https://bugs.gentoo.org/919282
+https://gitlab.gnome.org/GNOME/gimp/-/commit/a2458f1528e5733574bb26ff5452b1329116e6db
+
+From a2458f1528e5733574bb26ff5452b1329116e6db Mon Sep 17 00:00:00 2001
+From: Simon Budig <[email protected]>
+Date: Sat, 20 May 2023 18:40:41 +0200
+Subject: [PATCH] file-tiff-load: fix mismatching variable type
+
+---
+ plug-ins/file-tiff/file-tiff-load.c | 6 +++---
+ 1 file changed, 3 insertions(+), 3 deletions(-)
+
+diff --git a/plug-ins/file-tiff/file-tiff-load.c 
b/plug-ins/file-tiff/file-tiff-load.c
+index 0aafbaec5fd..a26e7af2752 100644
+--- a/plug-ins/file-tiff/file-tiff-load.c
++++ b/plug-ins/file-tiff/file-tiff-load.c
+@@ -1297,8 +1297,8 @@ load_image (GFile        *file,
+ 
+       /* any resolution info in the file? */
+       {
+-        gfloat   xres = 72.0;
+-        gfloat   yres = 72.0;
++        gdouble   xres = 72.0;
++        gdouble   yres = 72.0;
+         gushort  read_unit;
+         GimpUnit unit = GIMP_UNIT_PIXEL; /* invalid unit */
+ 

diff --git a/media-gfx/gimp/gimp-2.10.36-r2.ebuild 
b/media-gfx/gimp/gimp-2.10.36-r2.ebuild
new file mode 100644
index 000000000000..84edf850eedd
--- /dev/null
+++ b/media-gfx/gimp/gimp-2.10.36-r2.ebuild
@@ -0,0 +1,217 @@
+# Copyright 1999-2024 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=8
+GNOME2_EAUTORECONF=yes
+WANT_AUTOMAKE=
+
+inherit autotools gnome2 toolchain-funcs virtualx
+
+DESCRIPTION="GNU Image Manipulation Program"
+HOMEPAGE="https://www.gimp.org/";
+SRC_URI="mirror://gimp/v$(ver_cut 1-2)/${P}.tar.bz2"
+LICENSE="GPL-3+ LGPL-3+"
+SLOT="0/2"
+KEYWORDS="~alpha ~amd64 ~arm ~arm64 ~hppa ~ia64 ~loong ~ppc ~ppc64 ~riscv ~x86"
+
+IUSE="aalib alsa aqua debug doc gnome heif jpeg2k jpegxl mng openexr 
postscript udev unwind vector-icons webp wmf xpm cpu_flags_ppc_altivec 
cpu_flags_x86_mmx cpu_flags_x86_sse"
+
+RESTRICT="!test? ( test )"
+
+DEPEND="
+       >=app-accessibility/at-spi2-core-2.46.0
+       >=app-text/poppler-0.50[cairo]
+       >=app-text/poppler-data-0.4.7
+       >=dev-libs/glib-2.56.2:2
+       >=dev-libs/json-glib-1.2.6
+       dev-libs/libxml2:2
+       dev-libs/libxslt
+       >=gnome-base/librsvg-2.40.6:2
+       >=media-gfx/mypaint-brushes-2.0.2:=
+       >=media-libs/babl-0.1.98
+       >=media-libs/fontconfig-2.12.4
+       >=media-libs/freetype-2.1.7
+       >=media-libs/gegl-0.4.40:0.4[cairo]
+       >=media-libs/gexiv2-0.10.6
+       >=media-libs/harfbuzz-0.9.19:=
+       >=media-libs/lcms-2.8:2
+       media-libs/libjpeg-turbo:=
+       >=media-libs/libmypaint-1.6.1:=
+       >=media-libs/libpng-1.6.25:0=
+       >=media-libs/tiff-3.5.7:=
+       net-libs/glib-networking[ssl]
+       sys-libs/zlib
+       >=x11-libs/cairo-1.12.2
+       >=x11-libs/gdk-pixbuf-2.31:2
+       >=x11-libs/gtk+-2.24.32:2
+       x11-libs/libXcursor
+       >=x11-libs/pango-1.29.4
+       aalib? ( media-libs/aalib )
+       alsa? ( >=media-libs/alsa-lib-1.0.0 )
+       aqua? ( >=x11-libs/gtk-mac-integration-2.0.0 )
+       heif? ( >=media-libs/libheif-1.9.1:= )
+       jpeg2k? ( >=media-libs/openjpeg-2.1.0:2= )
+       jpegxl? ( >=media-libs/libjxl-0.7.0:= )
+       mng? ( media-libs/libmng:= )
+       openexr? ( >=media-libs/openexr-1.6.1:= )
+       postscript? ( app-text/ghostscript-gpl:= )
+       udev? ( dev-libs/libgudev:= )
+       unwind? ( >=sys-libs/libunwind-1.1.0:= )
+       webp? ( >=media-libs/libwebp-0.6.0:= )
+       wmf? ( >=media-libs/libwmf-0.2.8 )
+       xpm? ( x11-libs/libXpm )
+"
+
+RDEPEND="
+       ${DEPEND}
+       x11-themes/hicolor-icon-theme
+       gnome? ( gnome-base/gvfs )
+"
+
+BDEPEND="
+       >=dev-lang/perl-5.10.0
+       dev-libs/appstream-glib
+       >=dev-build/gtk-doc-am-1
+       dev-util/gtk-update-icon-cache
+       >=dev-util/intltool-0.40.1
+       >=sys-devel/gettext-0.19.8
+       >=dev-build/libtool-2.2
+       virtual/pkgconfig
+"
+
+DOCS=( "AUTHORS" "ChangeLog" "HACKING" "NEWS" "README" "README.i18n" )
+
+PATCHES=(
+       "${FILESDIR}/${PN}-2.10_fix_test-appdata.patch" # Bugs 685210 (and 
duplicate 691070)
+       "${FILESDIR}/${PN}-2.10_fix_musl_backtrace_backend_switch.patch" #900148
+       
"${FILESDIR}/${PN}-2.10_fix_configure_GCC13_implicit_function_declarations.patch"
 #899796
+       "${FILESDIR}/${P}_fix_strict-aliasing.patch" #917497
+       "${FILESDIR}/${P}_c99_tiff.patch" #919282
+       "${FILESDIR}/${P}_c99_metadata.patch" #919282
+)
+
+src_prepare() {
+       sed -i -e 's/mypaint-brushes-1.0/mypaint-brushes-2.0/' configure.ac || 
die #737794
+
+       sed -i -e 's/== "xquartz"/= "xquartz"/' configure.ac || die #494864
+       sed 's/-DGIMP_DISABLE_DEPRECATED/-DGIMP_protect_DISABLE_DEPRECATED/g' 
-i configure.ac || die #615144
+
+       gnome2_src_prepare  # calls eautoreconf
+
+       sed 's/-DGIMP_protect_DISABLE_DEPRECATED/-DGIMP_DISABLE_DEPRECATED/g' 
-i configure || die #615144
+       grep -F -q GIMP_DISABLE_DEPRECATED configure || die #615144, self-test
+
+       export CC_FOR_BUILD="$(tc-getBUILD_CC)"
+}
+
+_adjust_sandbox() {
+       # Bugs #569738 and #591214
+       local nv
+       for nv in /dev/nvidia-uvm /dev/nvidiactl /dev/nvidia{0..9} ; do
+               # We do not check for existence as they may show up later
+               # https://bugs.gentoo.org/show_bug.cgi?id=569738#c21
+               addwrite "${nv}"
+       done
+
+       addwrite /dev/dri/  # bugs #574038 and #684886
+       addwrite /dev/ati/  # bug #589198
+       addwrite /proc/mtrr  # bug #589198
+}
+
+src_configure() {
+       _adjust_sandbox
+
+       local myconf=(
+               GEGL="${EPREFIX}"/usr/bin/gegl-0.4
+               GDBUS_CODEGEN="${EPREFIX}"/bin/false
+
+               --enable-default-binary
+
+               --disable-check-update
+               --disable-python
+               --enable-mp
+               --with-appdata-test
+               --with-bug-report-url=https://bugs.gentoo.org/
+               --with-xmc
+               --without-libbacktrace
+               --without-webkit
+               --without-xvfb-run
+               $(use_enable cpu_flags_ppc_altivec altivec)
+               $(use_enable cpu_flags_x86_mmx mmx)
+               $(use_enable cpu_flags_x86_sse sse)
+               $(use_enable debug)
+               $(use_enable vector-icons)
+               $(use_with aalib aa)
+               $(use_with alsa)
+               $(use_with !aqua x)
+               $(use_with heif libheif)
+               $(use_with jpeg2k jpeg2000)
+               $(use_with jpegxl)
+               $(use_with mng libmng)
+               $(use_with openexr)
+               $(use_with postscript gs)
+               $(use_with udev gudev)
+               $(use_with unwind libunwind)
+               $(use_with webp)
+               $(use_with wmf)
+               $(use_with xpm libxpm)
+       )
+
+       gnome2_src_configure "${myconf[@]}"
+}
+
+src_compile() {
+       export XDG_DATA_DIRS="${EPREFIX}"/usr/share  # bug 587004
+       gnome2_src_compile
+}
+
+# for https://bugs.gentoo.org/664938
+_rename_plugins() {
+       einfo 'Renaming plug-ins to not collide with pre-2.10.6 file layout 
(bug #664938)...'
+       local prename=gimp-org-
+       (
+               cd "${ED}"/usr/$(get_libdir)/gimp/2.0/plug-ins || die
+               for plugin_slash in $(ls -d1 */); do
+                   plugin=${plugin_slash%/}
+                   if [[ -f ${plugin}/${plugin} ]]; then
+                       # NOTE: Folder and file name need to match for Gimp to 
load that plug-in
+                       #       so "file-svg/file-svg" becomes 
"${prename}file-svg/${prename}file-svg"
+                       mv ${plugin}/{,${prename}}${plugin} || die
+                       mv {,${prename}}${plugin} || die
+                   fi
+               done
+       )
+}
+
+src_test() {
+       virtx emake check
+}
+
+src_install() {
+       gnome2_src_install
+
+       # Workaround for bug #321111 to give GIMP the least
+       # precedence on PDF documents by default
+       mv "${ED}"/usr/share/applications/{,zzz-}gimp.desktop || die
+
+       find "${D}" -name '*.la' -type f -delete || die
+
+       # Prevent dead symlink gimp-console.1 from downstream man page 
compression (bug #433527)
+       local gimp_app_version=$(ver_cut 1-2)
+       mv "${ED}"/usr/share/man/man1/gimp-console{-${gimp_app_version},}.1 || 
die
+
+       # Remove gimp devel-docs html files if user doesn't need it
+       if ! use doc; then
+               rm -r "${ED}"/usr/share/gtk-doc || die
+       fi
+
+       _rename_plugins || die
+}
+
+pkg_postinst() {
+       gnome2_pkg_postinst
+}
+
+pkg_postrm() {
+       gnome2_pkg_postrm
+}

Reply via email to