commit:     494067c8bdfc4b0a573f42c944ca5b116c1f32e2
Author:     Viorel Munteanu <ceamac <AT> gentoo <DOT> org>
AuthorDate: Thu Dec 26 09:33:48 2024 +0000
Commit:     Viorel Munteanu <ceamac <AT> gentoo <DOT> org>
CommitDate: Thu Dec 26 09:49:41 2024 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=494067c8

media-libs/netpbm: add 11.9.0

Signed-off-by: Viorel Munteanu <ceamac <AT> gentoo.org>

 media-libs/netpbm/Manifest                        |   1 +
 media-libs/netpbm/files/netpbm-11.9.0-build.patch |  65 ++++++
 media-libs/netpbm/netpbm-11.9.0.ebuild            | 260 ++++++++++++++++++++++
 3 files changed, 326 insertions(+)

diff --git a/media-libs/netpbm/Manifest b/media-libs/netpbm/Manifest
index cff369e31cdb..bda9d0a868e8 100644
--- a/media-libs/netpbm/Manifest
+++ b/media-libs/netpbm/Manifest
@@ -1,3 +1,4 @@
 DIST netpbm-11.2.11.tar.xz 3782252 BLAKE2B 
422b9cefee2a54a9c222236935291f0c8d1f13f064f4ebd277d0f92974b9ce3d7e3d9ae6a0410d767553704a03c2de14ca8456996a53fca0f95d61f9ae72605f
 SHA512 
3d94c0c8c25873a16c78af960c964f5756b3e7a29463f001345956acc3bf1378b0b0b4fc0c57d7388dced0979ba4e8cee0def2200092544dd96fc7d04304660b
 DIST netpbm-11.2.12.tar.xz 3782188 BLAKE2B 
c8adb0ba54a982848a2ee0bafeacbdf4bf34dcd3ebaf6ec8473ab9c1edbe49299e1904fbea46d17fefafa0ec32a00fe79a8ab2793e6633a3f37c5db99477174a
 SHA512 
a277aa0b70f994b9c18b7c1f2f64610d3e154e47871a82f06062ab6d1bb6b049c8d1b1c56fb9cf5d43e5b865dfea281f1caf95d40dfbbdcbc3e0134678a3b32c
 DIST netpbm-11.8.2.tar.xz 3804800 BLAKE2B 
9b5bb460c2fbe73495cbb304ea0e1a2a4406838cbb4d0769d2b8147f9ee6156d93852ad36a5ea57a7437b9a1a3cc9f102271163bc4d6bbd004c42c7f81be2318
 SHA512 
b048b242891cbe56851b3da342de1717e1ab435a327b4eeebb83023e2e7ae57ae66a232df344b4d2b0fb12bc6abcf13d9cec392f19ff06951023ee4c002f9f17
+DIST netpbm-11.9.0.tar.xz 3806004 BLAKE2B 
bc00128a712845870ca0cdb15ac954efeb43fbc148d16019a272a45f2a6d8e27440954e8877c5dc5da00fe76ca842014c71a8f494788abf882bced2908554251
 SHA512 
243b7a0a35e30eafc219c78a9a81425d71a6c61ee2cf9ef519d8c3f113e2c98f24e01b3dfe978602d1fdeb7c152f6cddd68e8073d6efbb0ae9f8c0f3ddcbdcfa

diff --git a/media-libs/netpbm/files/netpbm-11.9.0-build.patch 
b/media-libs/netpbm/files/netpbm-11.9.0-build.patch
new file mode 100644
index 000000000000..3cab574345d0
--- /dev/null
+++ b/media-libs/netpbm/files/netpbm-11.9.0-build.patch
@@ -0,0 +1,65 @@
+diff --git a/GNUmakefile b/GNUmakefile
+index 9d02c6b..d8f3ca2 100644
+--- a/GNUmakefile
++++ b/GNUmakefile
+@@ -122,6 +122,9 @@ all: nonmerge
+ .PHONY: nonmerge
+ nonmerge: $(PRODUCT_SUBDIRS:%=%/all)
+ 
++$(PRODUCT_SUBDIRS:%=%/all): buildtools/all
++converter/all analyzer/all editor/all generator/all other/all: lib/all
++
+ # Completely parallel make (make --jobs) does not work because there are
+ # multiple targets somewhere in the Netpbm build that depend upon pm_config.h
+ # and similar targets, and the threads building those multiple targets might
+diff --git a/lib/Makefile b/lib/Makefile
+index b8b95fa..02b4df1 100644
+--- a/lib/Makefile
++++ b/lib/Makefile
+@@ -249,7 +249,7 @@ libpm.o: compile.h
+ .PHONY: install.lib
+ ifeq ($(NETPBMLIBTYPE),unixshared)
+ # install a Unix-style shared library
+-install.lib: $(PKGDIR)/lib $(PKGDIR)/sharedlink
++install.lib: $(PKGDIR)/lib
+       cd $(PKGDIR)/lib ; rm -f libnetpbm.$(NETPBMLIBSUFFIX).$(MAJ).*
+       $(INSTALL) -c -m $(INSTALL_PERM_LIBD) \
+         libnetpbm.$(NETPBMLIBSUFFIX).$(MAJ).$(MIN)  $(PKGDIR)/lib/
+@@ -291,29 +291,29 @@ $(INTERFACE_HEADERS:%=%_installhdr): 
$(PKGDIR)/include/netpbm
+         $(SRCDIR)/lib/$(@:%_installhdr=%) $(PKGDIR)/include/netpbm/
+ 
+ .PHONY: install.staticlib
+-install.staticlib: $(PKGDIR)/staticlink
++install.staticlib: $(PKGDIR)/lib
+       $(INSTALL) -c -m $(INSTALL_PERM_LIBS) libnetpbm.$(STATICLIBSUFFIX) \
+-        $(PKGDIR)/staticlink
++        $(PKGDIR)/lib
+ 
+ # Install a shared library stub -- the ".so" file used at link time to
+ # prepare a program for dynamically linking a library at run time 
+ .PHONY: install.sharedlibstub
+-install.sharedlibstub: $(PKGDIR)/sharedlink
++install.sharedlibstub: $(PKGDIR)/lib
+ ifeq ($(NETPBMLIBTYPE),unixshared)
+ # install the link-time (.so) links to the runtime libraries
+-      cd $(PKGDIR)/sharedlink ; \
++      cd $(PKGDIR)/lib ; \
+           rm -f libnetpbm.$(NETPBMLIBSUFFIX); \
+-          $(SYMLINK) ../lib/libnetpbm.$(NETPBMLIBSUFFIX).$(MAJ) \
++          $(SYMLINK) libnetpbm.$(NETPBMLIBSUFFIX).$(MAJ) \
+             libnetpbm.$(NETPBMLIBSUFFIX)
+ endif
+ ifeq ($(NETPBMLIBTYPE),dll)
+       $(INSTALL) -c -m $(INSTALL_PERM_LIBS) libnetpbm.dll.a \
+-        $(PKGDIR)/sharedlink
++        $(PKGDIR)/lib
+ endif
+ ifeq ($(NETPBMLIBTYPE),dylib)
+-      cd $(PKGDIR)/sharedlink/ ; \
++      cd $(PKGDIR)/lib/ ; \
+           rm -f libnetpbm.dylib; \
+-      $(SYMLINK) ../lib/libnetpbm.$(MAJ).$(MIN).dylib libnetpbm.dylib
++      $(SYMLINK) libnetpbm.$(MAJ).$(MIN).dylib libnetpbm.dylib
+ endif
+ 
+ distclean clean: localclean

diff --git a/media-libs/netpbm/netpbm-11.9.0.ebuild 
b/media-libs/netpbm/netpbm-11.9.0.ebuild
new file mode 100644
index 000000000000..73b34891de7f
--- /dev/null
+++ b/media-libs/netpbm/netpbm-11.9.0.ebuild
@@ -0,0 +1,260 @@
+# Copyright 1999-2024 Gentoo Authors
+# Distributed under the terms of the GNU General Public License v2
+
+EAPI=8
+
+inherit flag-o-matic multilib toolchain-funcs
+
+# Upstream has 3 flavors of netpbm: super stable, stable and advanced.
+# They only provide a tarball for super stable, but super stable is a bit 
lagging.
+# So we package the stable branch of their svn (currently versions 11.2.xx) on 
SLOT "0/stable"
+# and the advanced branch of their svn (currently versions 11.8.yy) on SLOT 
"0/advanced".
+# The stable branch is stabilized according to usual Gentoo rules, while the
+# advanced branch will not be stabilized.
+# A detailed explanation is here https://netpbm.sourceforge.net/release.html
+
+DESCRIPTION="A set of utilities for converting to/from the netpbm (and 
related) formats"
+HOMEPAGE="https://netpbm.sourceforge.net/";
+SRC_URI="https://dev.gentoo.org/~ceamac/${CATEGORY}/${PN}/${P}.tar.xz";
+
+LICENSE="Artistic BSD GPL-2 IJG LGPL-2.1 MIT public-domain"
+SLOT="0/advanced"
+KEYWORDS="~alpha ~amd64 ~arm ~arm64 ~hppa ~loong ~m68k ~mips ~ppc ~ppc64 
~riscv ~s390 ~sparc ~x86 ~amd64-linux ~x86-linux"
+IUSE="jbig jpeg png postscript rle cpu_flags_x86_sse2 static-libs svga tiff X 
xml"
+
+# app-text/ghostscript-gpl is really needed for postscript
+# some utilities execute /usr/bin/gs
+# some installed programs are perl scripts
+RDEPEND="
+       dev-lang/perl
+       jbig? ( media-libs/jbigkit:= )
+       jpeg? ( media-libs/libjpeg-turbo:=[static-libs?] )
+       png? (
+               >=media-libs/libpng-1.4:0=
+               sys-libs/zlib
+       )
+       postscript? (
+               app-text/ghostscript-gpl
+               sys-libs/zlib
+       )
+       rle? ( media-libs/urt:= )
+       svga? ( media-libs/svgalib )
+       tiff? ( >=media-libs/tiff-3.5.5:= )
+       xml? ( dev-libs/libxml2 )
+       X? ( x11-libs/libX11 )
+"
+DEPEND="
+       ${RDEPEND}
+       x11-base/xorg-proto
+"
+BDEPEND="
+       app-arch/xz-utils
+       app-alternatives/lex
+       virtual/pkgconfig
+"
+
+PATCHES=(
+       "${FILESDIR}"/netpbm-11.9.0-build.patch
+       "${FILESDIR}"/netpbm-11.0.0-misc-deps.patch
+       "${FILESDIR}"/netpbm-11.1.0-fix-clang-O2.patch
+       "${FILESDIR}"/netpbm-11.6.1-incompatible-pointer-types.patch
+)
+
+netpbm_libtype() {
+       case ${CHOST} in
+               *-darwin*) echo dylib;;
+               *)         echo unixshared;;
+       esac
+}
+
+netpbm_libsuffix() {
+       local suffix=$(get_libname)
+       echo ${suffix//\.}
+}
+
+netpbm_ldshlib() {
+       case ${CHOST} in
+               *-darwin*) echo '$(LDFLAGS) -dynamiclib -install_name 
$(SONAME)';;
+               *)         echo '$(LDFLAGS) -shared -Wl,-soname,$(SONAME)';;
+       esac
+}
+
+netpbm_config_lib() {
+       usex ${1} -l${2:-$1} NONE
+}
+
+# for bug #828127
+netpbm_cflags_for_build() {
+       if is-flagq -fPIC; then
+               echo -fPIC
+       fi
+}
+
+src_prepare() {
+       default
+
+       # make sure we use system libs
+       sed '/SUPPORT_SUBDIRS/s:urt::' -i GNUmakefile || die
+       rm -r urt converter/other/jbig/libjbig 
converter/other/jpeg2000/libjasper || die
+
+       # take care of the importinc stuff ourselves by only doing it once
+       # at the top level and having all subdirs use that one set #149843
+       sed \
+               -e '/^importinc:/s|^|importinc:\nmanual_|' \
+               -e '/-Iimportinc/s|-Iimp|-I"$(BUILDDIR)"/imp|g'\
+               -i common.mk || die
+       sed \
+               -e '/%.c/s: importinc$::' \
+               -i common.mk lib/Makefile lib/util/Makefile || die
+       sed \
+               -e 's:pkg-config:$(PKG_CONFIG):' \
+               -i GNUmakefile converter/other/Makefile other/pamx/Makefile || 
die
+
+       # The postscript knob is currently bound up with a fork test.
+       if ! use postscript ; then
+               sed \
+                       -e 's:$(DONT_HAVE_PROCESS_MGMT):Y:' \
+                       -i converter/other/Makefile generator/Makefile || die
+               sed -r \
+                       -e 's:(pbmtextps|pnmtops|pstopnm).*::' \
+                       -i test/all-in-place.{ok,test} || die
+               sed \
+                       -e 's:lps-roundtrip.*::' \
+                       -e 's:pbmtextps-dump.*::' \
+                       -e 's:pbmtextps.*::' \
+                       -i test/Test-Order || die
+               sed \
+                       -e '/^$/d' \
+                       -i test/all-in-place.ok || die
+               sed \
+                       '2iexit 80' \
+                       -i test/ps-{alt-,flate-,}roundtrip.test || die
+       fi
+
+       # Do not test png if not built
+       if ! use png ; then
+               sed -E \
+                       -e 's:(pamtopng|pngtopam|pnmtopng).*::' \
+                       -i test/all-in-place.{ok,test} || die
+               sed \
+                       -e '/^$/d' \
+                       -i test/all-in-place.ok || die
+
+               sed -E \
+                       -e 's:(pamrgbatopng|pngtopnm).*::' \
+                       -i test/legacy-names.{ok,test} || die
+               sed \
+                       -e '/^$/d' \
+                       -i test/legacy-names.ok || die
+               sed \
+                       -e 's:png-roundtrip.*::' \
+                       -e 's:winicon-roundtrip.*::' \
+                       -i test/Test-Order || die
+       fi
+
+       # pbmtext-iso88591 requires LC_ALL=en_US.iso88591, not available on musl
+       # pbmtext-utf8 requires locale, not available on musl
+       # ppmpat-random and pnmindex are broken on musl
+       # bug #907295
+       if use elibc_musl; then
+               sed \
+                       -e 's:pbmtext-iso88591.*::' \
+                       -e 's:pbmtext-utf8.*::' \
+                       -e 's:ppmpat-random.*::' \
+                       -e 's:pnmindex.*::' \
+                       -i test/Test-Order || die
+       fi
+
+       # broken in 11.9.0, upstream informed.  Skip it for now.
+       sed -e 's:pammixmulti-identity.*::' -i test/Test-Order
+}
+
+src_configure() {
+       cat config.mk.in - >> config.mk <<-EOF || die "writing config.mk failed"
+               # Misc stuff
+               BUILD_FIASCO = N
+               SYMLINK = ln -sf
+
+               # These vars let src_test work by default
+               PKGDIR_DEFAULT = ${T}/netpbm
+               RESULTDIR_DEFAULT = ${T}/netpbm-test
+
+               # Toolchain options
+               CC = $(tc-getCC) -Wall
+               LD = \$(CC)
+               CC_FOR_BUILD = $(tc-getBUILD_CC)
+               LD_FOR_BUILD = \$(CC_FOR_BUILD)
+               AR = $(tc-getAR)
+               RANLIB = $(tc-getRANLIB)
+               PKG_CONFIG = $(tc-getPKG_CONFIG)
+
+               STRIPFLAG =
+               CFLAGS_SHLIB = -fPIC
+               CFLAGS_FOR_BUILD += $(netpbm_cflags_for_build)
+
+               LDRELOC = \$(LD) -r
+               LDSHLIB = $(netpbm_ldshlib)
+               LINKER_CAN_DO_EXPLICIT_LIBRARY = N # we can, but dont want to
+               LINKERISCOMPILER = Y
+               NETPBMLIBSUFFIX = $(netpbm_libsuffix)
+               NETPBMLIBTYPE = $(netpbm_libtype)
+               STATICLIB_TOO = $(usex static-libs Y N)
+
+               # The var is called SSE, but the code is actually SSE2.
+               WANT_SSE = $(usex cpu_flags_x86_sse2 Y N)
+
+               # Gentoo build options
+               TIFFLIB = $(netpbm_config_lib tiff)
+               # Let tiff worry about its own dependencies #395753
+               TIFFLIB_NEEDS_JPEG = N
+               TIFFLIB_NEEDS_Z = N
+               JPEGLIB = $(netpbm_config_lib jpeg)
+               PNGLIB = $(netpbm_config_lib png)
+               ZLIB = $($(tc-getPKG_CONFIG) --libs zlib)
+               LINUXSVGALIB = $(netpbm_config_lib svga vga)
+               XML2_LIBS = $(netpbm_config_lib xml xml2)
+               JBIGLIB = $(netpbm_config_lib jbig)
+               JBIGHDR_DIR =
+               JASPERLIB = NONE
+               JASPERHDR_DIR =
+               URTLIB = $(netpbm_config_lib rle)
+               URTHDR_DIR =
+               X11LIB = $(netpbm_config_lib X X11)
+               X11HDR_DIR =
+       EOF
+}
+
+src_compile() {
+       emake -j1 pm_config.h version.h manual_importinc #149843
+       emake
+}
+
+src_test() {
+       # The code wants to install everything first and then test the result.
+       emake install.{bin,lib,data}
+       emake check
+}
+
+src_install() {
+       # Subdir make targets like to use `mkdir` all over the place
+       # without any actual dependencies, thus the -j1.
+       emake -j1 package pkgdir="${ED}"/usr
+
+       if [[ $(get_libdir) != "lib" ]] ; then
+               mv "${ED}"/usr/lib "${ED}"/usr/$(get_libdir) || die
+       fi
+
+       # Remove cruft that we don't need, and move around stuff we want
+       rm "${ED}"/usr/{README,VERSION,{pkgconfig,config}_template,pkginfo} || 
die
+
+       dodir /usr/share
+       mv "${ED}"/usr/misc "${ED}"/usr/share/netpbm || die
+
+       doman userguide/*.[0-9]
+       dodoc README
+
+       cd doc || die
+       dodoc HISTORY USERDOC
+       docinto html
+       dodoc -r ../userguide/*.html
+}

Reply via email to